如果一个服务端模版渲染用 Jinja2 的项目想引入 Vue

2020-12-20 05:24:19 +08:00
 Livid
会遇到一个问题就是 Vue 和 Jinja2 都用了 {{ variable }} 这样的方式来输出变量。

目前搜到的一个解决方法是:

https://blog.fusionscript.info/flask/2018/03/06/using-vue-and-jinja-together.html

大家还有什么别的思路么?
4725 次点击
所在节点    Vue.js
8 条回复
skenan
2020-12-20 05:53:27 +08:00
之前也研究过这个问题,可以修改 vue 的 delimiter https://testdriven.io/blog/combine-flask-vue/
Dreax
2020-12-20 05:55:43 +08:00
loading
2020-12-20 06:01:29 +08:00
我在 golang 里也遇到类似问题。基本就是后端前端选一个改,我选择改前端,也就是一楼的方法。
纯 api 不用模板体验并不好,所以还是必须混合用。
Yuxiaoy
2020-12-20 09:33:10 +08:00
https://greyli.com/jinja2-and-js-template/
看下李辉的几个解决方案
zjsxwc
2020-12-20 10:24:24 +08:00
vue 代码单独写到 *.vue 文件里面,
jinja 搞个自定义 tag 类似 include 的无脑复制*.vue 文件内容就行。
mxT52CRuqR6o5
2020-12-20 10:34:21 +08:00
最简单的方法,不使用{{}}给 vue 输出变量,而是用 v-text 输出,啥配置都不用改
falcon05
2020-12-20 12:48:30 +08:00
之前我也用 twig 模板引擎也遇到这种问题,这个 stackoverflow 链接提供几种解决方法: https://stackoverflow.com/questions/31480612/conflict-on-template-of-twig-and-vue-js/31525899
dingyaguang117
2020-12-20 23:32:39 +08:00
我一直是用 {% raw %}

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/737145

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX