Vue中如何使用filters过滤器
发表于:2025-11-15 作者:千家信息网编辑
千家信息网最后更新 2025年11月15日,这篇文章主要为大家展示了"Vue中如何使用filters过滤器",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Vue中如何使用filters过滤器"这篇文章
千家信息网最后更新 2025年11月15日Vue中如何使用filters过滤器
这篇文章主要为大家展示了"Vue中如何使用filters过滤器",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Vue中如何使用filters过滤器"这篇文章吧。
Vue.js 允许我们自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号({undefined{ }})插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由"管道"符号指示。
{{ message | capitalize }}
一、全局过滤器
定义一个全局过滤器很简单,只需要导出一个方法即可。
使用的时候很简单,只需要在入口文件全局引入此过滤器即可,使用 Vue.filter(key, value) 引入。
比如,Java后端返回的时间戳精确到秒,而JS中的时间戳是用毫秒表示,则可以定义一个转换时间戳的全局过滤器:
//main.jsimport Vue from 'vue'Vue.filter('millisecond', (value) => { if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1)})在需要使用的组件使用:
{{1516101106 | millisecond}}
全局过滤器之单一挂载
/** * dateTmp:要过滤的值 * fmtTmp:传入的参数,可接收多个参数 */{{ 1639998858000 | dateFormat("yyyy/MM/dd HH:mm:ss") }}Vue.filter('dateFormat', function (dateTmp, fmtTmp) { let fmt = fmtTmp let date = dateTmp if (!fmt) { fmt = 'yyyy.MM.dd' } if (!(date instanceof Date)) { date = new Date(date) } let o = { 'M+': date.getMonth() + 1, // 月份 'd+': date.getDate(), // 日 'h+': date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, // 小时 'H+': date.getHours(), // 小时 'm+': date.getMinutes(), // 分 's+': date.getSeconds(), // 秒 'q+': Math.floor((date.getMonth() + 3) / 3), // 季度 'S': date.getMilliseconds() // 毫秒 } let week = { '0': '日', '1': '一', '2': '二', '3': '三', '4': '四', '5': '五', '6': '六' } if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length)) } if (/(E+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, ((RegExp.$1.length > 1) ? (RegExp.$1.length > 2 ? '星期' : '周') : '') + week[date.getDay() + '']) } 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});
全局过滤器之批量挂载
//定义方法//filters.jsexport function slice (temp,num) { return temp.slice(0,num);}//挂载//main.jsimport * as filters from '@/assets/js/filters'; Object.keys(filters).forEach(key => { Vue.filter(key, filters[key]);});//调用{{ '123456' | slice(4) }}
二、组件过滤器
组件过滤器更简单,只需在对应组件中定义 filters 即可,不过只针对本组件有效。
比如定义一个首字母大写的过滤器:
//定义方法export default { filters: { capitalize: function (value) { if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1) } }}例子例子
{{ msg | setSize }}
以上是"Vue中如何使用filters过滤器"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
过滤器
全局
组件
内容
方法
时间
篇文章
例子
参数
小时
表达式
学习
帮助
有效
精确
两个
入口
只需
地方
多个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
浙江云峰网络技术有限公司处罚
常用的网络安全检测
中国互联网科技新闻
邮箱服务器要填什么
阿图什app软件开发制作
中科曙光国产服务器的优势
数据库安全惨痛案例
云服务器支持oraclesql
软件开发工程师面签需要注意什么
数据库中字段为空怎么表示
博图s1200web服务器
网络安全主题学习心得
p图怎样修改数据库
浅析网络安全法
网络安全 媒体的传播意义
党员软件开发岗位承诺
底层软件开发工具
互联网科技公司享受哪些优惠
元数据服务器管理架构
软件开发属于
服务器插路由器还是交换机
服务器被攻击多久修好
数据库课程教研记录表
fm只玩顶级联赛数据库开多大
软件开发1年没上班了
长春华易软件开发公司
m3 数据库
电话录音到服务器
东昱互联网科技公司
网络安全技术用于网络攻击