使用Vue.js和Flask来构建一个单页的App的示例
在这个教程中,我们将讲解如何将vue.js单页应用与Flask后端进行连接。 一般来说,如果你只是想通过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的时候。 听起来是不是很有趣?那让我们这样动手做做吧。 完整的源代码,你可以在这里找到: 客户端我将使用Vue CLI产生基本vue.js App。如果你还没有安装它,请运行: 客户端和后端代码将被拆分到不同的文件夹。初始化前端部分运行跟踪: 通过安装向导。我的设置是: Vue 只在运行时构建。 安装Vue-router。 使用ESLint检查代码。 选择一个ESLint 标准预设 。 不试用Karma + Mocha进行单位测试。 不使用Nightwatch建立端到端的测试。 ok,接着来: 这就可以开始安装 vue.js应用程序。让我们从添加一些页面开始吧。添加 home.vue和about.vue到frontend/src/components文件夹。它们非常简单,像这样:Home page and About 我们将使用它们正确地识别我们当前的位置(根据地址栏)。现在我们需要改变 frontend/src/router/index.js文件以便使用我们的新组件:const routes = routerOptions.map(route => {
return { ...route,component: () => import( @/components/${route.component}.vue )} }) Vue.use(Router) 如果你试着输入 localhost:8080和localhost:8080/about,你应该看到相应的页面。我们几乎已经准备好构建一个项目,并且能够创建一个静态资源文件包。在此之前,让我们为它们重新定义一下输出目录。在 frontend/config/index.js找到下一个设置:把它们改为 所以/dist文件夹的HTML、CSS、JS会在同一级目录/frontend 。现在你可以运行 $ npm run build创建一个包。后端 对于Flask服务器,我将使用Python版本3.6。在 /flaskvue创建新的子文件夹存放后端代码并初始化虚拟环境:为了使虚拟环境中运行(MacOS): 在Windows中需要激活此文档(http://pymote.readthedocs.io/en/latest/install/windows_virtualenv.html)。 在虚拟环境下安装: 现在让我们为Flask服务端编写代码。创建根目录文件run.py: 向这个文件添加下一个代码: @app.route('/')
def index(): return render_template("index.html") 这段代码与Flask的 **“Hello World”**代码略有不同。主要的区别是,我们指定存储静态文件和模板位置在文件夹 /dist,以便和我们的前端文件夹区别开。在根文件夹中运行Flask服务端:这将启动本地主机上的Web服务器: localhost:5000上的FLASK_APP服务器端的启动文件,flask_debug = 1将运行在调试模式。如果一切正确,你会看到熟悉的主页,你已经完成了对Vue的设置。同时,如果您尝试输入/about页面,您将面临一个错误。Flask抛出一个错误,说找不到请求的URL。事实上,因为我们使用了HTML5的History-Mode在Vue-router需要配置Web服务器的重定向,将所有路径指向index.html。用Flask做起来很容易。将现有路由修改为以下: ')
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添加下一行: 这里的路径'*'是一个通配符, Vue-router就知道除了我们上面定义的所有其他任何路径。现在我们需要更多的创造NotFound.vue文件在**/components**目录。试一下很简单:404 - Not Found 现在运行的前端服务器再次 npm run dev,尝试进入一些毫无意义的地址例如:localhost:8080/gljhewrgoh。您应该看到我们的“未找到”消息。添加API端我们的 vue.js/flask教程的最后一个例子将是服务器端API创建和调度客户端。我们将创建一个简单的Api,它将从1到100返回一个随机数。打开run.py并添加: app = Flask(name,template_folder = "./dist")
@app.route('/api/random') def random_number(): @app.route('/',defaults={'path': ''}) return render_template("index.html") 首先我导入random库和jsonify函数从Flask库中。然后我添加了新的路由 /api/random来返回像这样的JSON:你可以通过本地浏览测试这个路径: localhost:5000/api/random。此时服务器端工作已经完成。是时候在客户端显示了。我们来改变home.vue组件显示随机数: Home page Random number from backend: {{ randomNumber }} 在这个阶段,我们只是模仿客户端的随机数生成过程。所以,这个组件就是这样工作的:
现在在主页上,你应该看到前端显示我们产生的随机数。让我们把它连接到后端。 为此目的,我将用 axios库。它允许我们用响应HTTP请求并用Json返回JavaScript Promise。我们安装下它:打开 home.vue再在 部分添加一些变化: {
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,让我们安装它: 你可以阅读文档,更好的解释你要使你的服务器怎么样使用CORS。我将使用特定的方法,并将**{“origins”: “*”}**应用于所有/api/*路由(这样每个人都可以使用我的API端)。在run.py加上: 有了这种改变,您就可以从前端调用服务端。 更新: 事实上,如果你想通过Flask提供静态文件不需要CORS。感谢Carson Gee的下面的这一招。 这个主意是这样的。如果应用程序在调试模式下,它只会代理我们的前端服务器。否则(在生产中)只为静态文件服务。所以我们这样做: ')
def catch_all(path):
if app.debug: return requests.get('http://localhost:8080/{}'.format(path)).text return render_template("index.html") 很优雅的魔法:sparkles:! 现在有了一个完整的全栈**(full-stack) 应用程序,用您最喜爱Vue.js和Flask**技术构建。后记 最后,我想就如何改进这个解决方案谈几句话。 首先利用CORS,如果你想让你的API端访问外部的服务器。否则的话只需要使用代理服务器与前端开发技巧。 另一个改进是避免客户端硬编码API路由。也许你需要考虑一些API端点的字典。因此,当您更改API路由时,只需刷新一个字典即可。前端仍然有一个有效的端点。 通常在开发过程中,你将至少有2个终端窗口:一个是Flask和另一个是vue.js。在生产中可以摆脱Vue而只单独运行Node.js服务器。 源代码: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- C++ set_intersection(STL set_intersection)用法
- ruby-on-rails – 在Rails中使用simple_form,nes
- C#中判断一个集合是否是另一个集合的子集的简单方
- Cocos2d-x3.1 粒子效果示例
- Qt:QXMLStreamReader、QXMLStreamWriter,读写XM
- sqlite语法及与sql server 的语法区别
- Swift-UIButton&AlertView
- ruby-on-rails – 使用Rails和Postgres,数据库锁
- c# – XNA:获取一个数组/资源列表?
- ruby-on-rails – Rails 4迁移:Mysql2 ::错误: