vue-14 过滤器

什么是过滤器

过滤器对将要显示的文本,先进行特定格式化处理,然后再进行显示

注意:过滤器并没有改变原本的数据, 只是产生新的对应的数据

使用方式

1. 定义过滤器:

全局过滤器:

局部过滤器:在Vue实例中使用 fifilter 选项 , 当前实例范围内可用

mengxuegu.com

第五章 Vue 过滤器和插件

5.1 过滤器

5.1.1 什么是过滤器

过滤器对将要显示的文本,先进行特定格式化处理,然后再进行显示

注意:过滤器并没有改变原本的数据, 只是产生新的对应的数据

5.1.2 使用方式

1. 定义过滤器:

全局过滤器:

Vue.filter('过滤器名称',function(value1,[value2,...]){
        // 数据处理逻辑
    })

局部过滤器:在Vue实例中使用 fifilter 选项 , 当前实例范围内可用

 new Vue({
        filters: {
            '过滤器名称': function(value1,[value2,...]){
                // 数据处理逻辑
            }
        }
    })

2. 过滤器可以用在两个地方:双花括号 {{}} 和 v-bind 表达式

案例演示

  • 需求:
  1. 实现过滤敏感字符,如当文本中有 tmd、sb 都将进行过滤掉
  2. 过滤器传入多个参数 ,实现求和运算
  • 实现:
  1. 新建 vue-04-过滤器和插件 目录, 安装 vue.js 模块
  2. 在 vue-04-过滤器和插件 目录下创建 01-过滤器.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <h3>过滤器接收单个参数</h3>
        <p>{{content | contentFilter}}</p>
        <input type="text" :value="content | contentFilter">

        <h3>过滤器接收多个参数</h3>
        <p>{{englishScore | add(mathScore,chinaScore)}}</p>
        <input type="text" :value="englishScore | add(mathScore,chinaScore)">
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script>
        // Vue.filter('contentFilter',function(val){
        //     if(!val){
        //         return ''
        //     }
        //     return val.toString().toUpperCase().replace('TMD','***').replace('SB',"***")
        // })
        new Vue({
            el: '#app',
            data: {
                content: '小伙子,你tmd就是个SB',
                englishScore: 98,
                mathScore: 89,
                chinaScore: 100
            },
            filters:{
                contentFilter(val){
                    if(!val){
                        return ''
                    }
                    return val.toString().toUpperCase().replace('TMD','***').replace('SB','**')
                },
                add(num1,num2,num3){
                    return num1 + num2 + num3
                }
            }
        })
    </script>
</body>
</html>

gitee源码:https://gitee.com/cyzgw/vue_demo.git

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值