Flask应用中通过HTML单击实现Python调用的简单示例

需积分: 9 0 下载量 28 浏览量 更新于2024-11-23 收藏 2KB ZIP 举报
资源摘要信息:"本文档是一个关于如何使用Flask框架创建一个简单的Python应用程序,该应用程序可以通过单击HTML页面上的元素来触发。Flask是一个轻量级的Web应用框架,它是用Python编写的,适用于快速开发Web应用。本示例展示了最基本的Flask应用结构,以及如何在前端HTML文件中嵌入JavaScript代码以与后端Python代码交互。 首先,这个示例涉及以下几个关键知识点: 1. Flask框架介绍:Flask是一个使用Python编写的轻量级Web框架,它提供了构建Web应用所需的各种工具和功能。它易于上手,适合初学者快速开发小型项目。 2. HTML与Python的交互:在Web开发中,HTML主要负责页面的结构和内容的展示,而Python则用于处理服务器端逻辑。在本示例中,我们将学习如何通过HTML元素的点击事件发起对Flask应用的HTTP请求,从而触发Python中的相应处理函数。 3. 路由(Routing):在Flask中,路由是指定URL与特定Python函数之间的映射关系。当用户访问一个URL时,Flask会根据路由找到相应的函数来处理请求。 4. Jinja2模板引擎:Flask使用Jinja2作为其模板引擎,允许开发者将Python代码嵌入到HTML模板中,生成动态的HTML内容。 5. 前后端数据交互:了解前端JavaScript如何通过AJAX或表单提交等方式与后端的Flask应用进行数据交互。 接下来详细解释这些知识点: 1. Flask框架介绍: Flask允许开发者使用Python编写Web应用,它小巧灵活,但功能强大。Flask提供了一个核心功能,即对Web请求的路由映射,支持请求分发以及渲染响应内容。它还提供了开发时的调试工具,使得开发者可以更加方便地测试和开发应用程序。 2. HTML与Python的交互: 在本示例中,HTML页面通过JavaScript与用户交互,并在用户执行操作(比如点击按钮)时,JavaScript会发起一个AJAX请求到服务器端的Python Flask应用。这个请求会触发相应的Python函数,执行必要的逻辑,并返回结果给前端页面,完成一个完整的用户交互流程。 3. 路由(Routing): 在Flask应用中,定义路由非常简单,只需要在函数上使用装饰器@app.route()即可。例如,@app.route('/hello')会将URL '/hello' 映射到一个处理函数上,当用户访问'/hello'时,该函数就会被调用。路由可以包含变量,可以指定HTTP方法,还可以设置不同的URL变量规则。 4. Jinja2模板引擎: Jinja2是Flask的内置模板引擎,它允许开发者在HTML模板中嵌入Python代码,如变量表达式、条件判断和循环等。模板会被渲染成最终的HTML代码发送给用户浏览器。 5. 前后端数据交互: 在Web应用中,前端和后端的交互是通过HTTP请求完成的。本示例中,JavaScript可以使用AJAX方法(如fetch API)向Flask后端发起异步请求。Flask接收到这些请求后,根据路由将请求分发给相应的处理函数,并将处理结果返回给前端。前端收到数据后,可以利用JavaScript更新页面内容,从而实现动态的用户界面。 总结来说,本示例提供了一个基础的Web应用框架,演示了如何通过Flask和HTML构建一个简单的Web应用,并通过用户交互(如点击按钮)触发服务器端的Python处理逻辑。对于开发者来说,这是一个学习Flask框架、前后端交互以及Web开发基本概念的良好起点。"
2023-05-05 上传

{% extends "admin/base.html" %} {% block content %}

药品相互作用

{% for interaction in interactions %} {% empty %} {% endfor %}
ID 药品1 药品2 相互作用 操作
{{ interaction.id }} {{ interaction.drug1 }} {{ interaction.drug2 }} {{ interaction.interaction }} 编辑 <form action="{% url 'admin:drug_db_drug_interaction_delete' interaction.id %}" method="post" class="d-inline"> {% csrf_token %} <button class="btn btn-danger btn-sm">删除</button> </form>
暂无药品相互作用
添加新药品相互作用
{% endblock %} 需要定义那些视图和建那些文件

2023-05-18 上传