vuejs filter过滤器的使用(Vue过滤器filter实现及应用场景详解)
vuejs filter过滤器的使用
Vue过滤器filter实现及应用场景详解1. 简单介绍
Vue.js 允许你自定义过滤器(filter),可被用于一些常见的文本格式化。
过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。
过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:
<!-- 在双花括号中 --> {{ message | filter }} <!-- 在 `v-bind` 中 --> <li v-bind:msg="message | filter"></li>
过滤器函数总接收表达式的值作为第一个参数。
在上述例子中,filter 过滤器函数将会收到 message 的值作为第一个参数。
1.1 过滤器可以串联
{{ message | filterA | filterB }}
在这个例子中,filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB 中。
1.2 过滤器是 JavaScript 函数可以接收参数
{{ message | filterA('arg1', arg2) }}
filterA 被定义为接收三个参数的过滤器函数。其中 message 的值作为第一个参数,普通字符串 'arg1' 作为第二个参数,表达式 arg2 的值作为第三个参数。
2. vue-cli中定义全局过滤器
语法:Vue.filter( filterName,( ) => { return // 数据处理结果 } )
eg:
<li id="app"> <h3>{{userName | addName}}</h3> </li> <script> // 参数一:是过滤器的名字,也就是管道符后边的处理函数; // 参数二:处理函数,处理函数的参数同上 Vue.filter("addName",(value)=>{ return "my name is" + value }) let vm = new Vue({ el:"#app", data:{ userName:"小明" } }) </script>
2.1 实际开发使用
全局过滤器经常会被在数据修饰上,通常我们把处理函数给抽离出去,统一放在一个.js文件中。
// filter.js 文件 let filterPrice = (value) => { return '已收款' + value + '元' } let filterDate = (value) => { return value + '天' } export default {filterPrice,filterDate}
在main.js中 导入 上边 filter.js文件 ,也可以在任何组件中导入 filter.js这个文件,但对于全局过滤器来说,最好是在main.js中定义,导入的是一个对象,所以使用Object.keys()方法,得到一个由key组成的数组,遍历数据,让key作为全局过滤器的名字,后边的是key对应的处理函数,这样在任何一个组件中都可以使用全局过滤器了:
//main.js //下边是2种导入方式,推荐第一种 import * as filters from './utils/filter/filter' // import {filterPrice,filterDate} from './utils/filter/filter' console.log(filters) Object.keys(filters.default).forEach((item)=>{ Vue.filter(item,filters.default[item]) }) new Vue({ router, store, render: h => h(App), }).$mount('#app')
3. 在组件中使用 全局过滤器:
// test.vue <template> <li> <input type="text" v-model="filterCount" > <li>{{filterCount | filterPrice}}</li> <li>{{filterCount | filterDate}}</li> </li> </template> <script> export default { data(){ return { filterCount:1500 } }, } </script>
3. vue-cli中定义局部过滤器
// test.vue <template> <li> <input type="text" v-model="filterCount" > <li>{{filterCount | filterPrice}}</li> <li>{{filterCount | filterDate}}</li> </li> </template> <script> export default { data(){ return { filterCount:1500 } }, } </script>
4. 常见使用场景
4.1 格式日期(时间)
场景一:后端传的时间:2019-11-19T04:32:46Z
安装moment.js
// main.js import moment from 'moment' // 定义全局过滤器--时间格式化 Vue.filter('format',function(val,arg){ if(!val) return; val = val.toString() return moment(val).format(arg) })
// test.vue <template> <li class="filter">{{time | format('YYYY-MM-DD HH:MM:SS')}}</li> </template> <script> export default { data(){ return { time:'2019-11-19T04:32:46Z' } } } </script>
总结
到此这篇关于Vue过滤器(filter)实现及应用场景的文章就介绍到这了,更多相关Vue过滤器(filter)实现应用内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- vue3 props用法(vue3组合API中setup、 ref、reactive的使用大全)
- vuex怎么使用数据(vuex的辅助函数该如何使用)
- vue移动端返回在指定位置(vue移动端判断手指在屏幕滑动方向)
- vuefor指令使用教程(Vue必学知识点之forEach的使用)
- 使用vue-cli构建electron项目(MAC+PyCharm+Flask+Vue.js搭建系统)
- vue组件详解(Vue的方法和属性案例详解)
- vue前台解析pdf文件流(Vue实现在线预览pdf文件功能利用pdf.js/iframe/embed)
- vue3封装table组件(Vue封装通用table组件的完整步骤记录)
- vue指令使用技巧(Vue指令工作原理实现方法)
- vue双向数据绑定js如何实现(纯JS如何实现vue.js下的双向绑定功能)
- vue是怎样进行页面跳转(Vue实现登陆跳转)
- vue设置div大小(Vue实现div滚轮放大缩小)
- vue element admin接口(Vue-Element-Admin集成自己的接口实现登录跳转)
- vue 排班安排(vue实现钉钉的考勤日历)
- vuekeep-alive源码(vue中keepAlive组件的作用和使用方法详解)
- vue3 响应式的实现过程(Vue3.x使用mitt.js进行组件通信)
- 缅甸旅游攻略(缅甸旅游攻略必去景点推荐)
- 《庆余年2》新消息,原班人马,肖战特别出演,这才是最好的安排(庆余年2新消息原班人马)
- 宁夏灵武恐龙化石发现始末(宁夏灵武恐龙化石发现始末)
- 到了岁末 临门一脚 节点,天台综合督评会目标直指 全年红(到了岁末临门一脚)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
热门推荐
- jquery中text(),val(),html()区别
- dockermysql配置详解(Docker 部署Mysql 服务和Redis 服务的方法)
- css在ie中怎么显示不正常(IE6和IE7中行内元素后的浮动元素被折行的问题解决)
- mysql中mergeinto的用法(MySQL中exists、in及any的基本用法)
- Asp.Net中索引器的用法
- 如何让tomcat启动更快(快速解决Tomcat启动慢的问题,超简单)
- mysqldump 命令详解(mysqldump你可能不知道的参数)
- python实例之pyqt5多窗口实现(python+pyqt5编写md5生成器)
- 频繁变化字段如何建立索引(跳槽必备之你设计索引的原则是什么?怎么避免索引失效?)
- python函数参数讲解(Python高级特性与几种函数的讲解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9