国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

詳細講解Flask-Vue前后端分離的過程

89542767 / 1305人閱讀

  寫這篇文章的主要目的是,給大家詳細的進行介紹關于Flask-Vue前后端分離的過程,詳細介紹一下相關代碼的使用規范,以及一些相關實例,希望可以給大家帶來一定的幫助。

 

  最近學習了一下前后端分離技術,前端用的是Vue,后段用的是Flask

 

  vue官方網站:開源框架用的是Javascript框架,vue是前端前進式的框架,具備可視化功能,Vue采用自底向上的增量開發設計。vue是輕量化的框架設計,用起來簡單快速,并且比較的輕便。

 

  vue.js滿足當前移動和PCweb項目的開發需求,框架油然而生,而Vue.js框架便是這樣一種js的框架。它具有兩大核心功能:以海量數據為積累,實現簡單組件化功能。

 

  Flask:用Python實現,是一個web框架,屬于微框架。

 

  1、主要依賴版本

 

  Python:V3.6.4

 

  Vue:V2.9.6

 

  Vue-CLI:V2.9.6

 

  node:v10.6.0

 

  npm:V6.1.0

 

  Flask:V1.0.2

 

  Flask-Cors:V3.0.6

 

  bootstrap:V4.0.0(最新版4.1.2不兼容)

 

  以下項目的創建都是在Python虛擬環境和npm局部安裝的,只有Vue-CLI是全局安裝的。

 

  2、構建Python虛擬環境

 

  防止依賴的混亂,首先創建虛擬環境。

Mac:code hubo$ mkdir flask-vue-crud
Mac:code hubo$ cd flask-vue-crud/
Mac:flask-vue-crud$ python -m venv venv
Mac:flask-vue-crud$ source venv/bin/activate
(venv) Mac:flask-vue-crud hubo$ ls
venv

  第一行創建flask-vue-crud文件夾,第三行創建python虛擬環境python3.3版本可以通過venv模塊,python2版本可以使用virtualenv模塊。

 

  第四行激活虛擬環境。

 

  Windowssource venv/Scripts/activate.bat

 

  Linuxsource venv/bin/activate

 

  3、創建Flask項目

 

  第一步要做的就是安裝FlaskFlask-CORS擴展。

 

  什么是Flask—CORS

 

  假如應用不一樣的協議,又或者是請求來自于其他的IP地址或域名或端口,就需要用到Cross Origin Resource SharingCORS),這正是Flask-CORS擴展幫我們做到的。實際環境中只配置來自前端應用所在的域的請求。

(venv) Mac:flask-vue-crud hubo$ pip install Flask Flask-Cors

  然后在根目錄下創建app.py文件:

from flask import Flask, jsonify
from flask_cors import CORS
app = Flask(__name__)
CORS(app)
@app.route('/', methods=['GET'])
def ping_pong():
    return jsonify('Hello World!')     #(jsonify返回一個json格式的數據)
if __name__ == '__main__':
    app.run()

  然后執行:

(venv) Mac:flask-vue-crud hubo$ python app.py

  打開瀏覽器,輸入http://localhost:5000/ping,會看到輸出

Hello World!

  目前Flask環境已經配置好,并且已經創建了一個FlaskDemo

  4Vue Setup

 

  Vue CLI:官方發布vue.js項目腳手架,使用vue-cli可以快速創建vue項目。

 

  首先全局安裝vue Clinpm install-g(全局安裝)npm下載的國外的依賴,可以使用某寶的cnpm

 

  下載某寶的cnpm

npm install -g cnpm --registry=https://registry.npm.taobao.org

  使用npmcnom下載vue cli

(venv) Mac:flask-vue-crud hubo$ npm insatll -g vue-cli

  查看安裝成功

Mac:~ hubo$ vue -V
2.9.6

  接下來通過webpack初始化一個新的Vue項目client

Mac:flask-vue-crud hubo$ vue init webpack client

? Project name client
? Project description A Vue.js project
? Author hubo <1290259791@qq.com>
? Vue build standalone
? Install vue-router? Yes
? Use ESLint to lint your code? Yes
? Pick an ESLint preset Airbnb
? Set up unit tests No
? Setup e2e tests with Nightwatch? No
? Should we run `npm install` for you after the project has been created? (recom
mended) npm

  主要寫代碼的位置:/flask-vue-crud/client/src/,目錄結構如下所示:

.
├── App.vue
├── assets
│   └── logo.png
├── components
│   ├── HelloWorld.vue
│   └── Ping.vue
├── main.js
└── router
    └── index.js

  各個目錄的意思:

template:組件的 HTML 內容
script: 組件的邏輯代碼(Javascript)
style: 組件的樣式(CSS)

  名字作用

 

  main.js app的入口,它會加載和初始化Vue和根組件

 

  App.vue根組件-其他組件的入口

 

  assets靜態文件如圖片和字體等都放在這里

 

  components UI組件放在這里

 

  router URL同組件的映射關系在這里定義

 

  client/src/components/HelloWord.vue是自動生成的單文件組件,有三部分組成:

 

  運行該程序:

