Vue.js过滤器filters

目录

一、局部过滤器

二、全局过滤器

三、过滤器串联

四、过滤器接收多个参数 


        Vue.js允许自定义过滤器,过滤器的作用可被用于一些常见的文本格式化(也就是修饰文本,但是文本内容不会改变)

过滤器可以用在两个地方:双花括号插值或v-bind表达式

一、局部过滤器

局部过滤器使用示例:

    <div id="root">
        <p>电脑价格:{{price | addPriceIcon}}</p>
    </div>
    <script>
        Vue.config.productionTip = false;
        const vm = new Vue({
            el: '#root',
            data: {
                price:200
            },
            filters: {
                //处理函数
                addPriceIcon(value){
                    console.log(value);
                    return '¥' + value;
                }

            }
        })
    </script>

执行结果:

         这段代码的需求是在价格前面加上人民币符号(¥)。模板中文版(price)后边需要添加管道符号(|)作为分隔,管道符(|)后边是文本的处理函数(addPriceIcon),处理函数的第一个参数是管道符前边的文本内容(price)。        

二、全局过滤器

全局过滤器使用示例:

    <div id="root">
        <p>电脑价格:{{price | addPriceIcon}}</p>
    </div>
    <script>
        Vue.config.productionTip = false;
        Vue.filter("addPriceIcon",(value)=>{
            return '¥' + value;
        })
        const vm = new Vue({
            el: '#root',
            data: {
                price:200
            }
        })
    </script>

执行结果:

 注意:当全局过滤器和局部过滤器重名时,会采用局部过滤器

三、过滤器串联

过滤器还可以串联,例如:

{{price | filterA  | filterB}}

        filterA被定义为接收单个参数的过滤器参数,表达式price的值将被作为参数传入参数。然后继续调用同样被定义接收单个参数的过滤器函数filterB,将filterA的结果传递到filterB中。

过滤器串联示例:

    <div id="root">
        <p>电脑价格:{{price | addPriceIcon | addChinesePriceIcon}}</p>
    </div>
    <script>
        Vue.config.productionTip = false;
        Vue.filter("addPriceIcon",(value)=>{
            return '¥' + value;
        })
        Vue.filter("addChinesePriceIcon",(value)=>{
            return '人民币' + value;
        })
        const vm = new Vue({
            el: '#root',
            data: {
                price:200
            }
        })
    </script>

执行结果:

四、过滤器接收多个参数 

过滤器是JavaScript函数,因此可以接收两个参数:

{{ price | filterA(arg) }}

        filterA被定义为接收两个参数的过滤器参数。其中price的值作为第一个参数,表达式arg的值可作为第二个参数,也可接收多个参数

过滤器接收两个参数示例:

    <div id="root">
        <p>电脑价格:{{price | addPriceIcon(unit)}}</p>
    </div>
    <script>
        Vue.config.productionTip = false;
        const vm = new Vue({
            el: '#root',
            data: {
                price:200,
                unit:"(元)"
            },
            filters: {
                // 处理函数
                addPriceIcon(value1,value2){
                    return '¥' + value1 + value2;
                }
            }
        })
    </script>

执行结果:

过滤器接收多个参数示例:

    <div id="root">
        {{al | filterAa(a2,a3,...an...)}}
    </div>
    <script>
        filters: {
            // 处理函数
            addPriceIcon(a1,a2,a3,...an...){
                //a1是传入的第1个参数
                //a2是传入的第2个参数
                //a3是传入的第3个参数
                //......
                //an是传入的第n个参数
            }
    </script>
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue.js过滤器是一种用于对数据进行处理和格式化的功能。在Vue.js中,有两种使用过滤器的方式:全局过滤器和局部过滤器。 全局过滤器可以在Vue实例创建之前定义,并在整个应用程序中使用。例如,在Vue实例创建之前,可以使用Vue.filter()方法定义一个全局过滤器。然后,在模板中使用管道符(|)将数据传递给过滤器进行处理。\[1\]例如,可以定义一个名为addPriceIcon的全局过滤器,用于在价格前添加货币符号: ``` Vue.filter("addPriceIcon", (value) => { return '¥' + value; }) ``` 然后,在模板中使用该过滤器: ``` <p>电脑价格:{{price | addPriceIcon}}</p> ``` 局部过滤器只在特定的Vue实例中可用。可以在Vue实例的filters选项中定义局部过滤器。\[2\]例如,可以在Vue实例的filters选项中定义一个名为addPriceIcon的过滤器: ``` filters: { addPriceIcon(value) { return '¥' + value; } } ``` 然后,在模板中使用该过滤器: ``` <p>电脑价格:{{price | addPriceIcon}}</p> ``` 无论是全局过滤器还是局部过滤器,都可以在模板中使用管道符(|)将数据传递给过滤器进行处理。过滤器可以接受参数,并在处理数据时使用这些参数。\[3\]例如,可以定义一个名为sum的全局过滤器,用于将传入的值加上4: ``` Vue.filter("sum", function(value) { return value + 4; }); ``` 然后,在模板中使用该过滤器: ``` <p>{{message | sum}}</p> ``` 总结起来,Vue.js过滤器是一种用于对数据进行处理和格式化的功能。可以通过全局过滤器或局部过滤器来定义和使用过滤器。无论是全局过滤器还是局部过滤器,都可以在模板中使用管道符(|)将数据传递给过滤器进行处理。过滤器可以接受参数,并在处理数据时使用这些参数。 #### 引用[.reference_title] - *1* *2* [Vue.js过滤器filters](https://blog.csdn.net/m0_61961937/article/details/130302483)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Vue.js基础-过滤器filters)](https://blog.csdn.net/Jasmines1993/article/details/79665079)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏志121

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值