vue(vue.js)—过滤器
原文链接:vue(vue.js)—过滤器 – 每天进步一点点 (longkui.site)
vue中的过滤器是对要显示的数据进行特定格式化后进行显示。比如最常用的保留两位小数,我们就可以用过滤器实现,它并没有改变原始数据的值,只是通过新的方式显示出来。功能类似于angular中的管道。
对于过滤器要知道两点
1.对要显示的数据进行特定格式化后再显示。
2.并没有改变原本的数据,只是用新的数据进行显示。
3.过滤器的本质就是一个函数
0.简单的用法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
<! DOCTYPE html> < html lang = "en" > < head > < meta charset = "UTF-8" > < meta http-equiv = "X-UA-Compatible" content = "IE=edge" > < meta name = "viewport" content = "width=device-width, initial-scale=1.0" > < title >vue测试</ title > </ head > < body > < div id = "root" > < h3 >格式化前的时间{{time}}</ h3 > < h3 >格式化后的时间{{time | timeFormat }}</ h3 > </ div > < script type = "text/javascript" > new Vue({ el: '#root', data:{ time:new Date().getTime() //获取时间戳 }, //过滤器 filters:{ timeFormat(value){ //value值就是 ‘|’ 的值,return 会直接替换掉原来的值 console.log(value) return moment(value).format("YYYY-MM-DD") } } }) </ script > </ body > </ html > |
效果如下:
上方所谓的过滤器就是 {{ time | timeFormat}} 这一部分,主要是“|” 这个符号解析的,vue读取的时候,先将“|” 符号前的time 作为传递到 timeFormat这个函数中,这个函数调用了momentjs对时间进行了格式化然后返回到页面中进行展示。
当然这个也支持自定义参数格式,也就是你的时间格式化的结果 不一定只有一种,可能有很多种。
2.组合用法
过滤器可以多个连在一起用,类似{{ time | timeFormat | str1 | str2 }} 这种,原则上可以无限套娃,但是实际开发中用的并不多,最多用过两层。
举例来说,上面的我们格式化时间后假如只想截取前几位,那么可以用字符串截取函数。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
<! DOCTYPE html> < html lang = "en" > < head > < meta charset = "UTF-8" > < meta http-equiv = "X-UA-Compatible" content = "IE=edge" > < meta name = "viewport" content = "width=device-width, initial-scale=1.0" > < title >vue测试</ title > </ head > < body > < div id = "root" > < h3 >格式化前的时间{{time}}</ h3 > < h3 >格式化后的时间{{time | timeFormat }}</ h3 > < h3 >格式化前的字符串{{str}}</ h3 > < h3 >格式化后的字符串{{str | mystr | mySlice}}</ h3 > </ div > < script type = "text/javascript" > new Vue({ el: '#root', data:{ time:new Date().getTime(), //获取时间戳 str:"ni hao!" }, //过滤器 filters:{ timeFormat(value){ //value值就是 ‘|’ 的值,return 会直接替换掉原来的值 console.log(value) return moment(value).format("YYYY-MM-DD") }, //字符串截取过滤器 mySlice(value){ console.log("mySlice",value) return value.slice(0,3) }, //字符串拼接过滤器 mystr(value){ console.log("mystr",value) return value+"hello" } } }) </ script > </ body > </ html > |
效果图如下:
可以看出,字符按第一个过滤器执行的结果是 ni hao!hello
按照第二个过滤器执行的结果是hi
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具