简述Vue中的过滤器
1、过滤器的基本概念
- 概念:本质上是函数;
- 作用:用户输入数据后,它能够进行处理,并返回一个数据结果;(无return语句不会报错,但是这种过滤器没有丝毫意义)
- 格式:管道符( | )进行连接,而管道符的作用就是:上一个命令的输出可以作为下一个命令的输入;
- 位置:只能是Mustache表达式、v-bind表达式;{{ msg | filterFuction }} <p v-bind:id="msg | filterFuction"></p>
- 强调:在过滤器函数中,表达式的值作为第一个参数、带引号的参数会被当做字符串处理、而不带引号的参数则会被当做属性名处理,过滤器可以接受参数,参数跟在过滤器名称的后面,参数之间以逗号分隔,例如:
{{ message | filterFunction('arg1',arg2)}}//过滤器函数中传入的参数以后面开始的参数来统计和赋值
2、过滤器种类
- 内置过滤器(Vue2.x之后没有内置过滤器,必须自己定义)
- capitalize:将表达式中的首字母转换为大写形式;
- uppercase:将表达式的所有字母转换为大写格式;
- lowercase:将表达式的所有字母转换为小写格式;
- json过滤器:相当于JSON.stringify();
- 限制:处理并返回过滤后的数组 处理对象:数组
- limitBy:第一个参数是显示数据的数量,第二个参数(可选)为开始显示的数组下标,默认为2;
- filterBy:(字符串|函数 in 过滤值);
- orderBy:返回排序后的数组,(字符串|数组|函数,排序方式(可选,大>=0升序,<0降序,默认为1));
- currency:将数字值转换为货币的形式输出(符号:默认$,小数位:默认为2);
- debounce过滤器:默认300ms
- 自定义过滤器
- 语法:Vue.filter(ID,function(){ })
- 步骤:
- 建立js文件
- 在app.js文件中引入
- 写filter函数
- 单个参数(以值为参数)
- 全局写法:
import Vue from 'vue'
Vue.filter('uppercase',function(value){
if(value){
return value.toUpperCase()
}
})使用:{{ data | uppercase}} data : 'wxh'
- 全局写法:
- 单个参数(以值为参数)
结果:WXH
局部写法:(只能在当前实例中使用)
<template>
<div id="example">{{ data | uppercase}}</div>
</template>
<script>
export default {
name: "example",
data() {
return {
data: "wxh"
};
},
filters: {
uppercase: function(value) {
if (value) {
return value.toUpperCase();
}
}
},
methods: {}
};
</script>使用与结果跟上边一样
- 多参数(参数之间用 “,” 分开)Vue1.x以空格分隔
- 写过滤器函数:
import Vue from 'vue'
Vue.filter('concat',function(value,prep,desc){
if(value){
return value + prep + desc
}
}) - 在组件中使用:
<template>
<div id="example">{{ data | concat('是一个',describe)}}</div>
</template>
<script>
export default {
name: "example",
data() {
return {
data: "wxh",
describe : "善良的小姑娘"
};
},
methods: {}
};
</script>结果:
- 写过滤器函数:
- 多参数(参数之间用 “,” 分开)Vue1.x以空格分隔

