隐藏页面特效

django学习第四天----mark_safe的用法,静态文件配置,用指令创建django项目应用注意点,ORM介绍,创建表执行命令,模板渲染补充(组件),inclusion_tag 自定义标签

1|0补充第三天跟safe差不多的一个方法


  • templatetags文件夹
自定义的py文件 需要先导入模块 from django.utils.safestring import mark_safe @register.simple_tag def atag(v1,v2): print(v1,v2) return mark_safe('<a href=''>百度</a>') html文件 {% atag a b %} #用mark_safe方法跟safe过滤器是一样的

2|0静态文件配置


  • 1.在项目根目录下创建一个文件夹,名称随便,比如叫作static_file,用来存放我们的静态文件(js/css/图片文件等等)

  • 2.在settings.py配置文件中写上如下内容

STATIC_URL = '/static/' #静态文件夹路径别名 随便起 STATICFILES_DIRS = [ os.path.join(BASE_DIR,'static_file') #拼接存放静态文件的静态文件夹路径 ]

  • 3.使用静态文件配置路径
三种写法 1.<link rel='stylesheet' href='/static/css/style_css.css'> 2.html文件中{% load static %} 使用:<link rel ='stylesheet' href="{% static 'css/style_css.css' %}"> #推荐只用第二种 3.html文件中{% load static %} <link rel='stylesheet' href="{% get_static_prefix %}css/style_css.css"> 引入js文件 <script src='/static/js/xx.js/'></script>

  • 4.js文件外部引入的问题导致的问题
html文件中js代码用外部引入情况时,并且js代码中有需要替换的字符串(即模板渲染),此时把js代码用外部引入的方式引入到html中,渲染效果不会生效。 原因:首先后台传入数据到html文件中进行模板渲染字符串替换,从上到下执行,未找到htmljs处的模板渲染,也就是还是没有调用js代码,所以没法渲染,当读取完浏览器加载运行代码时候才发送调用js代码请求,这时候模板渲染那段时间早就过去了,所以没有成功渲染。 解决办法:只能在html中写需要模板渲染的js代码,不要用外部引入的方式。

3|0用指令创建django项目应用注意点


  • 1.首先在项目目录下执行以下命令
python manage.py startapp app01
  • 2.然后再settings.py配置文件中的INSTALLED_APPS这一项配置列表里面,加上应用名称
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', # 'app01.apps.App01Config', #全称 'app01', #简写 ] 如果没有配置应用,那么在应用中写逻辑时,django框架提供的很多功能,是没有调用的,凡是手动创建的应用,都需要在这里配置一下

4|0ORM


  • object relational mapping,对象关系映射。主要完成的就是数据库操作。
1.MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的工作量,不需要面对因数据库变更而导致的无效劳动 2.ORM是“对象-关系-映射”的简称。(Object Relational Mapping,简称ORM)(将来会学一个sqlalchemy,是和他很像的,但是djangoorm没有独立出来让别人去使用,虽然功能比sqlalchemy更强大,但是别人用不了) 3.类对象--->sql--->pymysql--->mysql服务端--->磁盘,orm其实就是将类对象的语法翻译成sql语句的一个引擎,明白orm是什么了,剩下的就是怎么使用orm,怎么来写类对象关系语句。
  • 总结
优点: 开发效率高,应用程序开发程序员对类对象关系,比对sql语句要熟练一些 迁移数据库时只需要修改配置,orm就能够帮我们将类对象关系翻译成对应数据库的sql语句 缺点: 效率相对低,因为orm有一个翻译动作,现将orm语句翻译成sql语句,再去数据库里面执行,比直接写的原生sql语句多了一步翻译动作,所以效率相对低一些

4|1创建表


  • 在应用文件夹下的models.py文件中写上如下内容
from django.db import models class Book(models.Model): id = models.AutoField(parimary_key=True) #主键,自增 title = models.CharField(max_length=64,null=True)#不定长64位,可以为空 state = models.BooleanField(default=True)#设置默认值为True 布尔类型 price = models.DecimalField(max_digits=20,decimal_places=5)#总长度20,小数位5 publish = models.CharFiles(max_length=32) #不定长32位
对应的sql语句 create table book( id int primary key auto_increment, title varchar(64), state boolean not null default true, pub_date date not null, price decimal(20,5) not null, publish varchar(32) not null )
  • 类写完之后,执行数据库同步(迁移)指令才能生成表
python manage.py makemigrations #在应用的migrations文件夹中生成迁移文件(也就是记录文件) python manage.py migrate #执行对应的记录文件,翻译成sql语句并到数据库中执行对应的sql来创建表

5|0pycharm提供的数据库图形化界面工具的使用


  • SQLite的
Database处选择SQLite,然后下载驱动就可以了。
  • mysql的
