vue中filters选项的用法

vue中filters选项的用法

filters是.vue文件中export对象中的一个选项,其类型是Object,即包含Vue实例可用过滤器的哈希表。

下面讲讲filters选项的用法

1、html如下

<div id="app">
  {{message | filters2| filters3(true,priceCount)}}
</div>

2、js如下

var app = new Vue({
  el: "#app",
  data: {
    message: 199,
    priceCount:0.8
  },
  filters:{
    filters2:function (arg) {
      console.log("arg:"+arg)
      if(arg>100){
        return arg-8;
      }else {
        return arg;
      }
    },
    filters3:function (arg_1,arg_2,arg_3) {
      var result;
      console.log("arg_1:"+arg_1)
      console.log("arg_2:"+arg_2)
      console.log("arg_3:"+arg_3)
      if(arg_2){
        result = arg_1*arg_3;
        console.log("result"+result);
        return result;
      }else{
        result =arg_1;
        console.log("result"+result);
        return result
      }
 
    }
  }
});

3、控制台的输出

helloVue.js:17 arg:199
helloVue.js:26 arg_1:191
helloVue.js:27 arg_2:true
helloVue.js:28 arg_3:0.8
helloVue.js:35 result152.8

4、分析

首先,在data里面定义两个变量message:199,priceCount:0.8,

然后,在.vue文件中的<script>里面的filters选项里面定义两个函数filters2(arg)和filters3(arg_1,arg_2,arg_3)

最后,在.vue文件里面的<template>中调用filters中定义的函数,如下所示:

<div id="app">
  {{message | filters2| filters3(true,priceCount)}}
</div>
{{}}里面第一个变量message是在data里面定义的变量,message作为filters2函数的参数,然后filters2函数的返回值result作为filter3函数的第一个参数,即filters3(result,true,priceCount),所以得到上述控制台的输出







转载地址:点击打开链接

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vuefilters是用于在模板对数据进行筛选和格式化的方法。通过filters,你可以在模板对数据进行一些常见的操作,比如格式化日期、转换大小写、截取字符串等。 在Vue的组件,你可以在`filters`选项下定义一个或多个过滤器。下面是一个例子: ```javascript Vue.filter('capitalize', function(value) { if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1) }) ``` 在上面的例子,我们定义了一个名为`capitalize`的过滤器,它会将传入的值的首字母转换为大写。在模板使用这个过滤器的方式如下: ```html <p>{{ message | capitalize }}</p> ``` 在上面的代码,`message`是要被过滤的数据。通过管道符`|`将`message`传递给`capitalize`过滤器进行处理,然后将处理后的结果显示在模板。 除了单个参数的过滤器,你也可以定义接受多个参数的过滤器。例如: ```javascript Vue.filter('truncate', function(value, length) { if (!value) return '' if (value.length > length) { return value.substring(0, length) + '...' } else { return value } }) ``` 在上面的例子,我们定义了一个名为`truncate`的过滤器,它会将传入的字符串截取到指定的长度,并在末尾添加省略号。在模板使用这个过滤器的方式如下: ```html <p>{{ message | truncate(20) }}</p> ``` 上面的代码,`message`是要被过滤的数据,`20`是传递给`truncate`过滤器的参数,表示截取的长度。 以上是关于Vuefilters的简单介绍和用法。你可以根据实际需求定义和使用不同的过滤器来对数据进行筛选和格式化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值