1.redirect和render_template的区别?

redirect:重定向,会改变url

render_template:模板渲染,用模板来渲染当前页,不会改变url

2.关于 'g' 对象踩的坑

【描述】

博客项目,在login请求中设置g对象,在register请求中取得g对象,取得None

@bp.route('/login',methods=('GET','POST'))
def login():
#...
g.myname = 'john' @bp.route('/register',methods=('GET','POST'))
def register():
#...
name = g.get('myname')
print(name) # None

【分析】

文档中说道:To share data that is valid for one request only from one function to another ...

注意是一次请求,一次!

要实现跨request需要用到session

3.从DB取出的博客文章显示最多100个字符,其后的省略,如何实现?

【描述】

最终需要的效果图:

我的数据库:

CREATE TABLE user (
id INTEGER PRIMARY KEY AUTOINCREMENT,
username TEXT UNIQUE NOT NULL,
password TEXT NOT NULL
); CREATE TABLE post (
id INTEGER PRIMARY KEY AUTOINCREMENT,
author_id INTEGER NOT NULL,
created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
title TEXT NOT NULL,
body TEXT NOT NULL,
FOREIGN KEY (author_id) REFERENCES user (id)
);

【解决方案1】

1.写sql的时候这样写 :SUBSTR(p.body,1,100) as body

SELECT p.id , title, SUBSTR(body,1,100) as body,created,author_id,username
FROM post p JOIN user u ON p.author_id = u.id
ORDER BY created DESC

注意一定要定义别名 ... as body,不然会导致在html模板中取不到值

2.前端css代码

font-size:0.6em;
overflow:hidden;
white-space: nowrap;
text-overflow:ellipsis;

【解决方案2】

在模板中使用过滤器(truncatechars),如下将截断100位之后的字符串,并以...表示

<p class="list-group-item-text blog-index-textbody">{{ post['body']|truncatechars:100  }}</p>

4.按照flask官方文档,我在VScode的TERMINAL中运行失败,如何解决?

【描述】

【解决方案】

看了一下VScode的TERMINAL是powershell,CMD 和 powershell 的命令不一样

powershell

> $env:FLASK_APP = "myapp"
> $env:FLASK_ENV="development"
> flask run

CMD

> set FLASK_APP=myapp
> set FLASK_ENV=development
> flask run

【备注】

1.因为导出的环境变量问题,导致windows下初始化db失败(flask init-db),通过上述方案成功解决

2.windows下把这启动flask服务的命令写进bat文件,以后每次只需要运行这个bat文件就可以了,当然命令要用CMD的那个

运行方法: ./start.bat

5.从数据库中博客表(TABLE post)取出的时间(created)不对

【描述】

博客表:

CREATE TABLE post (
id INTEGER PRIMARY KEY AUTOINCREMENT,
author_id INTEGER NOT NULL,
created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
title TEXT NOT NULL,
body TEXT NOT NULL,
FOREIGN KEY (author_id) REFERENCES user (id)
);

其中created字段时间比实际时间早了8小时左右

【解决方案】

网上查了一下是因为时区的关系

记得datetime外层一定要裹上括号

created TIMESTAMP NOT NULL DEFAULT (datetime('now','localtime')),

或者

created TIMESTAMP NOT NULL DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')),

参考:https://www.cnblogs.com/GDLMO/archive/2010/07/19/1780920.html

6.今天碰到操作sqlite的时候出现db locked的情况。

原因是我用了sqlite manager打开了数据库观察,导致删除文章失败。。。呕

7.从后台取到html的数据(博客内容body),反应到模板上显示出了源码,如何解决

【描述】

模板: <p class="list-group-item-text blog-index-textbody">{{ post['body'] }}</p>

显示如下:

【解决方案】

正则去掉标签

8.flask怎么实现点击链接后在新标签页打开?

9.B站发表评论的HTML代码,为什么没有用form?他用的是什么?

估计是ajax

10.用form提交表单后刷新页面,会提示“确认重新提交表单”的警告框,如何解决?

