Python Flask 简明教程(12)--Flask获取Ajax传输的JSON数据

简介: 本文目录1. 前言2. 创建项目结构3. 发起Ajax请求4. 编写app.py5. 接收JSON数据6. 测试7. 小结

本文目录

1. 前言

2. 创建项目结构

3. 发起Ajax请求

4. 编写app.py

5. 接收JSON数据

6. 测试

7. 小结

1. 前言

上一篇讲了Flask接收URL参数及表单参数,其实这两种方式用的比较少了,现在还是流行通过Ajax传输JSON数据。


本篇就通过一个完整的FlaskWeb项目,演示下如何实现Flask获取Ajax传输的JSON数据。


2. 创建项目结构

使用VSCode创建项目文件夹flask-ajax-demo,结构如下:


其中app.py是Python程序,user.html是静态页面。


3. 发起Ajax请求

编写user.html,代码如下:


<!DOCTYPE html>

<html>

<body>

   <input type="button" value="发送数据" onclick="btnSendData()">

   <script type="text/javascript" src="https://cdn.bootcdn.net/ajax/libs/jquery/1.9.1/jquery.min.js"></script>

   <script>

       function btnSendData() {

           var input = {

               'name': 'tom',

               'password': '123456'

           };

           $.ajax({

               url: '/addUser',

               type: 'post',

               contentType: 'application/json',

               data: JSON.stringify(input),

               success: function (res) {

                   console.log(res);

               }

           });

       }

   </script>

</body>

</html>


首先,我们引用了jquery,以便使用$.ajax发起Ajax请求。


然后,点击【发送数据】按钮时,发送Ajax请求,注意访问路径为/addUser,请求方式post,内容类型application/json。


重点来了,此处要将input对象转换为JSON字符串发送,所以使用JSON.stringify(input)将发送对象转换为JSON字符串。


4. 编写app.py

编写app.py启动程序,然后编写一个路由方法user,以便跳转到user.html:


from flask import Flask, render_template, request

app = Flask(__name__)


@app.route('/user')

def user():

   return render_template('user.html')


if __name__ == '__main__':

   app.run(debug=True)


5. 接收JSON数据

编写addUser方法,接收网页发过来的JSON数据


@app.route('/addUser', methods=['POST'])

def login():

   json = request.json

   print('recv:', json)

   return json


此处注意我们的返回值,也是json类型。


6. 测试

启动程序,访问http://127.0.0.1:5000/user,此时会显示user.html页面,效果如下:


点击按钮,Python控制台打印如下,已成功接收json数据。


recv: {'name': 'tom', 'password': '123456'}

1

查看控制台,输出如下,网页也已经成功接收到后台返回的数据。



7. 小结

本篇演示了如何使用Flask获取Ajax传输过来的JSON数据,还是相当简单的,直接通过request.json即可实现。


相关文章
|
1月前
|
XML 前端开发 JavaScript
PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
48 3
|
2月前
|
前端开发 API 开发者
深度剖析:AJAX、Fetch API如何成为Python后端开发者的最佳拍档!
深度剖析:AJAX、Fetch API如何成为Python后端开发者的最佳拍档!
44 4
|
2月前
|
前端开发 JavaScript API
惊呆了!学会AJAX与Fetch API,你的Python Web项目瞬间高大上!
在Web开发领域,AJAX与Fetch API是提升交互体验的关键技术。AJAX(Asynchronous JavaScript and XML)作为异步通信的先驱,通过XMLHttpRequest对象实现了局部页面更新,提升了应用流畅度。Fetch API则以更现代、简洁的方式处理HTTP请求,基于Promises提供了丰富的功能。当与Python Web框架(如Django、Flask)结合时,这两者能显著增强应用的响应速度和用户体验,使项目更加高效、高大上。
54 2
|
2月前
|
前端开发 API 开发者
从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
从零到精通,AJAX与Fetch API让你的Python Web前后端交互无所不能!
48 3
|
2月前
|
Web App开发 前端开发 JavaScript
Python编程—Ajax数据爬取(一)
Python编程—Ajax数据爬取(一)
67 0
|
2月前
|
前端开发 NoSQL MongoDB
Python编程—Ajax数据爬取(二)
Python编程—Ajax数据爬取(二)
111 0
|
2月前
|
前端开发 API 数据格式
颠覆传统!AJAX、Fetch API与Python后端,开启Web开发新篇章!
在Web开发领域,技术的快速迭代推动着应用不断进化。传统前后端交互方式已无法满足现代Web应用对高效、实时性和用户体验的需求。AJAX作为异步通信的先驱,使页面无需刷新即可更新部分内容,显著提升用户体验;尽管XML曾是其主要数据格式,但如今JSON已成为主流。Fetch API则以其简洁、灵活的特点成为AJAX的现代替代品,基于Promises的异步请求让开发更加高效。与此同时,Python后端凭借高效稳定和丰富的库支持,成为众多开发者的首选,无论是轻量级的Flask还是全功能的Django,都能为Web应用提供强大的支撑。
43 0
|
2月前
|
XML 前端开发 API
惊艳全场的秘诀!AJAX、Fetch API与Python后端,打造令人惊叹的Web应用!
惊艳全场的秘诀!AJAX、Fetch API与Python后端,打造令人惊叹的Web应用!
32 0
|
3月前
|
JSON 前端开发 数据格式
layui 穿梭框transfer组件 数据data用ajax来获取
layui 穿梭框transfer组件 数据data用ajax来获取
238 2
|
5月前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
【7月更文挑战第13天】在Web开发中,AJAX和Fetch API是实现页面无刷新数据交换的关键。在Flask博客系统中,通过创建获取评论的GET路由,我们可以展示使用AJAX和Fetch API的前端实现。AJAX通过XMLHttpRequest发送请求,处理响应并在成功时更新DOM。Fetch API则使用Promise简化异步操作,代码更现代。这两个工具都能实现不刷新页面查看评论,Fetch API的语法更简洁,错误处理更直观。掌握这些技巧能提升Python Web项目的用户体验和开发效率。
73 7