第一步:去mysql里面创建一个库 create database orm01 default charset=utf8mb4; 第二步:将setting.py配置文件的DATABASSES配置改成如下内容 #完整连接数据库的指令:mysql -h 127.0.0.1 -p 3306 -u root -p666 DATABASES = { 'default':{ 'ENGINE':'django.db.backends.mysql', 'NAME':'orm01', #数据库名 'HOST':'127.0.0.1', #ip 'PORT':3306, #端口 'USER':'root', #数据库用户 'PASSWORD':'666' #自己数据库密码 } } #注意:字典中的每一项名称都是固定写法,并且必须都是大写 第三步:指定django连接mysqlpython模块 1.下载pymysql pip install pymysql 2.指定连接模块,需要在项目主目录下的__init__.py文件中来指定,如下 import pymysql pymysql.install_as_MySQLdb() 第四步:执行数据库同步指令 python manage.py makemigrations python manage.py migrate 第五步:通过pycharm提供的操作数据库的图形界面工具来连接一下mysql 在左边database里面选择mysql,然后下载驱动,就可以了。 这边下载驱动遇到的一个问题: Server returns invalid timezone. Go to 'Advanced' tab and set 'serverTimezon'。错误原因是时区错误,MySQL默认的时区是UTC时区,比北京晚8个小时,所以要修改mysql的时长。 解决办法: 先登录mysql,然后查看下时区,命令:show variables like'%time_zone'; 如果value显示的是SYSTEM,就表示没有设置时区。 设置时区命令:set global time_zone = '+8:00'; 执行完命令后,再去连接下载驱动,就可以了。

5|1models添加字段后执行migrations遇到的问题


You are trying to add a non-nullable field 'state' to book without a default; we can't do that (the database needs something to populate existing rows). Please select a fix: 1) Provide a one-off default now (will be set on all existing rows with a null value for this column) 2) Quit, and let me add a default in models.py Select an option: 出现问题的原因就是,比如新增的state属性对应的字段,默认是不能为空的,如果我们没有设置它的可以为空,或没有给它设置默认值,那么如果数据表中有了几行数据,那么这几行中的新增的这一列数据,就没有办法自动添加数据,orm不知道给你添加什么数据,所以遇到了上面的报错情况,上面的报错请求就是告诉你,给新添加的字段添加默认值,或者设置可以为空才行。 解决办法: 1.直接在提示信息:输入默认值,然后回车 2.退出窗口,在state = models.BooleanField(null=True) 或者 state = models.BooleanField(default='默认值'),然后再执行数据库同步指令

5|2数据库同步指令执行顺序 如下图


6|0模板渲染补充(组件)


  • 组件
组件就是一个html,其中封装了一些特定功能,比如就是一个导航栏,或者就是一个左侧菜单,想当我们将一些听定功能封装成了一个组件,将来任何其他html文件中如果使用这部分功能,可以直接引入使用。
  • 使用django模板渲染系统中使用组件的步骤
第一步:创建组件的html文件,名字随便取,比如叫作zujian.html,比如内容如下,做一个顶部导航栏组件 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>zujian</title> <style> .nav{ background-color: blue; height: 100px; } .nav a{ color:white; } </style> </head> <body> <div class="nav"> <a href="">百度</a> <a href="">京东</a> <a href="">个人中心</a> </div> </body> </html> 第二步:使用组件,需要借助下面这个标签 {% include '组件文件名称.html' %} 示例:比如我们需要某个html文件中使用,比如show.html文件中使用,show.html文件内容如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> {# <style>#} {# .nav{#} <!-- 可以修改样式,但是注意权重问题 --> {# background-color: yellow!important;#} #无敌 {# }#} {# </style>#} </head> <body> <h1>这是show页面</h1> {% include 'zujian.html' %} <!-- 在哪里引入组件,组件就生成在页面的对应位置上 --> </body> </html>

6|1inclusion_tag 自定义标签


  • 动态组件的应用
zhujian.html文件内容 <style> .nav{ background-color: blue; height: 100px; } .nav a{ color:white; } </style> </head> <body> <div class="nav"> {% for i in data %} <a href=''>{{ i }}</a> {% endfor %} </div> 注意:在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义标签 1.app中创建templatetags文件夹(文件夹名称必须是templatetags 2.templatetags文件夹中创建任意.py文件,比如mytag.py 3.mytag.py文件中写上如下内容 from django import template register = template.Library() #制作注册器,名字必须交register @register.inclusion_tag('zujian.html') def xiaolin(v1): #v1 = [11,22,33] return {"data":v1} 4.使用inclusion_tag,比如在show2.html文件中使用 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> {% load mytag %} #加载这个py文件 {% xiaolin d %} #引用mytag文件中自定义标签中的函数,并把后台数据d传给它 <h1>这是show2页面</h1> </body> </html> 5.需要后台给show2.html传递数据,比如views.py文件写法 def show2(request): d = ['国产','欧美','日韩'] return render(request,'show2.html',{'d':d})

7|0inclusion_tag的加载流程 重点!!!


第一步:在视图views.py文件中写入函数,将渲染的数据返回到show2.html. 第二步:show2.html中使用inclusion_tag自定义标签,先加载py文件{% load mytag %},然后{% xiaolin d %}并将数据传递给你在mytag里面定义的自定义标签。 第三步:在mytag文件中,inclusion_tag装饰器将函数的返回值,交给zujian.html去进行模板渲染 @register.inclusion_tag('zujian.html') 第四步:zujian.html拿到数据进行模板渲染,生成模板渲染之后的组件内容 第五步:将渲染后的组件(zujian.html),以include引入组件的形式,返回到使用inclusion_tag的地方,即最后返回到show2.html中,此时show2.html中就有了zujian.html渲染后的组件。

7|1图解inclusion_tag的加载流程



__EOF__

本文作者404 Not Found
本文链接https://www.cnblogs.com/weiweivip666/p/13308736.html
关于博主:可能又在睡觉
版权声明:转载请注明出处
声援博主:如果看到我睡觉请喊我去学习
posted @   我在路上回头看  阅读(850)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示