【解决方案】redirect

11.如何实现评论了之后不刷新页面,只刷新评论列表呢?(局部刷新)

【解决方案】ajax

12.一个html里面有多个form表单,如何区别这些表单呢?

【解决方案】

用隐藏输入框<input type="hidden" name="form1"/>

13.删除一篇博客文章后,怎么同时删除留言等信息呢?数据库该如何设计?

【方法一】

利用外键完整性约束,在外键加入ON DELETE CASCADE

DROP TABLE IF EXISTS user;
DROP TABLE IF EXISTS post;
DROP TABLE IF EXISTS comment;
CREATE TABLE user (
id INTEGER PRIMARY KEY AUTOINCREMENT,
username TEXT UNIQUE NOT NULL,
password TEXT NOT NULL
); CREATE TABLE post (
id INTEGER PRIMARY KEY AUTOINCREMENT,
author_id INTEGER NOT NULL,
created TIMESTAMP NOT NULL DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')),
title TEXT NOT NULL,
body TEXT NOT NULL,
FOREIGN KEY (author_id) REFERENCES user (id)
); CREATE TABLE comment (
authorid INTEGER NOT NULL,
postid INTEGER NOT NULL,
userid INTEGER NOT NULL,
ctext TEXT NOT NULL,
ctime TIMESTAMP NOT NULL DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')),
enable_dis BOOLEAN NOT NULL,
reply_targetid INTEGER,
FOREIGN KEY (userid) REFERENCES user (id),
FOREIGN KEY (reply_targetid) REFERENCES user (id),
FOREIGN KEY (authorid) REFERENCES post (author_id),
FOREIGN KEY (postid) REFERENCES post (id) ON DELETE CASCADE
);

注意:sqlite需要手动开启外键完整性约束: sqlite> PRAGMA foreign_keys = ON;

参考:https://blog.csdn.net/qq_34082034/article/details/54927680

14.flask中一个简单的路由系统必须返回一个渲染页面或者重定向页面吗?如果我只是想进行逻辑处理呢?

【描述】

一个简单的路由:

@app.route('/hello')
def hello():
pass
return render_template('index.html')

前端传来一个form想由后端处理,只需要逻辑处理后update一下数据库就行,不用返回新页面,如何实现呢?

【解决方案】ajax

15.【踩坑】模板中注释的语句居然也会被debug检查

【描述】

flask会检查{{...}}里面的内容,而不管在模板中是否被注释。因为路由有所改动,导致报错。。

【解决方案】

删掉,原理请参考源码

16.jinja渲染模板html代码会产生大量空行(空格),如何解决?

在block中加入"-"符号。
例如:
------
{%- if test -%}
{%- endif -%}

