pip3 install flask

pycharm 创建项目

默认的代码解释说明(及开启debug模式)

#encoding:utf-8
from flask import Flask    #从flask框架中导入flask这个类 app = Flask(__name__)      #初始化一个flask对象,取名叫app,需要传递一个参数,(固定写法,__name__)
                   #1、方便flask框架去寻找资源 2、方便flask插件出现错误时,去定位问题 @app.route('/')          #装饰器,作用为url函数的视图函数的映射
def hello_world():
return 'Hello World!'    #将结果返回给浏览器 if __name__ == '__main__':
app.run(debug=True)            #启动应用服务器,设置debug模式,定为程序出问题时的位置

使用配置文件设置debug模式

#新建config.py文件(这里文件名称自定义,以后所有的配置信息均可添加到这里),添加:
DEBUG=True          #这里debug一定要大写 #主要py文件引用上述文件(flask_test.py)
#encoding:utf-8
from flask import Flask
import config          #引入上面创建的文件 app = Flask(__name__)
app.config.from_object(config)    #app加载文件 @app.route('/')
def hello_world():
return 'Hello World!' if __name__ == '__main__':
app.run(debug=True)

url传参数

#encoding:utf-8
from flask import Flask app = Flask(__name__)

#传递参数
@app.route('/p/<id>')          #参数需要放在“<>”中,并且要与函数中传入的参数同名
def p(id):                #加入参数,函数名称要与上面的路由名称相同
return '请求的参数 %s ' % id if __name__ == '__main__':
app.run(debug=True)

反转url

反转url主要用于模版和页面的重定向(从视图函数到url的转换)

#encoding:utf-8
from flask import Flask,url_for            #导入url_for app = Flask(__name__) @app.route('/')
def index(): print (url_for("p",id='abc'))    #url_for模块使用,这里的的p和test为下面定义的函数名,但是要以字符串的方式写进去,并且如果函数有参数,这里也要写上
print (url_for("test"))
return 'Hello World!' @app.route('/p/<id>')
def p(id):
return '请求的参数 %s ' % id @app.route('/test1/')
def test():
return "反转url测试 test" if __name__ == '__main__':
app.run(debug=True)

打印结果:

url跳转(重定向)及url反转功能应用

#encoding:utf-8
from flask import Flask,url_for,redirect              #导入redirect函数和url_for app = Flask(__name__) @app.route('/')
def index(): return '欢迎来到我的第一个flask首页' @app.route('/question/<is_login>')          #模拟是否登陆,传入参数is_login
def p(is_login):
if is_login == '1':                 #1为登陆成功,其他为失败,失败则跳转到登陆函数(下面的login)
return "跳转到问答界面成功"
else:
return redirect(url_for('login'))      #失败,跳转到登陆函数(界面) @app.route('/login/')                  #登陆函数
def login():
return "请登陆" if __name__ == '__main__':
app.run(debug=True)

#入口url
http://127.0.0.1:5000/question/1(参数)

url跳转及静态文件引入(css文件)示例

利用url_for 从index页面跳转到login页面,加载静态文件

index.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
  <link rel="stylesheet" href="{{ url_for('static',filename='css/index.css') }}">    #加载、static目录下的css目录下的index.css文件
   <script src="{{ url_for('static',filename='js/index.js') }}"></script>         #加载js文件
<body>

  <div class="nav">
        <ul>
<li><a href="{{ url_for('login') }}">登陆</a></li>    #点击登陆从index跳转到login页面
<li><a href="#">发布问答</a></li>
       
</ul>
</div>
{% block main %} {% endblock %}
  <img  src="{{ url_for('static',filename='images/aa.jpg') }}">      #加载image文件
</body>
</html>

