VUE过滤器的使用方法-创新互联
这篇文章主要讲解了“VUE过滤器的使用方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VUE过滤器的使用方法”吧!
坚守“ 做人真诚 · 做事靠谱 · 口碑至上 · 高效敬业 ”的价值观,专业网站建设服务10余年为成都咖啡厅设计小微创业公司专业提供成都定制网页设计营销网站建设商城网站建设手机网站建设小程序网站建设网站改版,从内容策划、视觉设计、底层架构、网页布局、功能开发迭代于一体的高端网站建设服务。1. 定义一个日期格式化函数
都9012了,我们就采用 ES Module的写法,在vue初始化的项目src的文件中新建一个filters文件夹,并在其中添加DateFmt.js文件,代码如下
// wx:46488492export function DateFmt(date, fmt) {if (date == null) return null;var o = { "M+": date.getMonth() + 1, // 月份 "d+": date.getDate(), // 日 "h+": date.getHours(), // 小时 "m+": date.getMinutes(), // 分 "s+": date.getSeconds(), // 秒 "q+": Math.floor((date.getMonth() + 3) / 3), // 季度 "S": date.getMilliseconds() };if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));for (var k in o) if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));return fmt; }
2. 使用过滤器 DateFmt
定义好函数后,我们采用全局注册filter的方式。在main.js
中使用import { DateFmt } from '@/filters/DateFmt.js'
导入我们上边定义的函数。 使用Vue.filter("DateFmt", DateFmt)
完成filter全局注册。
在components
文件夹中,添加我们的测试组件DateFormat.vue
,在该文件template>div
节点下输入{{new Date()|DateFmt('yyyy-MM-dd hh:mm:ss')}}
然后在app.vue引入我们刚新添加的组件,运行,你就会在看到当前日期已经按照我们需要的格式显示在网页上。是的,就是这么简单,那完了么?
3. 在JS中使用 DateFmt
好奇的朋友会发现,我们定义的filter都是在template中使用的,那我如何在js代码中使用呢?当然,在开发这两个app期间,减少数据转换的次数,有了这样的需求。
3.1 在组件页面导入函数
回到开头,我们强调了一下,过滤器其实就是一个函数。既然是函数,那引入就好了。所以在我们最初建立 DateFormat.vue
单文件组件的块中使用
import { DateFmt } from '@/filters/DateFmt.js'
导入我们的函数。代码如下:
在我们中新加一个元素,并绑定
curDateImportFilter
属性,运行 npm run serve 回到浏览器,你就会看到两个格式化日期。这样好吗?我们多了一个import , 虽然实现了,但觉得不够好。
3.2 使用Vue.filter 返回过滤器
如果我们仔细看官方文档,就会发现官说明了,通过 Vue.filter("filter")
返回定义的函数
,所以Vue.filter不仅可以注册,还可以返回。
我们继续在data中添加属性 :
curDateVueFilter: Vue.filter("DateFmt")(new Date(), 'yyyy-MM-dd hh:mm:ss')
通过上边的步骤绑定该属性,你会在浏览器上看到三个格式化好的日期。要使用Vue.filter,我们不得不额外的导入import Vue from 'vue'
。跟上边一样,虽然实现了,但不够好。
3.3 使用实例属性$options
在vue组件,每个组件都有各自的属性,这些属性大多挂载中属性 $options
中,在chrome浏览器打印$vm0信息,我们就找到filter的信息。这里科普一下,在安装vue开发者工具后$vm0表示我们当前选择的组件,结果如下图所示:
从图形上看,当前组件的filters为一个对象,并不能直接找到,不过展开至__proto__
原型上看到了我们的DateFmt方法。好了现在我们在继续在data中添加属性
curDateOptFilter: this.$options.filters.DateFmt(new Date(), 'yyyy-MM-dd hh:mm:ss')
是的,采用这个方式,就不用再引入vue或者函数了,跟直接在template使用一样。简洁方便,感觉好多了。在深入一点,通过调试我们就会发现 Vue.filter 是调用options.filters原型上的方法,如下图所示
感谢各位的阅读,以上就是“VUE过滤器的使用方法”的内容了,经过本文的学习后,相信大家对VUE过滤器的使用方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!
本文标题:VUE过滤器的使用方法-创新互联
URL地址:http://pwwzsj.com/article/ejecg.html