组件

  1. 将一些功能标签写在一个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文件需要的位置;就会将这这个导航栏应用过来

自定义过滤器

  1. 首先在app应用下边创建一个文件夹 ---- templatetags (必须是这个名字,不能改变)

  2. 在这个文件夹里边写入自己的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
  3. 在HTML文件中的应用

    # 首先导入tag.py这个文件
    {% load tag %} # 无参数的使用方法
    <h1>{{ name|filter2}}</h1> # 有参数的使用方法
    <h1>{{ name|filter2:'你好坏'}}</h1>
  4. 文件中需要的参数是在视图文件中传入的

    def home(request):
    name = 'adrian'
    return render(request,'home.html',{'name':name})

自定义标签

  1. 首先在app应用下边创建一个文件夹 ---- templatetags (必须是这个名字,不能改变)

  2. 在这个文件夹里边写入自己的python的逻辑文件,名字随意 ,这个文件的名字是tag

    # 下面是一个自定义标签
    from django import template
    # 导入django自带的包
    register = template.Library() # register 名字不能改变,注册器
    #在你写的函数头部加上这个装饰器,这就是一个自定义标签 @register.simple_tag
    def filter2(n1,n2): return n1 + n2
  3. 在HTML文件中的应用

    # 首先导入tag.py这个文件
    {% load tag %} <h1>{% filter 'x' 'o' %}</h1>
  4. 文件中需要的参数是在视图文件中传入的

    def home(request):
    name = 'adrian'
    return render(request,'home.html',{'name':name})

inclusion_tag ---- 用于返回html代码片段

  1. 这个方法是给你需要的html页面返回一个html文件的片段,通过渲染一个html文件模板来显示一些数据

    应用的创景一般是网页的左侧下拉栏,这种下拉栏一般网页中的应用多,但是数据有不一样,所以就使用inclusion_tag来做不同页面的不同数据需求的处理;

  2. 首先写一个简单的函数

    from django import template
    register = template.Library() # register 名字不能改变,注册器
    # 在这个函数的头部加一个有参装饰器
    @register.inclusion_tag('result.html')
    # 这个装饰器的参数是一个html页面
    def inclusion(): return {'l1':['抽烟','喝酒','烫头']}
    # 在定义的这个字典中的键 l1 必须是result这个html文件中的for所有循环的列表名,这两个名字必须一致
  3. result这个html文件的代码

    <ul>
    {% for i in l1 %}
    <li>{{ i }}</li>
    {% endfor %}
    </ul>
  4. 如何使用这个方法呢?

    # 在你需要的网页上将这个文件导入tag.py 文件是你写函数的文件
    {% load tag %} # 将在你需要的地方写
    {% inclusion %}
    # inclusion是你写的函数

静态文件配置

  1. 在页面中需要加入一些css,js,图片等文件,如何在django中写这些文件的路径呢?

    #首先在你的项目文件里建立一个statics文件夹,在这个文件夹下在增加你需要的文件夹,比如css,js文件夹,在这些文件夹下写入对应的css,js文件,
  2. 其次就是在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"),]
  3. 在html文件中如何使用

    <link rel="stylesheet" href="/static/css/index.css">
    在插入css文件时只需要写你的路径别名,在加上css文件夹名和文件名