[Flask] Flask问题集(后端模板渲染项目)的更多相关文章

  1. 细说后端模板渲染、客户端渲染、node 中间层、服务器端渲染(ssr)

    细说后端模板渲染.客户端渲染.node 中间层.服务器端渲染(ssr) 前端与后端渲染方式的发展大致经历了这样几个阶段:后端模板渲染.客户端渲染.node 中间层.服务器端渲染(ssr). 1. 后端 ...

  2. Python Web Flask源码解读(三)——模板渲染过程

    关于我 一个有思想的程序猿,终身学习实践者,目前在一个创业团队任team lead,技术栈涉及Android.Python.Java和Go,这个也是我们团队的主要技术栈. Github:https:/ ...

  3. Flask框架 请求与响应 & 模板语法

    目录 Flask框架 请求与响应 & 模板语法 简单了解Flask框架 Flask 框架 与 Django 框架对比 简单使用Flask提供服务 Flask 中的 Response(响应) F ...

  4. (4)Flask项目模板渲染初体验

    一.准备静态资源 将项目使用到的静态资源拷贝到static目录 二.创建前台首页html 创建templates/home/home.html页面,内容包含导航和底部版权两部分,中间内容区域为模板标签 ...

  5. Flask(1):基本示例、配置文件、路由、请求和响应、模板渲染

    Flask的特点: - pip install flask - 短小精悍.可扩展性强的 web框架 注意:上下文管理机制 - 依赖 wsgi:werkzeug Flask的简单示例: from fla ...

  6. Flask 的模板渲染

    Flask 的模板渲染 渲染模板语言和django很像,都是用{{}},{%%} 注意点: 1 flask给模板传值,render_template("index.htm",use ...

  7. Flask -- 静态文件 和 模板渲染

    静态文件 一般用于存放图片,样式文件(css, js等) 保存位置:包中或者文件所在目录创建一个 static 目录 访问:在应用中使用 /static/...即可访问 , 更好的方式是使用url_f ...

  8. flask框架下的jinja2模板引擎(1)(模板渲染)

    #转载请留言联系 模板是什么? 在 flask 框架中,视图函数有两个作用:处理业务逻辑和返回响应内容.在大型应用中,把业务逻辑和表现内容放在一起,会增加代码的复杂度和维护成本.模板作用即是承担视图函 ...

  9. Flask模板渲染

    目录 Flask模板渲染 Jinja2模板引擎简介 模板 Jinja2 模板变量 变量 控制结构 宏,类似Python代码中的函数 模板继承 包含(Include) 过滤器 链式调用 常见内建过滤器 ...

随机推荐

  1. shell脚本 mysqldump方式全备份mysql

    一.简介 源码地址 日期:2018/10/8 介绍:mysqldump方式全备份脚本,并保存固定天数的全备份 效果图: 二.使用 适用:centos6+ 语言:中文 注意:使用前先查看脚本,修改对应变 ...

  2. 远程调用RPC

    一.简介 RPC,就是Remote Procedure Call的简称呀,翻译成中文就是远程过程调用. 本地调用,就好比你现在在家里,你要想洗碗,那你直接把碗放进洗碗机,打开洗碗机开关就可以洗了.这就 ...

  3. 转:Android preference首选项框架

    详解Android首选项框架ListPreference 探索首选项框架 在 深入探讨Android的首选项框架之前,首先构想一个需要使用首选项的场景,然后分析如何实现这一场景.假设你正在编写一个应用 ...

  4. LightningChart .NET v.10.2.1已经发布了!

    LightningChart .NET v.10.2.1已经发布了! 了解更多关于兼容性和优化方面的最新改进. 主要改进 我们很高兴地宣布LightningChart .NET产品系列的第三个主要版本 ...

  5. ciscn_2019_en_3

    例行检查我就不放了,64位的程序放入ida中 可以看到s到buf的距离是0x10,因为puts是遇到\x00截止.而且题目没有限制我们s输入的数量,所以可以通过这个puts泄露出libc的基值 很明显 ...

  6. [BUUCTF]REVERSE——[BJDCTF2020]BJD hamburger competition

    [BJDCTF2020]BJD hamburger competition 附件 步骤: 例行检查,64位程序,无壳儿 由于unity是用C++开发的,这里就不用IDA了,直接用dnspy看源码 在B ...

  7. java 图形化小工具Abstract Window Toolit

      老掉牙的历史 Java1.0在发布的时候,就为我们提供了GUI操作的库,这个库系统在所有的平台下都可以运行,这套基本的类库被称作抽象窗口工具集(Abstract Window Toolit),简称 ...

  8. Unhandled Exception: FormatException: Unexpected character

    错误原因 json格式不正确,检查:是否加了注释.最后一个是否加了逗号... 正确格式 { "name": "shellon", "age" ...

  9. 往docker中的mysql导入sql文件

    先把sql文件上传到服务器 然后拷贝sql文件到docker中的mysql 容器中 docker cp test.sql mysql:/test.sql 这里的mysql都是容器名称 根据自己的来 用 ...

  10. cmake之生成动态库

    演示源码下载地址: https://github.com/mohistH/demo_cmake_dylib 把文仅为参考. 以实际情况为准 1.目录结构 │ CMakeLists.txt │ inde ...