Django之模版层

文章目录

  • 模版语法传值
  • 模版语法传值特性
  • 模版语法标签
    • 语法格式
    • if模板标签
    • for模板标签
    • with起别名
  • 模版语法过滤器
    • 常用过滤器
  • 自定义过滤器、标签、inclusion_tag
    • 自定义过滤器
    • 自定义标签
    • 自定义inclusion_tag
  • 模版导入
  • 模版继承

模版语法传值

	模板层三种语法{{}}:主要与数据值相关{%%}:主要与逻辑相关{##}:模板注释django的模板语法是自己写的 跟jinja2不一样
'''
1.针对需要加括号调用的名字 django模板语法会自动加括号调用你只需要写名字就行
2.模板语法的注释前端浏览器是无法查看的 {##},
模板语法{##}是由后端处理的,当识别为模板注释时就会从html文件中移除了,不会返回给用户;
而html注释<!---->是由前端浏览器对html处理时渲染时不做处理,但检查网页源码时还是能看见这些注释的。
'''

通过之前的Django知识的了解,如果我们需要向页面传递参数,可以通过render函数帮助我们实现:

第一种方式:手动将所有内容放入字典内进行传递

	def index(request):name = 'jack'dic = {'hobby':['jump','music','rap']}return render(request,'index.html', {'name': name, 'dic': dic})

第一种方式传值:精准传值 不浪费资源 针对多资源的传递书写麻烦

第二种方式:将当前名称空间中所有的变量名与值全部传递

	def index(request):name = 'jack'dic = {'hobby': ['jump', 'music', 'rap']}return render(request,'index.html',locals())

第二种方式传值:将函数名称空间中所有的名字全部传递 名字过多并且不使用的情况下比较浪费资源

模版语法传值特性

在这里插入图片描述

		1.关于模版语法传值的范围是很大的 我们的八大数据类型都可以传值还有函数以及类2.文件对象也可以展示并调用方法3.函数名的传递会自动加括号执行并将返回值展示到页面上 需要写上return返回值才可以返回到页面注意函数如果有参数则不会执行也不会展示 模板语法不支持有参函数4.类名的传递也会自动加括号产生对象内存地址并展示到页面上如果想使用的话可以通过对象句点符的方式点出来5.对象不会加括号,但可以获取对象的一些数据属性6.索引、键、属性只能通过句点的方式取ps:总结针对可以加括号调用的名字模板语法都会自动加括号调用ps:模板语法会判断每一个名字是否可调用 如果可以则调用!!!

模版语法标签

在模板内通过:{% %} 来定义;例如:{%for %} {% endfor %}。在前面Django学习的章节内我们就使用了:

	{% load static %} # 加载静态接口{% static '静态文件路径' % # 使用静态接口作为前缀寻找静态文件{% url '路由别名' %} # 根据路由别名执行该路由规则{% for obj in data %} # 给定一个迭代器,根据其内容决定遍历次数代码块{% endfor %}

语法格式

	if elif else{% if 条件 %}  条件一般是模板语法传过来的数据  直接写名字使用即可条件成立执行的代码{% elif 条件1 %}条件1成立执行的代码	{% else %}条件都不成立执行的代码{% endif %}for循环(html页面输入for Tab后面会自动补全)需要用到一个关键字 forloop 用来记录循环第几次的{% for i in str %}{% if forloop.first %}<p>这是我循环第一次!!</p>{% elif forloop.last %}<p>这是我最后一次循环!!</p>{% else %}<p>{{ i }}</p>{% endif %}{% empty %}<p>我是判断当前标签是否有值的哦! 如果是空我就运行啦!!</p>{% endfor %}

if模板标签

if这种模板标签非常类似于Python内的if,只不过部分模板标签都会有一个end标签名为作用域的结束,而Python则是以缩进为作用域。

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body><url>{% if 1 > 2 %}条件1>2判断成功执行{% elif 3 > 1 %}条件3>1判断成功执行{% elif 5 > 2 %}条件5>2判断成功执行{% else %}以上条件都没有触发{% endif %}</url></body>
</html>

一个作用域内只有一个条件能执行成功,浏览器打开效果:
在这里插入图片描述

for模板标签

for标签的几个常用属性

for内可用描述
forloop.counter当前循环的索引值(从1开始)
forloop.counter0当前循环的索引值(从0开始)
forloop.revcounter当前循环的倒序索引值(从1开始)
forloop.revcounter0当前循环的倒序索引值(从0开始)
forloop.first当前循环是不是第一次循环(布尔值)
forloop.last当前循环是不是最后一次循环(布尔值)
forloop.parentloop本层循环的外层循环

视图传递一个列表,index.html:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body><url>{% for li in lis %}{% if forloop.first %}<li>我是第一个列表{{ li }}</li>{% elif forloop.last %}<li>我是最后一个列表{{ li }}</li>{% else %}<li>{{ li }}</li>{% endif %}{% endfor %}</url></body>
</html>

在这里插入图片描述

直接遍历forloop也是可以的,而它显示的则是上面提到的所有属性内容:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body><url>{% for foo in lis %}{{ forloop }}<br/>{% endfor %}</url></body>
</html>

在这里插入图片描述

补充:当for接收的值不存在,如何处理
如果给定迭代器为空或找不到,则for标记可以带有一个可选子句,其文本将显示:{% empty %}

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body><url>{% for foo in llllll %}{{ foo }}{% empty %}该循环找不到遍历内容{% endfor %}</url></body>
</html>

在这里插入图片描述


遍历一个字典:

	{% for key,val in dic.items %}<p>{{ key }}:{{ val }}</p>{% endfor %}{% for foo in d.keys %}<p>{{ foo }}</p>{% endfor %}{% for foo in d.values %}<p>{{ foo }}</p>{% endfor %}{% for foo in d.items %}<p>{{ foo }}</p>{% endfor %}

with起别名

使用一个简单地名字缓存一个复杂的变量,当你需要使用一个“昂贵的”方法(比如访问数据库)很多次的时候是非常有用的

	d = {'username':'kevin','age':18,'info':'这个人有点意思','hobby':[111,222,333,{'info':'NB'}]}# with起别名{% with d.hobby.3.info as nb  %}<p>{{ nb }}</p>with语法内就可以通过as后面的别名快速的使用到前面非常复杂获取数据的方式<p>{{ d.hobby.3.info }}</p>{% endwith %}{% with total=business.employees.count %}{{ total }} employee{{ total|pluralize }}{% endwith %}不要写成as

模版语法过滤器

该模板语法类似与Python的内置方法,通过|符号对值进行操作。

常用过滤器

语法:{{ value|过滤器名:参数 }}
过滤器用管道符隔开(无空格),最多支持多传入一个参数。
过滤器是支持链式的,可以将多个过滤器串起来,上一个过滤器的输出作为下一个的输入

过滤器功能示例
default如果一个变量是false或者为空,使用给定的默认值。 否则,使用变量的值。{{ value|default:“nothing”}}
length对于字符串列表这类有length属性的,得到其值{{ value|length}}
filesizeformat将传入的数字当做文件的字节数,将其处理成合适展示的文件大小,如2048就会展示为2 KB{{ value|filesizeformat }}
slice对字符串进行切片{{value|slice:“2:-1”}}
add将传入的数字或字符串做相加或拼接处理{{value|add:1}}
safe模板语法默认转义带html语法的文本,safe取消标签文本转义,让其可以被html渲染{{ value|safe}}
truncatechars如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“…”)结尾。{{ value|truncatechars:9}}
truncatewords在一定数量的字后截断字符串,处理同上…。{{ value|truncatewords:9}}
cut移除value中所有的与给出的变量相同的字符串如果value为’i love you’,那么将输出’iloveyou’.{{ value|cut:’ ’ }}
timesincedatetime数据距离现在的时间(从现在起){{ blog_date|timesince }}
timeuntildatetime数据距离现在的时间(到现在止){{ blog_date|timesince }}
datedatetime数据字符化输出{{ value|date:“Y-m-d H:i:s”}}

