• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Vue和Flask通信的实现

vue 搞代码 4年前 (2022-01-08) 17次浏览 已收录 0个评论
文章目录[隐藏]

最近新做了个项目,前端使用的是目前很流行的前端框架,对于后端,本项目选择的是比较好上手、轻量级的python后台框架:Flask。感兴趣的可以了解一下

安装axios和实现通信

这里我们通过axios来连接Vue前端和Flask后端,使用AJAX请求进行通信。使用如下命令安装

 npm install axios

axios的使用格式:

 import axios from 'axios'; export default { data: function () { return { serverResponse: 'res_test' }; }, methods: { getData() { // 设置对应<mark style="color:transparent">本文来源gaodaimacom搞#^代%!码&网*</mark>python的接口,这里使用的是localhost:5000 const path = 'http://127.0.0.1:5000/getMsg'; // 这里要使用 res =>表示返回的数据 axios.get(path).then(res => { // 这里服务器返回response为一个json对象 // 通过.data来访返回的数据,然后在通过.变量名进行访问 // 可以直接通过response.data取得key-value var msg = res.data.msg; this.serverResponse = msg; // 因为不能直接使用this作为指针,因此在这之前将this赋给了then指针 alter('Success' + response.status + ',' + response.data + ',' + msg); // 成功后显示提示 }).catch(error => { console.error(error); }); } }, } 

代码及演示

前端代码

对./components/HelloWorld.vue文件进行改写。代码如下:

 <!-- html部分 --> <div> <span>{{ serverResponse }}</span><!--这里使用{{}}来引用JavaScript中赋给this的值--><button>get data</button></div><!-- js部分 --><!-- css部分 --><!-- Add "scoped" attribute to limit CSS to this component only --> h1, h2 { font-weight: normal; } ul { list-style-type: none; padding: 0; } li { display: inline-block; margin: 0 10px; } a { color: #42b983; } 

这里主要实现了通过单击按钮来和服务器端进行交互获得数据并传回前端,将得到的数据重新来对前端进行渲染。

得到如上页面之后,我们单击get date按钮,就会像后端发送GET请求,后端服务器监听到请求之后就会返回对应的数据。

客户端代码

 from flask import Flask from flask import jsonify from flask_cors import CORS app = Flask(__name__) cors = CORS(app, resources={r"/getMsg": {"origins": "*"}}) @app.route('/') def hello_world(): return 'test!' # 监听127.0.0.1:5000/getMsg请求 @app.route('/getMsg', methods=['GET', 'POST']) def home(): response = { 'msg': 'Hello, Python !' } return response if __name__ == '__main__': app.run() 

到此这篇关于Vue和Flask通信的实现的文章就介绍到这了,更多相关Vue和Flask通信内容请搜索gaodaima搞代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持gaodaima搞代码网

以上就是Vue和Flask通信的实现的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Vue和Flask通信的实现

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址