您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
三六零分类信息网 > 佳木斯分类信息网,免费分类信息发布

Vue.js+Flask做出手机App

2026/1/6 5:00:58发布43次查看
这次给大家带来vue.js+flask做出手机app,vue.js+flask做出手机app的注意事项有哪些,下面就是实战案例,一起来看一下。
一般来说,如果你只是想通过flask模板使用vue.js库也是没有问题的。但是,实际上是一个很明显的问题那就是,jinja(模板引擎)也和vue.js一样采用双大括号用于渲染,但只是一个还算过的去的解决方案。
我想要一个不同的例子。如果我需要建立一个单页应用程序(应用程序使用单页组成, vue-router 在html5的history-mode以及其他更多好用的功能)用vue.js,由flask提供web服务?简单地说应该这样,如下所示:
flask为 index.html 服务, index.html 包含我的vue.js app。
在前端开发中我使用webpack,它提供了所有很酷的功能。
flask有api端,我可以从我的spa访问。
我可以访问api端,甚至当我为了前端开发而运行node.js的时候。
听起来是不是很有趣?那让我们这样动手做做吧。
完整的源代码,你可以在这里找到:https://github.com/oleg-agapov/flask-vue-spa
客户端
我将使用vue cli产生基本vue.js app。如果你还没有安装它,请运行:
$ npm install -g vue-cli
客户端和后端代码将被拆分到不同的文件夹。初始化前端部分运行跟踪:
$ mkdir flaskvue$ cd flaskvue$ vue init webpack frontend
通过安装向导。我的设置是:
vue 只在运行时构建。
安装vue-router。
使用eslint检查代码。
选择一个eslint 标准预设 。
不试用karma + mocha进行单位测试。
不使用nightwatch建立端到端的测试。
ok,接着来:
$ cd frontend$ npm install# after installation$ npm run dev
这就可以开始安装 vue.js 应用程序。让我们从添加一些页面开始吧。
添加 home.vue 和 about.vue 到 frontend/src/components 文件夹。它们非常简单,像这样:
// home.vue<template><p><p>home page</p></p></template>
and
// about.vue<template><p><p>about</p></p></template>
我们将使用它们正确地识别我们当前的位置(根据地址栏)。现在我们需要改变 frontend/src/router/index.js 文件以便使用我们的新组件:
import vue from 'vue'import router from 'vue-router'const routeroptions = [{ path: '/', component: 'home' },{ path: '/about', component: 'about' }]const routes = routeroptions.map(route => {return {...route,component: () => import(`@/components/${route.component}.vue`)}})vue.use(router)export default new router({routes,mode: 'history'})
如果你试着输入 localhost:8080 和 localhost:8080/about ,你应该看到相应的页面。
我们几乎已经准备好构建一个项目,并且能够创建一个静态资源文件包。在此之前,让我们为它们重新定义一下输出目录。在 frontend/config/index.js 找到下一个设置:
index: path.resolve(__dirname, '../dist/index.html'),assetsroot: path.resolve(__dirname, '../dist'),
把它们改为
index: path.resolve(__dirname, '../../dist/index.html'),assetsroot: path.resolve(__dirname, '../../dist'),
所以/dist文件夹的html、css、js会在同一级目录/frontend 。现在你可以运行 $ npm run build 创建一个包。
后端
对于flask服务器,我将使用python版本3.6。在 /flaskvue 创建新的子文件夹存放后端代码并初始化虚拟环境:
$ mkdir backend$ cd backend$ virtualenv -p python3 venv
为了使虚拟环境中运行(macos):
$ source venv/bin/activate
在windows中需要激活此文档(http://pymote.readthedocs.io/en/latest/install/windows_virtualenv.html)。
在虚拟环境下安装:
(venv) pip install flask
现在让我们为flask服务端编写代码。创建根目录文件run.py:
(venv) cd ..(venv) touch run.py
向这个文件添加下一个代码:
from flask import flask, render_templateapp = flask(__name__,static_folder = ./dist/static,template_folder = ./dist)@app.route('/')def index():return render_template(index.html)
这段代码与flask的 **“hello world”**代码略有不同。主要的区别是,我们指定存储静态文件和模板位置在文件夹 /dist ,以便和我们的前端文件夹区别开。在根文件夹中运行flask服务端:
(venv) flask_app=run.py flask_debug=1 flask run
这将启动本地主机上的web服务器: localhost:5000 上的 flask_app 服务器端的启动文件, flask_debug = 1 将运行在调试模式。如果一切正确,你会看到熟悉的主页,你已经完成了对vue的设置。
同时,如果您尝试输入/about页面,您将面临一个错误。flask抛出一个错误,说找不到请求的url。事实上,因为我们使用了html5的history-mode在vue-router需要配置web服务器的重定向,将所有路径指向index.html。用flask做起来很容易。将现有路由修改为以下:
@app.route('/', defaults={'path': ''})@app.route('/<path:path>')def catch_all(path):return render_template(index.html)
现在输入网址localhost:5000/about 将重新定向到index.html和vue-router将处理路由。
添加404页
因为我们有一个包罗万象的路径,我们的web服务器在现在已经很难赶上404错误,flask将所有请求指向index.html(甚至不存在的页面)。所以我们需要处理未知的路径在vue.js应用。当然,所有的工作都可以在我们的路由文件中完成。
在frontend/src/router/index.js添加下一行:
const routeroptions = [{ path: '/', component: 'home' },{ path: '/about', component: 'about' },{ path: '*', component: 'notfound' }]
这里的路径'*'是一个通配符, vue-router 就知道除了我们上面定义的所有其他任何路径。现在我们需要更多的创造 notfound.vue 文件在**/components**目录。试一下很简单:
// notfound.vue<template><p><p>404 - not found</p></p></template>
现在运行的前端服务器再次 npm run dev ,尝试进入一些毫无意义的地址例如: localhost:8080/gljhewrgoh 。您应该看到我们的“未找到”消息。
添加api端
我们的 vue.js/flask 教程的最后一个例子将是服务器端api创建和调度客户端。我们将创建一个简单的api,它将从1到100返回一个随机数。
打开run.py并添加:
from flask import flask, render_template, jsonifyfrom random import *app = flask(__name__,static_folder = ./dist/static,template_folder = ./dist)@app.route('/api/random')def random_number():response = {'randomnumber': randint(1, 100)}return jsonify(response)@app.route('/', defaults={'path': ''})@app.route('/<path:path>')def catch_all(path):return render_template(index.html)
首先我导入random库和jsonify函数从flask库中。然后我添加了新的路由 /api/random 来返回像这样的json:
{randomnumber: 36}
你可以通过本地浏览测试这个路径: localhost:5000/api/random。
此时服务器端工作已经完成。是时候在客户端显示了。我们来改变home.vue组件显示随机数:
<template><p><p>home page</p><p>random number from backend: {{ randomnumber }}</p><button @click="getrandom">new random number</button></p></template><script>export default {data () {return {randomnumber: 0}},methods: {getrandomint (min, max) {min = math.ceil(min)max = math.floor(max)return math.floor(math.random() * (max - min + 1)) + min},getrandom () {this.randomnumber = this.getrandomint(1, 100)}},created () {this.getrandom()}}</script>
在这个阶段,我们只是模仿客户端的随机数生成过程。所以,这个组件就是这样工作的:
在初始化变量 randomnumber 等于0。
在methods部分我们通过 getrandomint(min, max) 功能来从指定的范围内返回一个随机数, getrandom 函数将生成随机数并将赋值给 randomnumber
组件方法 getrandom 创建后将会被调用来初始化随机数
在按钮的单击事件我们将用 getrandom 方法得到新的随机数
现在在主页上,你应该看到前端显示我们产生的随机数。让我们把它连接到后端。
为此目的,我将用 axios 库。它允许我们用响应http请求并用 json 返回 javascript promise 。我们安装下它:
(venv) cd frontend(venv) npm install --save axios
打开 home.vue 再在 <script> 部分添加一些变化:
import axios from 'axios'methods: {getrandom () {// this.randomnumber = this.getrandomint(1, 100)this.randomnumber = this.getrandomfrombackend()},getrandomfrombackend () {const path = `http://localhost:5000/api/random`axios.get(path).then(response => {this.randomnumber = response.data.randomnumber}).catch(error => {console.log(error)})}}
在顶部,我们需要引用axios库。然后有一个新的方法 getrandomfrombackend 将使用axios异步调用api和检索结果。最后, getrandom 方法现在应该使用 getrandomfrombackend 函数得到一个随机值。
保存文件,到浏览器,运行一个开发服务器再次刷新 localhost:8080 。你应该看到控制台错误没有随机值。但别担心,一切都正常。我们得到了 cors 的错误意味着flask服务器api默认会关闭其他web服务器(在我们这里,vue.js app是在 node.js服务器上运行的应用程序)。如果你 npm run build 项目,那在 localhost:5000 (如flask服务器)你会看到app在工作的。但是,每次对客户端应用程序进行一些更改时,都创建一个包并不十分方便。
让我们用打包了cors插件的flask,将使我们能够创建一个api访问规则。插件叫做flaskcors,让我们安装它:
(venv) pip install -u flask-cors
你可以阅读文档,更好的解释你要使你的服务器怎么样使用cors。我将使用特定的方法,并将**{“origins”: “*”}**应用于所有/api/*路由(这样每个人都可以使用我的api端)。在run.py加上:
from flask_cors import corsapp = flask(__name__,static_folder = ./dist/static,template_folder = ./dist)cors = cors(app, resources={r/api/*: {origins: *}})
有了这种改变,您就可以从前端调用服务端。
更新:
事实上,如果你想通过flask提供静态文件不需要cors。感谢carson gee的下面的这一招。
这个主意是这样的。如果应用程序在调试模式下,它只会代理我们的前端服务器。否则(在生产中)只为静态文件服务。所以我们这样做:
import requests@app.route('/', defaults={'path': ''})@app.route('/<path:path>')def catch_all(path):if app.debug:return requests.get('http://localhost:8080/{}'.format(path)).textreturn render_template(index.html)
很优雅的魔法:sparkles:!
现在有了一个完整的全栈**(full-stack) 应用程序,用您最喜爱 vue.js 和 flask**技术构建。
后记
最后,我想就如何改进这个解决方案谈几句话。
首先利用cors,如果你想让你的api端访问外部的服务器。否则的话只需要使用代理服务器与前端开发技巧。
另一个改进是避免客户端硬编码api路由。也许你需要考虑一些api端点的字典。因此,当您更改api路由时,只需刷新一个字典即可。前端仍然有一个有效的端点。
通常在开发过程中,你将至少有2个终端窗口:一个是flask和另一个是vue.js。在生产中可以摆脱vue而只单独运行node.js服务器。
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
vue封装轻量级文件上传组件
使用iscroll做出网页内容滚动
以上就是vue.js+flask做出手机app的详细内容。
佳木斯分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product