views.py

	from django.shortcuts import renderfrom datetime import datetimedef index(request):lis = [1,2,3,4,5]num = 10strs = 'Hello'ctime = datetime.now()b1 = Trueb2 = Falsefile_size = 10502030texts = '这是一段很长且内容丰富的文本'return render(request, 'index.html', locals())

index.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body><p>获取值的长度:{{ lis|length }}</p><p>加法运算:{{ num|add:20 }}</p><p>字符串拼接:{{ strs|add:' World' }}</p><p>日期格式:{{ ctime|date:'Y年-m月-d日 H时:i分:s秒' }}</p><p>当结果为True{{ b1|default:'我触发了' }}</p><p>当结果不为True{{ b2|default:'我触发了' }}</p><p>通过数值计算文件大小:{{ file_size|filesizeformat }}</p><p>截取文本(7位数,包含点):{{ texts|truncatechars:7 }}</p><p>截取文本(3位数,包含点):{{ texts|truncatechars:3 }}</p></body>
</html>

打开浏览器效果:
在这里插入图片描述


如果传入这种内容到前端会是什么样子呢;

	h = "<h1>我是标题</h1>"

在这里插入图片描述
如果需要在后端就写好标签,传入到前端直接显示的话,存在两种方式:

方式一:导入一个新的方法来完成需求

	from django.shortcuts import renderfrom django.utils.safestring import mark_safedef index(request):h = mark_safe("<h1>我是标题</h1>")return render(request, 'index.html', locals())