flask 安装及基础学习(url_for反转,静态文件引入)的更多相关文章

  1. Django基础,Day7 - 添加静态文件 static files

    添加css样式文件 1.首先在app目录下创建static文件夹,如polls/static.django会自动找到放在这里的静态文件. AppDirectoriesFinder which look ...

  2. springMVC3学习(四)--访问静态文件如js,jpg,css

    如果你的DispatcherServlet拦截的是*.do这样的URL,就不存在访问不到静态资源的问题 如果你的DispatcherServlet拦截了"/"所有的请求,那同时对* ...

  3. Asp .Net core 2 学习笔记(3) —— 静态文件

    这个系列的初衷是便于自己总结与回顾,把笔记本上面的东西转移到这里,态度不由得谨慎许多,下面是我参考的资源: ASP.NET Core 中文文档目录 官方文档 记在这里的东西我会不断的完善丰满,对于文章 ...

  4. django基础知识之管理静态文件css,js,images:

    管理静态文件 项目中的CSS.图片.js都是静态文件 配置静态文件 在settings 文件中定义静态内容 STATIC_URL = '/static/' STATICFILES_DIRS = [ o ...

  5. python的Web框架,Django模板变量,过滤器和静态文件引入

    HTML模板的路径查找 在setting中设置查找路径: #默认的查找在此处填写,优先级最高,为在manage.py的同级路径中,添加(常规是template)文件夹,在(template)文件夹中配 ...

  6. django模板层之静态文件引入优化

    1.新手使用 我们一般在初学django的情况下,引入django的静态文件一般有如下两种方式: 通过路径引用: <script type="text/javascript" ...

  7. EasyUI Tabs + Yii2.0实现iframe方式打开页面(解决共用静态文件引入加载的问题)

    在项目实际开发中,有将打开的各个链接页面隔离的需求(防止静态资源起冲突),这个时候常规思路就是使用iframe来实现!但遇到一个比较棘手的问题,当用easyui Tabs打开一个iframe页面时,怎 ...

  8. django框架中的静态文件引入

    首先在项目文件中新建文件夹static 之后在settings.py中配置路径 如下图所示: 下一步在你刚创建的static文件夹中添加app的文件夹名称,例如:teacher,如下图: 之后在tea ...

  9. 有关PHP安装,基础学习

    首先要安装 wamp 和 NavicatMySQLFront (要在非中文目录下) 打开DW 点击站点 ——新建站点:设置站点名称,选择本地站点文件夹:wap\www 服务器:添加 +    服务器名 ...

随机推荐

  1. 数据库管理 trove openstack

    Trove是数据库即服务的OpenStack.它旨在完全基于OpenStack运行,其目标是允许用户快速轻松地利用关系数据库的功能,而无需处理复杂的管理任务.云用户和数据库管理员可以根据需要配置和管理 ...

  2. 继承&派生 属性查找

    # 在单继承背景下,无论是新式类还是经典类属性查找顺序都一样 # 先object->类->父类->... 实例: class Foo: def f1(self): print('Fo ...

  3. C# 成员默认访问权限(public、private、protected、internal)

    C# 成员默认访问权限(public.private.protected.internal) 来源 https://www.cnblogs.com/yezongjie/p/20181121Access ...

  4. jqGrid 手册 - 搜索

    搜索 类型: colModel Options Toolbar Searching Custom Searching Single field searching Advanced Searching ...

  5. JS简易弹出层

    目标 实现简易的js弹出框.为了简单灵活的在小项目中使用. 实现思路 研究bootstrap的弹出框效果后,认为层级示意图如下: 层说明 弹出层分为三层.最底层的遮罩层,覆盖在浏览器视口上.它之上是弹 ...

  6. 「JLOI2015」骗我呢 解题报告?

    「JLOI2015」骗我呢 这什么神仙题 \[\color{purple}{Link}\] 可以学到的东西 对越过直线的东西翻折进行容斥 之类的..吧? Code: #include <cstd ...

  7. Visible Trees HDU - 2841(容斥)

    对于已经满足条件的(x1,y1),不满足条件的点就是(n*x1,n*y1),所以要求的就是满足点(x,y)的x,y互质,也就是gcd(x,y) == 1,然后就可以用之前多校的方法来做了 另f[i] ...

  8. js获取元素位置和style的兼容性写法

    今天说一下js获取元素位置和style的方法.当然不只是element.style那么简单.. 主角:getBoundingClientRect,getClientRects,getComputedS ...

  9. Git中撤销提交

    Git的几种状态 未修改 原始内容 已修改 ↓ 工 作 区 已暂存 ↓ git add 暂 存 区 已提交 ↓ git commit 本地仓库 已推送 ↓ git push 远程仓库 注意:下面所有命 ...

  10. 洛谷P2261 余数求和

    整除分块的小应用. 考虑到 k % x = k - (k / x) * x 所以把 x = 1...n 加起来就是 k * n - (k / i) * i i = 1...k(注意这里是k) 对于这个 ...