- 双向过滤器:(Vue1.x之后被废除,因此无法实现数据的双向绑定,而我们可以采用computed里面的getter与setter方法进行数据双向绑定,但是比较繁琐)
filters : {
doubleFilter : {//自定义 过滤器 以及 计算属性 形式差不多
//model--->view 将model数据输出到view层之前进行数据转化
read : function(value){ },
//view--->model 将视图的值在写会model前进行转化
write : function(newVal,oldVal){ }
}
}
- 双向过滤器:(Vue1.x之后被废除,因此无法实现数据的双向绑定,而我们可以采用computed里面的getter与setter方法进行数据双向绑定,但是比较繁琐)
3、过滤器的一个小型demo
- 进行数据的格式化,让数据按照我们的规定输出,例如:将日期转化为 2019-07-15 15:11:49
- 过滤器
import Vue from 'vue' Vue.filter('timeFormatter', function (value) {
if (value) {
let date = new Date(value);
let y = date.getFullYear();
let MM = date.getMonth() + 1;
MM = MM < 10 ? ('0' + MM) : MM;
let d = date.getDate();
d = d < 10 ? ('0' + d) : d;
let h = date.getHours();
h = h < 10 ? ('0' + h) : h;
let m = date.getMinutes();
m = m < 10 ? ('0' + m) : m;
let s = date.getSeconds();
s = s < 10 ? ('0' + s) : s;
return y + '-' + MM + '-' + d + ' ' + h + ':' + m + ':' + s;
}
})使用:
<template>
<div id="example">
<p>过滤器:{{ time | timeFormatter}}</p>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
time : new Date().getTime()
};
},
methods: {}
};
</script>结果:过滤器:2019-07-15 15:13:50
- 在定时器 “ 补零 ” 方面,也可以采用es6的方法;
import Vue from 'vue' Vue.filter('timeFormatter', function (value) {
if (value) {
let date = new Date(value);
let y = date.getFullYear();
let MM = date.getMonth() + 1;
MM = MM.toString().padStart(2,'0');//padStart为字符串的方法 为两位数,不足时在开头补零
let d = date.getDate();
d = d.toString().padStart();
let h = date.getHours();
h = h.toString().padStart();
let m = date.getMinutes();
m = m.toString().padStart();
let s = date.getSeconds();
s = s.toString().padStart();
return y + '-' + MM + '-' + d + ' ' + h + ':' + m + ':' + s;
}
})
4、遇到的问题
无
简述Vue中的过滤器的更多相关文章
- 黑马vue---28、vue中全局过滤器的基本使用
黑马vue---28.vue中全局过滤器的基本使用 一.总结 一句话总结: vue中的过滤器可以传递参数(根据参数来过滤),也可以用管道符拼接多个过滤器:例如<p>{{ msg | msg ...
- 简述vue中父子组件是怎样相互传递值的(基础向)
前言 首先,你需要知道vue中父组件和子组件分别指的是什么? 父组件:vue的根实例——用new Vue()构造函数创建的vue实例(实例会有一个挂载点,挂载点里的所有内容可理解为父组件的内容) ...
- 第二章 Vue快速入门-- 24 过滤器-Vue中全局过滤器的基本使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- 简述vue中v-if和v-show的区别
vue中的 v-if 和 v-show 二者都可以动态的控制元素的隐藏和显示,但是他们控制的原理是不同的 v-if v-if 控制元素显示或隐藏是把dom元素整个的渲染或者删除,如果删除,也就是页面中 ...
- Vue 中的过滤器的使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- vue中的过滤器
过滤器 过滤器规则 Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化.过滤器可以用在两个地方: 双花括号插值{{}}和 v-bind 表达式 (后者从 2.1.0+ 开始支持).过滤器应 ...
- Vue中全局过滤器期与局部过滤器期的使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Vue中,过滤器的使用方法!
Vue.js允许自定义过滤器,可被用于一些常见的文本格式化.过滤器可以用在两个地方:双花括号插值和v-bind表达式.过滤器应该被添加在JavaScript表达式的尾部,由“管道”符号指示:(借官方的 ...
- 简述Vue中使用Vuex
1.为什么要用vuex 在vue组件通信的过程中,我们通信的目的往往就是在组件之间传递数据或组件的状态(这里将数据和状态统称为状态),进而更改状态.但可以看到如果我们通过最基本的方式来进行通信,一旦需 ...
随机推荐
- L3-015. 球队“食物链”
某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席突发奇想,希望从中找出一条包含所有球队的“食物链 ...
- 1122. Hamiltonian Cycle (25)
The "Hamilton cycle problem" is to find a simple cycle that contains every vertex in a gra ...
- Comet OJ - 模拟赛 #2 Day1 比赛总结
比赛情况 40 + 60 + 0 = 100pts 哎,T1做错了,没有对拍.如果发现错误 \(=>\) 改正 \(=>\) 40->100pts,160pts \(=>\) ...
- 原生JS 将时间转换成几秒前,几分钟前…常用于评论回复功能
//格式化时间 留备用~ function getDateDiff(dateStr) { var publishTime = dateStr / 1000, d_seconds, d_minutes, ...
- 【leetcode】1103. Distribute Candies to People
题目如下: We distribute some number of candies, to a row of n = num_people people in the following way: ...
- js用逗号分隔字符串,保留双引号中的字符串
/** * 按逗号分解字符串, 引号中的逗号要保留, 并去除空值. * 方案: 1.将引号中都逗号替换为一个字符串中没有的符号; 2. 用split分解; 3. 去掉空值; 4. 还原引号中的逗号. ...
- handy源码阅读(六):tcp类
首先是tcpconn和tcpserver类: struct TcpConn : public std::enable_shared_from_this<TcpConn>, private ...
- echart--如何自定义提示框的内容和样式实例
图例的大概样子 具体设置代码为:
- spring boot不要放在tomcat下启动,因为自身就带了集成tomcat
spring boot不要放在tomcat下启动,因为自身就带了集成tomcat
- 约数定理(two)
筛约数个数和 理论基础: 1.对n质因数分解,n=p1^k1 * p2^k2 * p3^k3 …… 则n的约数个数为(k1+1)*(k2+1)*(k3+1)…… 2.线性筛素数时,用i和素数pj来筛掉 ...