方式二:后端正常传参,前端过滤解析

	<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body>{{ h|safe }}</body></html>

在这里插入图片描述

自定义过滤器、标签、inclusion_tag

简介、环境准备

这类似于在Python内自定义函数,在开始前要做3个步骤:

  1. 在应用下创建一个名字必须叫"templatetags"文件夹
  2. 在上序文件夹内创建一个任意名称的py文件
  3. 在该py文件内固定先书写以下两条代码
	from django import templateregister = template.Library()

完成上面步骤之后,记得重启Django项目啊!正式开始我们的实例


自定义过滤器

在定义的py文件内,开始创建我们的过滤器

	@register.filter(name='myfileter') # 自定义过滤器def index(x,y): # 接受两个值return x * y # 只做简单的运算

html文件首先要加载我们定义的过滤器,通过存放过滤器的那个py文件名

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>add</title></head><body>{% load mytag %} <!-- 加载自定义的过滤器 -->{{ 10|myfileter:2 }} <!--102传进去了,进行10*2,得到20 --></body>
</html>

页面打开效果
在这里插入图片描述

自定义标签

定义方式几乎与过滤器一致,我们这里定义的是简单版的标签

mytag.py

	from django import templateregister = template.Library()# 自定义简单版标签(for那些标签都是通过register.tag定义出来的)@register.simple_tag(name='mysimple')def func1(a,b,c,d):return '%s-%s %s:%s'%(a,b,c,d)

index.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body>{% load mytag %}{% mysimple 1 'Hello' 2 'World' %}</body>
</html>

浏览器打开效果
在这里插入图片描述

自定义inclusion_tag

定义inclusion_tag是为了避免模块会重复代码
mytag.py

	from django import templateregister = template.Library()# 自定义inclusion_tag@register.inclusion_tag('test.html', name='my_inclusion_tag')def func(n):l = []for i in range(1, n + 1):l.append(f'第{i}页')return {'lis':l} # 表示将列表传入到test.html页面内

test.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>test</title></head><body>{% for foo in lis %}<li>{{ foo }}</li>{% endfor %}</body>
</html>