django 组件 自定义过滤器 自定义标签 静态文件配置的更多相关文章

  1. 自定义过滤器和标签 & 静态文件相关

    自定义过滤器和标签 1.在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag. 2.在app中创建templatetags模块(模块名 ...

  2. Django框架之模板继承和静态文件配置

    一.模板继承 目的是:减少代码的冗余 语法: {% block classinfo %} {% endblock %} 具体步骤: 1.创建一个base.html文件,2.把要显示的页面的内容写在这里 ...

  3. Django框架之模板基础,静态文件配置

    一.模板继承 目的是:减少代码的冗余 语法: {% block classinfo %} {% endblock %} 具体步骤: 1.创建一个base.html文件,2.把要显示的页面的内容写在这里 ...

  4. django系列4.2--自定义标签, 自定义过滤器, inclusion_tag, 引入静态文件(css,js等)

    项目的目录为 在app中创建templates时,最好要再创建一个app名相同的文件夹,因为项目找文件时从第一个app开始遍历,不同app内的同名文件会有冲突,所以这样处理 一.自定义标签和过滤器 1 ...

  5. HttpResponse,render,redirect,静态文件配置,request对象方法,pycharm连接MySQL,django连接MySQL,django ORM

    HttpResponse 主要用于返回字符串类型的数据 def index(request): return HttpResponse('index页面') 在页面中就会显示 index页面 rend ...

  6. day58——模板继承、组件、自定义标签和过滤器、inclusion_tag、静态文件配置、url别名和反向解析、url命名空间

    day58 模板相关 模板继承(母版继承) 1. 创建一个xx.html页面(作为母版,其他页面来继承它使用) 2. 在母版中定义block块(可以定义多个,整个页面任意位置) {% block co ...

  7. day51:django:dispatch&模板渲染&过滤器&标签&组件&静态文件配置

    目录 1.dispatch 2.模板渲染 3.过滤器 4.标签 5.组件 6.静态文件配置 dispatch 回顾:CBV对应的URL传参 urls.py url(r'^book/(\d+)/(\d+ ...

  8. django自定义过滤器和标签

    1.自定义过滤器和标签的流程: 1.在某个app下创建一个名为templatetags(必需,且包名不可变)的包.假设我们在名为app01的app下创建了一个templatetags的包,并在该包下创 ...

  9. django 简易博客开发 3 静态文件、from 应用与自定义

    首先还是贴一下源代码地址  https://github.com/goodspeedcheng/sblog 上一篇博客我们介绍了 django 如何在views中使用templates以及一些常用的数 ...

随机推荐

  1. 网络编程-python实现-TCP实现文件下载(1.1.4)

    @ 目录 代码实现 代码实现 客户端 from socket import * def main(): # 创建socket tcp_client_socket = socket(AF_INET, S ...

  2. go-slice实现的使用和基本原理

    目录 摘要 Slice数据结构 使用make创建Slice 使用数组创建Slice Slice 扩容 Slice Copy 特殊切片 总结 参考 你的鼓励也是我创作的动力 Posted by 微博@Y ...

  3. Java篇:Docker的介绍安装 和常用命令

    文章目录 为什么 出现docker Docker的简介 容器(Container) 镜像(Image) 仓库(Repository) Docker的安装 查看容器 删除镜像 删除容器 部署应用 以my ...

  4. Spring Cloud 入门教程(一): Eureka 服务注册

    创建一个Maven工程,New-Other-Maven-Maven Probject 点击Next,红色框里的选上 点击Next 点击Finsh就完成了一个Maven Probject的创建. (1) ...

  5. ​grafana 的主体架构是如何设计的?

    ​grafana 的主体架构是如何设计的? grafana 是非常强大的可视化项目,它最早从 kibana 生成出来,渐渐也已经形成了自己的生态了.研究完 grafana 生态之后,只有一句话:可视化 ...

  6. pdf2swf 和pdf2html 使用命令详解

    pdf2swf 将pdf文档转换为flash方式阅读,可以满足公式.图片的格式定义: pdf2htmlEX 将pdf文档转换为html方式阅读,有一下优点: 在HTML文件中精确显示原生文本 保持PD ...

  7. Flowable学习入门

    一.Flowable简介 1.Flowable是什么 Flowable是一个使用Java编写的轻量级业务流程引擎.Flowable流程引擎可用于部署BPMN 2.0流程定义(用于定义流程的行业XML标 ...

  8. java连接mongodb数据库

    最近毕设需要用到这个数据库.然而又不会,没办法,只能上网学习学习. 记录一下java连接mongodb数据库的简单方法.这里只是记录一下学习.熟悉一下CURD方法. 但是毕业用到的是SpringBoo ...

  9. stm32之can总线过滤器研究

    stm32的can总线的配置如下:       CAN_InitStructure.CAN_TTCM=DISABLE;//禁止时间触发通信模式      CAN_InitStructure.CAN_A ...

  10. Java 初中级程序员如何快速成长???

    Java 技术学习路线 Java 语言是一门非常流行和重要的语言,目前仍是需求量很大的语言,应用范围很广的语言,在企业级开发.移动开发.大数据云计算.人工智能等领域都有大量的应用. 怎么样学习好 Ja ...