大家好,欢迎来到IT知识分享网。
1、过滤器的用法,用 ‘|’ 分割表达式和过滤器。
Vue.js 1.x有内置过滤器,但是2.0中已经废弃了过滤器,需要我们自定义。Vue.js 自定义过滤器,可被用作一些常见的文本格式化。过滤器可以用在两个地方:mustache 插值和 v-bind
表达式。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示:
<!-- in mustaches -->{ { message | capitalize }}<!-- in v-bind --><div v-bind:id="rawId | formatId"></div>
Vue 2.x 中,过滤器只能在 mustache 绑定和 v-bind
表达式 (后者从 2.1.0 起支持) 中使用,因为过滤器设计目的就是用于文本转换。为了在其他指令中实现更复杂的数据变换,你应该使用计算属性。
过滤器函数总接受表达式的值作为第一个参数。
<template>
<div>
<h1>{
{message | capitalize}}</h1>
</div>
</template>
<script>
export default {
data () {
return {
message: 'vue filter'
}
},
filters: {
capitalize: function (value) {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
}
}
</script>
过滤器可以串联:
{
{ message | filterA | filterB }}
过滤器是 JavaScript 函数,因此可以接受参数:
{
{ message | filterA('arg1', arg2) }}
这里,字符串 'arg1'
将传给过滤器作为第二个参数, arg2
表达式的值将被求值然后传给过滤器作为第三个参数。
2、自定义的过滤器
过滤器的结构为:Vue.filter(“id”,function(value,a){});
value是过滤器的一个参数,也是默认的原始值。a是自定义的一个参数。
<template>
<div>
<!--输出的字符串中a的个数-->
<span>msg的值:{
{msg}},其中a的个数:</span> {
{msg | myfilter('a')}}
<br>
</div>
</template>
<script>
export default {
data () {
return {
msg: 'a1a1aba2babac'
}
},
filters: {
myfilter (value, arg) {
let s = value.split('')
let n = 0
s.forEach((elem) => {
if (elem === arg) {
n++
}
})
return n
}
}
}
</script>
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/15533.html