别急,还没完呢,这不是我们主页面,我们的目的为了重复使用上面页面的代码(但必须上面界面是经过inclusion_tag传入的)。

index.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title></head><body>{% load mytag %}<b>第一次使用</b>{% my_inclusion_tag 2 %} <!-- 向那个页面传入值2,然后拿到它的页面 --><b>第二次使用</b>{% my_inclusion_tag 5 %} <!-- 向那个页面传入值2,然后拿到它的页面 --></body>
</html>

打开浏览器效果:
在这里插入图片描述
每次都可以传值给inclusion_tag,然后由inclusion_tag将值传递给某个页面,再然后那个页面产生的结果会返回到我们调用inclusion_tag的页面

总结:当某个区域需要反复使用inclusion_tag,那么得到数据不是固定的


模版导入

将写好的一个模板导入到另一个模板里面,类似于模块。

如:我们写的一个导航栏模板,写好之后其它任意模板都可以导入使用:

语法:{% include '模板文件' %}

headers.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script><link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css" rel="stylesheet"><script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
</head>
<body>
<nav class="navbar navbar-inverse"><div class="container-fluid"><!-- Brand and toggle get grouped for better mobile display --><div class="navbar-header"><button type="button" class="navbar-toggle collapsed" data-toggle="collapse"data-target="#bs-example-navbar-collapse-1" aria-expanded="false"><span class="sr-only">Toggle navigation</span><span class="icon-bar"></span><span class="icon-bar"></span><span class="icon-bar"></span></button><a class="navbar-brand" href="#">Brand</a></div><!-- Collect the nav links, forms, and other content for toggling --><div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"><ul class="nav navbar-nav"><li class="active"><a href="#">Link <span class="sr-only">(current)</span></a></li><li><a href="#">Link</a></li><li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true"aria-expanded="false">Dropdown <span class="caret"></span></a><ul class="dropdown-menu"><li><a href="#">Action</a></li><li><a href="#">Another action</a></li><li><a href="#">Something else here</a></li><li role="separator" class="divider"></li><li><a href="#">Separated link</a></li><li role="separator" class="divider"></li><li><a href="#">One more separated link</a></li></ul></li></ul><form class="navbar-form navbar-left"><div class="form-group"><input type="text" class="form-control" placeholder="Search"></div><button type="submit" class="btn btn-default">Submit</button></form><ul class="nav navbar-nav navbar-right"><li><a href="#">Link</a></li><li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true"aria-expanded="false">Dropdown <span class="caret"></span></a><ul class="dropdown-menu"><li><a href="#">Action</a></li><li><a href="#">Another action</a></li><li><a href="#">Something else here</a></li><li role="separator" class="divider"></li><li><a href="#">Separated link</a></li></ul></li></ul></div><!-- /.navbar-collapse --></div><!-- /.container-fluid -->
</nav></body>
</html>

yel.html 主页

{% include 'headers.html' %} <!-- 放在任意位置都可以,笔者习惯性放在这里,更明确一些。 -->
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>index</title><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.4.1/jquery.min.js"></script><script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script><link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css" rel="stylesheet"></head><body>Hello World!</body>
</html>

打开浏览器看看效果
在这里插入图片描述

模版继承

模板继承类似于模板导入,但不同的是继承分为:母版、子版。

  • 母版:正常页面布局,可以留出某块区域给子版进行使用
  • 子版:可以完全继承与模板,但是这就与导入无异了,所以子版可以在母版预留出来的区域继续编辑自己的内容
		{% extends 'html文件名' %}			# 新建一个页面 第一行写入继承代码{% block 区域名称 %}					# 可以通过这个方式定位到页面的位置母版内容							# 这个地方填写新的代码{% endblock %}{% block 区域名称 %}			# 在模板划分的区域内编写内容子板内容{% endblock %}母版在划定区域的时候一般都有三个区域:CSS区域、HTML文档区域、JS区域。目的就是为了让子版具有独立的CSS、JS以便于增加拓展性。在模板的head标签内:{% block css %}{% endblock %}在模板的body标签结尾:{% block javascript %}{% endblock %}{% block css %}{% endblock %}{% block content %}{% endblock %}{% block js %}{% endblock %}'''子板中还可以使用母板的内容  {{ block.super }} 	让他使用之前原主页的内容'''	

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/143567.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数字三角形模型 笔记