(venv) Mac:flask-vue-crud hubo$ cd client/
(venv) Mac:client hubo$ ls
README.md index.html package.json
build node_modules src
config package-lock.json static
(venv) Mac:client hubo$ npm run dev     啟動dev

  訪問http://localhost:8080能看到前端頁面

 

  5、添加一個新組件

 

  創建client/src/components/Ping.vue:

<template>
  <div>
    <p>{{ msg }}</p>
  </div>
</template>
<script>
export default {
  name: 'Ping',
  data() {
    return {
      msg: 'Hello!',
    };
  },
};
</script>

  更新client/src/router/index.js,映射/pingPing組件:

import Vue from 'vue';
import Router from 'vue-router';
import HelloWorld from '@/components/HelloWorld';
import Ping from '@/components/Ping';

Vue.use(Router);

export default new Router({
  routes: [
    {
      path: '/',
      name: 'HelloWorld',
      component: HelloWorld,
    },
    {
      path: '/ping',
      name: 'Ping',
      component: Ping,
    },
  ],
  mode: 'history',
});

  上面的mode:'history’是為了讓URL變成http://localhost8080/ping的形式。如果,不加該設置,默認的URLhttp://localhost:8080/#/ping的形式。

 

  訪問http://localhost:8080/ping能看到Hello!

 

  6、連接前后段

 

  通過axios發送AJAX請求,安裝axios

import Vue from 'vue';
import Router from 'vue-router';
import HelloWorld from '@/components/HelloWorld';
import Ping from '@/components/Ping';

Vue.use(Router);

export default new Router({
  routes: [
    {
      path: '/',
      name: 'HelloWorld',
      component: HelloWorld,
    },
    {
      path: '/ping',
      name: 'Ping',
      component: Ping,
    },
  ],
  mode: 'history',
});

  更新Ping.vue組件,代碼如下。

<template>
  <div>
    <button type="button" class="btn btn-primary">{{ msg }}</button>
  </div>
</template>

<script>
import axios from 'axios';

export default {
  name: 'Ping',
  data() {
    return {
      msg: 'Hello World!',
    };
  },
  methods: {
    getMessage() {
      const path = 'http://localhost:5000/ping';
      axios.get(path)
        .then((res) => {
          this.msg = res.data;
        })
        .catch((error) => {
          // eslint-disable-next-line
          console.error(error);
        });
    },
  },
  created() {

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/127611.html

相關文章

  • 計算機畢業設計大學英語閱讀大賽管理系統【ssm+vue前后分離】代碼講解安裝調試

    摘要:作者計算機編程吉哥簡介專業從事程序開發,微信小程序開發,定制化項目源碼代碼講解文檔撰寫制作。做自己喜歡的事,生活就是快樂的。 ?作者:計算機編程-吉哥 ?簡介:專業從事JavaWeb程序開發,微信小程序開發,定制化項目、源碼、代碼講解、文檔撰寫、ppt制作。做自己喜歡的事,生活就是快樂...

    hss01248 評論0 收藏0
  • 系統講解 - SSO單點登錄

    摘要:概念英文全稱,單點登錄。登錄如上述流程圖一致。系統和系統使用認證登錄。退出上圖,表示的是從某一個系統退出的流程圖。與的關系如果企業有多個管理系統,現由原來的每個系統都有一個登錄,調整為統一登錄認證。 概念 SSO 英文全稱 Single Sign On,單點登錄。 在多個應用系統中,只需要登錄一次,就可以訪問其他相互信任的應用系統。 比如:淘寶網(www.taobao.com),天貓網...

    Kylin_Mountain 評論0 收藏0
  • webpack工程化集成React技術棧(一)

    項目開始前,我們先聊一聊關于項目的一些說明。該項目起始于2017年初,當時公司主要技術棧為gulp+angular,鑒于react的火熱的生態,在公司決定研發bss管理系統時選用react開發,目的也是為react native打下基礎,以解決后期公司大前端技術棧的逐步成熟。(當時沒有選擇vue開發的主要原因是weex生態還不夠特別成熟),既然決定換新,項目的構建也跟著一起換,從gulp轉向火熱的...

    tianhang 評論0 收藏0
  • 雙十二大前工程師讀書清單

    摘要:本文最早為雙十一而作,原標題雙大前端工程師讀書清單,以付費的形式發布在上。發布完本次預告后,捕捉到了一個友善的吐槽讀書清單也要收費。這本書便從的異步編程講起,幫助我們設計快速響應的網絡應用,而非簡單的頁面。 本文最早為雙十一而作,原標題雙 11 大前端工程師讀書清單,以付費的形式發布在 GitChat 上。發布之后在讀者圈群聊中和讀者進行了深入的交流,現免費分享到這里,不足之處歡迎指教...

    happen 評論0 收藏0
  • 雙十二大前工程師讀書清單

    摘要:本文最早為雙十一而作,原標題雙大前端工程師讀書清單,以付費的形式發布在上。發布完本次預告后,捕捉到了一個友善的吐槽讀書清單也要收費。這本書便從的異步編程講起,幫助我們設計快速響應的網絡應用,而非簡單的頁面。 本文最早為雙十一而作,原標題雙 11 大前端工程師讀書清單,以付費的形式發布在 GitChat 上。發布之后在讀者圈群聊中和讀者進行了深入的交流,現免費分享到這里,不足之處歡迎指教...

    余學文 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<