Flask, Vue.js 中集成 Bootstrap/BootstrapVue

紧接上一篇 Flask 和 Vue.js 开发及整合部署实例,来体验一下它们与 Bootstrap/BootstrapVue 的集成。漂亮的网站少不得一个好的 CSS 框架,现在有许许多的 CSS 框架可选,纯 CSS 的, 轻量级的, 含 JS 的 CSS 框架,如 Pure, Bulma, Spectre, 国产的 Element 等。而我总觉得 Bootstrap 更是五臟俱全,像 Element 专为 Vue.js 打造的一样,Bootstrap 也有 BootstrpVue 那样一个结晶品。

本文准确的内容应该是关于 Vue.js 与 Bootstrap/BootstrapVue 的话题,与 Flask 没什么事,不过这里呢,还是强拉上 Flask, 由 Flask 的 API 来产生一些数据。

同样是阅读 Flask和Vue.js构建全栈单页面web应用【通过Flask开发RESTful API】的一个实践品。本篇基于 Flask 和 Vue.js 开发及整合部署实例 中的步骤建立的项目 flask-vue-app,方便起见,用了一个新项目名称 flask-vue-bootstrap。记得我们为 Flask 和 Vue.js 分别建立了 backend  和 frontend 两个子项目。

安装体验 Bootstrap

在 frontend 目录中执行

$ npm install bootstrap --save        # 当前(2020-07-04) 安装版本为 bootstrap@4.5.0,锁定版本安装用  npm instll bootstrap@4.5.0 --save

注:忽略 jquery 和 proper.js 的警告,不要安装它们

把  Bootstrap 样式导入到 frontend 项目中,只需要在 frontend/src/main.js 中加上一行

可以想像这一步就完成了 Bootstrap 的 css 和 js 文件的导入,相当于下面两行代码

<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css">
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/js/bootstrap.min.js"></script>

接下来要应用 Bootstrap 的样子,先在 frontend/src/App.vue 的 style 部分中的 #app 块中加上

这样才不至于下面要显示的按钮紧贴着页面顶部,然后在 ping  组件 frontend/components/Ping.vue 中的 <template> 部分修改为

样式 container, btn, 和 btn-primary 就是来自于  Bootstrap

这时候假如  backendfrontend 下还分别运行着

$ python app.py                       # backend 目录下
$ npm run serve                      # frontend 目录下

上边两个服务没运行的话就执行它们,这时候 http://localhost:8080/ping 会自动刷新,显示了 Bootstrap 风格的 pong! 按钮

显示一个 Bootstrap 表格

再来一个例子,做一个显示 Book 列表的页面,Bootstrap 风格,数据由 Flask API 提供。也借些了解一下 Vue.js 的简要开发步骤,完整的  CRUD 程序的开发还要再放一放 

创建一个 Books 组件

需要创建文件 frontend/components/Books.vue 文件,内容为

由以上内容可知,该组件将从 http://localhost:5000/api/books API 获取数据,数据的结构为 [{title: '...', author: '...', read: true/false}, ...]

Vue 的  / 路由指向 Books 组件

更新 fontend/router/index 文件,两处改动

首先引入 Books 组件

再在 const routes 数组中把 path: '/' 的路由更改为

用 http://localhost:8080/ 将能访问 Books 列表。要显示出 Books 列表还需要在  Flask 中创建一个  /api/books API

创建 Flask API /api/books

在 backend/app.py 中添加

我们在 Manning 出版社找了畅销书的前三本,/api/books 返回 JSON 字符串.

打开 http://localhost:8080/, 看到

关于 BootstrapVue

有了 Bootstrap 为什么还要 BootstrapVue 呢?记得前面安装 Bootstrap 时提示有些组件依赖到  jQuery, 而 Vue 使用的是虚拟 DOM, 如果使用 jQuery 来操作 DOM,将无法实现 Vue 的 View 与 Model 的双向绑定。BootstrapVue 解除了 Bootstrap 对 jQuery 的依赖问题,同时 BootstrapVue 还为 Vue 提供了很多标签指令,如 b 开头的 <b-button> 等。

注意:千万不要用 jQuery 去直接操作绑定了 Vue 数据的 DOM 元素。

安装 BootstrapVue, 在 frontend 目录中执行

$ npm install bootstrap-vue --save    # 当前(2020-07-04) 安装的 BootstrapVue 是 2.15.0,所以欲锁定安装版本可用  npm install bootstrap-vue@2.15.0  --save

BootstrapVue 的使用,修改 frontend/src/main.js, 其加加上两行

Vue 组件中应用 BootstrapVue 的实例,可以在 frontend/src/components/Books.vue 中把行

改为

在浏览器中,以上 <b-button> 的写法分别会被渲染为

BootstrapVue 还支持许多的 HTML 组件,特别是在用到 Modal 窗口时应该要用 BootstrapVue 的  <b-modal> 标签,因为 Bootstrap 的 Modal 组件要使用到 jQuery,在 Vue 项目应尽力避免使用 jQuery 来操作 DOM.

再试 Flask 与 Vue.js 的集成

这是一个回顾,具体集成实现的原理见上一篇 Flask 和 Vue.js 开发及整合部署实例。假如现在在项目的根目录,下面命令用于集成 Flask 与 Vue.js,完后只需要启动 Flask

不需要启动 npm run serve 了,直接通过 Flask 的服务访问 http://localhost:5000

这能获得与之前访问 http://localhost:8080 一样的效果。

小结

本文的全部关键操作总结如下,其他都是 Vue 的常规操作了:

  1. npm install bootstrap --save
  2. src/main.js 中加 import 'bootstrap/dist/css/bootstrap.css;
  3. npm install bootstrap-vue --save
  4. src/main.js 中再加 import BootstrapVue from 'bootstrap-vue; , import 'bootstrap-vue/dist/bootstrap-vue.css;  和 Vue.use(BootstrapVue)

本文的完整代码在:https://github.com/yabqiu/flask-vue-bootstrap.git

本文链接 https://yanbin.blog/flask-vue-js-integrate-with-bootstrap-bootstrapvue/, 来自 隔叶黄莺 Yanbin Blog

[版权声明] Creative Commons License 本文采用 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 进行许可。

Subscribe
Notify of
guest


1 Comment
Inline Feedbacks
View all comments
JackZhou
4 years ago

嗯,有了这篇,基本上就解决了使用PYTHON进行WEB前后端开发的问题了。