方格取数 走两次的最大值 设有 NN 的方格图&#xff0c;我们在其中的某些方格中填入正整数&#xff0c;而其它的方格中则放入数字0。如下图所示&#xff1a; 某人从图中的左上角 A 出发&#xff0c;可以向下行走&#xff0c;也可以向右行走&#xff0c;直到到达右下角的 B 点…

LOWORD, HIWORD, LOBYTE, HIBYTE的解释

文章目录 实验结论 实验 int 类型大小正常为4Byte 以小端序来看 0x12345678在内存中的存储为 0x78 0x56 0x34 0x120x78在低地址&#xff0c;0x12在高地址 程序输出 #include <stdio.h> #include <string.h> #include<windows.h>int main() {int a 0x12345…

竞赛选题 深度学习的智能中文对话问答机器人

文章目录 0 简介1 项目架构2 项目的主要过程2.1 数据清洗、预处理2.2 分桶2.3 训练 3 项目的整体结构4 重要的API4.1 LSTM cells部分&#xff1a;4.2 损失函数&#xff1a;4.3 搭建seq2seq框架&#xff1a;4.4 测试部分&#xff1a;4.5 评价NLP测试效果&#xff1a;4.6 梯度截断…

互联网Java工程师面试题·微服务篇·第一弹

目录 ​编辑 1、您对微服务有何了解&#xff1f; 2、微服务架构有哪些优势&#xff1f; 3、微服务有哪些特点&#xff1f; 4、设计微服务的最佳实践是什么&#xff1f; 5、微服务架构如何运作&#xff1f; 6、微服务架构的优缺点是什么&#xff1f; 7、单片&#xff0c…

vue请求代理查看真实地址

查看真实地址方式&#xff1a; 通过配置vue.config.js文件&#xff0c;直接在请求头输出完整地址&#xff1a; /api/: { changeOrigin: true, target: process.env.VUE_APP_PLATFORM_URL, logLevel: debug, // 在终端输出 onProxyRes(proxyR…

2023/11/15JAVA学习

如何多开一个程序

modbus-RTU是一种比较简单、可靠的协议

modbus-RTU是一种比较简单、可靠的协议 RTU, 是modbus中的一种应用层协议&#xff0c;在OSI的第七层 数据格式 应用

day2324_jdbc

今日内容 零、 复习昨日 一、作业 二、SQL注入 三、PreparedStatement 四、事务 五、DBUtil 零、 复习昨日 一、引言 1.1 如何操作数据库 使用客户端工具访问数据库&#xff0c;需要手工建立连接&#xff0c;输入用户名和密码登录&#xff0c;编写 SQL 语句&#xff0c;点击执行…

Java设计模式-结构型模式-适配器模式

适配器模式 适配器模式应用场景案例类适配器模式对象适配器模式接口适配器模式适配器模式在源码中的使用 适配器模式 如图&#xff1a;国外插座标准和国内不同&#xff0c;要使用国内的充电器&#xff0c;就需要转接插头&#xff0c;转接插头就是起到适配器的作用 适配器模式&…

Ansible playbook详解

playbook是ansible用于配置&#xff0c;部署&#xff0c;和被管理被控节点的剧本 playbook常用的YMAL格式&#xff1a;&#xff08;文件名称以 .yml结尾&#xff09; 1、文件的第一行应该以 "---" (三个连字符)开始&#xff0c;表明YMAL文件的开始。    2、在同一…

C# 将PDF文档转换为Word文档

