python flask jinja2使用Vue,并解决jinja2和vue冲突

2024-04-01 05:48

本文主要是介绍python flask jinja2使用Vue,并解决jinja2和vue冲突,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://www.axios-js.com/zh-cn/docs/
axios官网

方法1

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="https://cdn.jsdelivr.net/npm/vue"></script><script src="https://code.jquery.com/jquery-3.2.1.min.js"></script><script src="https://unpkg.com/axios/dist/axios.min.js"></script></head>
<body><div id="app"><select ><option v-for="item in selects" :value="item">[[item]]</option></select><h2>{{item}}</h2><div v-for="udata in userData">[[ udata.name ]]</div></div><script>const vue = new Vue({el:"#app",delimiters: ["[[", "]]"],data:{selects:['enu','cha'],userData:[]},created: function() {var self = thisaxios.get('/api/tasks').then(function (response) {self.userData = (response.data);}).catch(function (error) {console.log(error);});// $.getJSON('/api/tasks', function(data) {//     console.log(data);//     self.userData = data;//     console.log(self.userData);// })}})</script>
</body></html>

WanmaitFlask这种方式是直接disable掉jinjia2的

from flask import Flask
from flask import render_template
from flask import jsonifyclass WanmaitFlask(Flask):jinja_options = Flask.jinja_options.copy()jinja_options.update(dict(variable_start_string='%%',# Default is '{{', I'm changing this because Vue.js uses '{{' / '}}'variable_end_string='%%',))
app=WanmaitFlask(__name__)@app.route("/test")
def test():return render_template("test.html",item=[123,345])@app.route("/api/tasks")
def tasks():lists=[{"name":"123"},{"name":"123"},{"name":"123"},{"name":"123"}]return jsonify(lists)if __name__ == '__main__':app.run("0.0.0.0",8888,debug=True)

https://www.jb51.net/zt/jquerydown.htm
这是js 路径

方法2 更改vue的数据绑定方式

from flask import Flask
from flask import render_template
from flask import jsonify# class WanmaitFlask(Flask):
#     jinja_options = Flask.jinja_options.copy()
#     jinja_options.update(dict(variable_start_string='%%',
#                               # Default is '{{', I'm changing this because Vue.js uses '{{' / '}}'
#                               variable_end_string='%%',))
app=Flask(__name__)@app.route("/test")
def test():return render_template("test.html",item=[123,345])@app.route("/api/tasks")
def tasks():lists=[{"name":"123"},{"name":"123"},{"name":"123"},{"name":"123"}]return jsonify(lists)if __name__ == '__main__':app.run("0.0.0.0",8888,debug=True)
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="https://cdn.jsdelivr.net/npm/vue"></script><script src="https://code.jquery.com/jquery-3.2.1.min.js"></script><script src="https://unpkg.com/axios/dist/axios.min.js"></script></head>
<body><div id="app"><select ><option v-for="item in selects" :value="item">[[item]]</option></select><h2>{{item}}</h2><div v-for="udata in userData">[[ udata.name ]]</div></div><script>const vue = new Vue({el:"#app",delimiters: ["[[", "]]"],data:{selects:['enu','cha'],userData:[]},created: function() {var self = thisaxios.get('/api/tasks').then(function (response) {self.userData = (response.data);}).catch(function (error) {console.log(error);});// $.getJSON('/api/tasks', function(data) {//     console.log(data);//     self.userData = data;//     console.log(self.userData);// })}})</script>
</body></html>

****delimiters: ["[[", “]]”],这句话是很重要的,就是把{undefined{}}改成[[]]

这篇关于python flask jinja2使用Vue,并解决jinja2和vue冲突的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/866356

相关文章

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

解决Spring运行时报错:Consider defining a bean of type ‘xxx.xxx.xxx.Xxx‘ in your configuration

《解决Spring运行时报错:Considerdefiningabeanoftype‘xxx.xxx.xxx.Xxx‘inyourconfiguration》该文章主要讲述了在使用S... 目录问题分析解决方案总结问题Description:Parameter 0 of constructor in x

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在