django 组件 自定义标签 静态文件配置
Posted zhufanyu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django 组件 自定义标签 静态文件配置相关的知识,希望对你有一定的参考价值。
组件
将一些功能标签写在一个html文件里,这个文件作为一个组件,如果那个文件需要就直接拿过来使用即可;
这是title.html文件,写了一个导航栏,作为一个公用的组件 <div style="background-color: cyan;width: 100%;height: 40px;"> <span style="font-size: 20px;">首页</span> <span style="font-size: 20px;">搜索</span> <span style="font-size: 20px;">登录</span> <span style="font-size: 20px;">注册</span> </div> 引用方式: {% include 'title.html' %} 将这个语句放在你html文件需要的位置;就会将这这个导航栏应用过来
自定义标签
首先在app应用下边创建一个文件夹 ---- templatetags (必须是这个名字,不能改变)
在这个文件夹里边写入自己的python的逻辑文件,名字随意 ,这个文件的名字是tag
# 下面是一个自定义的过滤器 from django import template # 导入django自带的包 register = template.Library() # register 名字不能改变,注册器 #在你写的函数头部加上这个装饰器,这就是一个过滤器 # 这是无参数的过滤器 @register.filter def filter(n1): ''' 这是一个子自定义的过滤器,无参数的过滤器 :param n1: 接收的在html文件中的过滤器中的管道符前边的那个变量的值 :return: ''' return n1 + '你好' # 这是有参数的过滤器 @register.filter def filter2(n1,n2): ''' 这是一个子自定义的过滤器,有参数的过滤器 :param n1: 接收的在html文件中的过滤器中的管道符前边的那个变量的值 :param n2: 传入的参数,管道符后边的,如果不需要传参数就不要写, :return: ''' return n1 + n2
在HTML文件中的应用
# 首先导入tag.py这个文件 {% load tag %} # 无参数的使用方法 <h1>{{ name|filter2}}</h1> # 有参数的使用方法 <h1>{{ name|filter2:'你好坏'}}</h1>
文件中需要的参数是在视图文件中传入的
def home(request): name = 'adrian' return render(request,'home.html',{'name':name})
inclusion_tag ---- 用于返回html代码片段
这个方法是给你需要的html页面返回一个html文件的片段,通过渲染一个html文件模板来显示一些数据
应用的创景一般是网页的左侧下拉栏,这种下拉栏一般网页中的应用多,但是数据有不一样,所以就使用inclusion_tag来做不同页面的不同数据需求的处理;
首先写一个简单的函数
from django import template register = template.Library() # register 名字不能改变,注册器 # 在这个函数的头部加一个有参装饰器 @register.inclusion_tag('result.html') # 这个装饰器的参数是一个html页面 def inclusion(): return {'l1':['抽烟','喝酒','烫头']} # 在定义的这个字典中的键 l1 必须是result这个html文件中的for所有循环的列表名,这两个名字必须一致
result这个html文件的代码
<ul> {% for i in l1 %} <li>{{ i }}</li> {% endfor %} </ul>
如何使用这个方法呢?
# 在你需要的网页上将这个文件导入tag.py 文件是你写函数的文件 {% load tag %} # 将在你需要的地方写 {% inclusion %} # inclusion是你写的函数
静态文件配置
在页面中需要加入一些css,js,图片等文件,如何在django中写这些文件的路径呢?
#首先在你的项目文件里建立一个statics文件夹,在这个文件夹下在增加你需要的文件夹,比如css,js文件夹,在这些文件夹下写入对应的css,js文件,
其次就是在django的settings配置文件进行文件配置
#关键的概念:Django中,静态资源的存放通过设置 STATIC_URL, STATICFILES_DIRS 来设置,一般STATIC_URL设置为:/static/ ---- 这个名字就叫做静态文件路径别名,可以改变 #STATIC_URL='/static/', 这个static 是在Django 具体APP下建立的statics目录,用来存放静态资源。而STATICFILES_DIRS一般用来设置通用的静态资源,例如: STATICFILES_DIRS=[os.path.join(BASE_DIR, "statics"),]
在html文件中如何使用
<link rel="stylesheet" href="/static/css/index.css"> 在插入css文件时只需要写你的路径别名,在加上css文件夹名和文件名
以上是关于django 组件 自定义标签 静态文件配置的主要内容,如果未能解决你的问题,请参考以下文章