一.开发框架&#xff1a; .NetCore6.0 工具&#xff1a;Visual Studio 2022 二.思路&#xff1a; 1.使用SHA256Hash标识文档转换记录&#xff0c;数据库已经存在对应散列值&#xff0c;则直接返还已经转换过的文档 2.数据库没有对应散列值记录的话&#xff0c;则保存上传PDF…

OpenHarmony Promise详解

一&#xff0c;定义 作为一个android开发人员&#xff0c;刚接触Promise可能不好理解&#xff0c;因为android中的异步操作都是开启线程操作或者kotlin的协程&#xff0c;但是Promise并不是单独去开启一个线程来处理异步任务&#xff0c;它是在同一个线程中去处理异步任务。异…

性能测试 —— Jmeter分布式测试的注意事项和常见问题

Jmeter是一款开源的性能测试工具&#xff0c;使用Jmeter进行分布式测试时&#xff0c;也需要注意一些细节和问题&#xff0c;否则可能会影响测试结果的准确性和可靠性。 Jmeter分布式测试时需要特别注意的几个方面 1. 参数化文件的位置和内容 如果使用csv文件进行参数化&…

java算法学习索引之动态规划

一 斐波那契数列问题的递归和动态规划 【题目】给定整数N&#xff0c;返回斐波那契数列的第N项。 补充问题 1&#xff1a;给定整数 N&#xff0c;代表台阶数&#xff0c;一次可以跨 2个或者 1个台阶&#xff0c;返回有多少种走法。 【举例】N3&#xff0c;可以三次都跨1个台…

python循环队列

1.循环队列简介&#xff1a; 循环队列是一种队列的实现方式&#xff0c;它可以避免队列空间的浪费。循环队列的特点是队列的末尾连接到队列的开头&#xff0c;形成一个循环。这样当队列尾部元素达到队列的最大容量时&#xff0c;新的元素可以循环地放入队列的开头。这种设计使…

Linux使用Docker完整安装Superset,同时解决please use superset_config.py to override it报错

文章目录 Docker安装Superset流程1. 首先获取镜像2. 生成SSL3. 创建Superset容器4. 更新数据库5. 测试访问Superset Docker安装Superset流程 1. 首先获取镜像 docker pull amancevice/superset2. 生成SSL 接下来我们运行一些额外的程序&#xff1a; openssl rand -base64 4…

ubuntu开机系统出错且无法恢复。请联系系统管理员。

背景&#xff1a; ubuntu22.04.2命令行&#xff0c;执行自动安装系统推荐显卡驱动命令&#xff0c;字体变大&#xff0c;重启后出现如下图错误&#xff0c;无法进入系统&#xff0c;无法通过CTRLALTF1-F3进入TTY模式。 解决办法&#xff1a; 1.首先要想办法进入系统&#xff…

python实现一个简单的桌面倒计时小程序

本章内容主要是利用python制作一个简单的桌面倒计时程序&#xff0c;包含开始、重置 、设置功能。 目录 一、效果演示 二、程序代码 一、效果演示 二、程序代码 #!/usr/bin/python # -*- coding: UTF-8 -*- """ author: Roc-xb """import tkin…

Python数据容器(字典)

字典 1.字典的定义2.字典数据的获取3.字典的嵌套4.嵌套字典的内容获取5.字典的常用操作6.常用操作总结7.遍历字典8.练习 1.字典的定义 同样使用{}&#xff0c;不过存储的元素是一个一个的&#xff1a;键值对&#xff0c;语法如下 # 定义字典字面量 {key:value,key:value,...,…

systemverilog:interface中的modport用法

使用modport可以将interface中的信号分组并指定方向&#xff0c;方向是从modport连接的模块看过来的。简单示例如下&#xff1a; interface cnt_if (input bit clk);logic rstn;logic load_en;logic [3:0] load;logic [7:0] count;modport TEST (input clk, count,output rst…