Vue学习:过滤器

过滤器:对要显示的数据进行特定格式化后再显示(适用于一些简单的逻辑处理)

显示格式化之后的时间(即时间戳)

Date.now()

1676441811559

解析时间的第三方库:moment.js(但是体积比较大)dayjs (比较小)

使用计算属性来得出,

    <!-- 准备容器 -->
    <div id='root'>
       <h2>显示格式化之后的时间</h2>
       <h3>格式前:{{time}}</h3>
       <h3>格式后:{{fmTime}}</h3>

        </form>

    </div>
    <script>
        new Vue({
            el: '#root',
            data: {
                time:1676441811559,

            },
            computed:{
                fmTime(){
                    return dayjs(this.time). format('YYYY年MM月DD日 HH:mm:ss')
                }
            }

        });
       

使用methods方法

methods
       <h3>格式后:{{getFmtTime()}}</h3>

  methods: {
                getFmtTime(){
                    return dayjs(this.time). format('YYYY-MM-DD HH:mm:ss')
                }

使用过滤器:不传参( 过滤器:捕获time 然后作为参数传递给filterTime 返回值替换掉整个语法)

  过滤器:捕获time 然后作为参数传递给filterTime 返回值替换掉整个语法
        <h3>格式后:{{time | filterTime}}</h3>

   filters:{
              
                filterTime(val,){//函数  返回值替换掉整个语法
                    console.log(val)
                    return dayjs(val). format(YYYY-MM-DD HH:mm:ss)
                }
            }

传参: 想要一个过滤器实现不同的效果 可以传参 参数作为第2个值

 <h3>格式后:{{time | filterTime('YYYY年MM月DD日')}}</h3>

            filters:{
                //ES6形参默认值 如果a有值 就用传递的值 如果没有 就直接使用默认值
                filterTime(val,a='YYYY-MM-DD HH:mm:ss'){//函数  返回值替换掉整个语法
                    console.log(val)
                    return dayjs(val). format(a)
                }
            }

多个过滤器之间可以串联 进行过滤器的串联(将 第一个参数传递给第1个过滤器 返回值作为第2个过滤器的参数) 一层一层

 <h3>格式后:{{time | filterTime('YYYY年MM月DD日') | mySilce}}</h3>

            filters:{
                //ES6形参默认值 如果a有值 就用传递的值 如果没有 就直接使用默认值
                filterTime(val,a='YYYY-MM-DD HH:mm:ss'){//函数  返回值替换掉整个语法
                    console.log(val)
                    return dayjs(val). format(a)
                },
                mySilce(val){
                    return val.slice(0,4)//截取前四位
                }
            }

全局过滤器 必须在vUE之前 Vue.filter

      Vue.filter('mySilce',function(val){
                    return val.slice(0,4)//截取前四位
                })
                

过滤器不一定非得在 插值语法上在v-bind也可以’

    <h1 :x="url | mySilce">xccccccxx</h1>
 url:'shdiasuiu'
<!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>
    <script src="https://cdn.bootcdn.net/ajax/libs/dayjs/1.11.7/dayjs.min.js"></script>
    <script type="text/javascript" src="./js引入/测试版本/vue.js"></script>
</head>

<body>
    <!-- 计算属性实现 -->
    <!-- 准备容器 -->
    <div id='root'>
       <h2>显示格式化之后的时间</h2>
       <h3>格式前:{{time}}</h3>
       <hr>
       计算属性
       <h3>格式后:{{fmTime}}</h3>
       <hr>
      methods
       <h3>格式后:{{getFmtTime()}}</h3>
       <hr>
       过滤器:捕获time 然后作为参数传递给filterTime 返回值替换掉整个语法
        <h3>格式后:{{time | filterTime}}</h3>
        想要一个过滤器实现不同的效果 可以传参 参数作为第2个值
        <h3>格式后:{{time | filterTime('YYYY年MM月DD日')}}</h3>
        进行过滤器的串联(将 第一个参数传递给第1个过滤器 返回值作为第2个过滤器的参数)
        <h3>格式后:{{time | filterTime('YYYY年MM月DD日') | mySilce}}</h3>

        <h1 :x="url | mySilce">xccccccxx</h1>


    </div>
    <div id="root2">
        <h2>{{name | mySilce}}</h2>
    </div>
    <script>
        Vue.filter('mySilce',function(val){
                    return val.slice(0,4)//截取前四位
                })

        new Vue({
            el: '#root',
            data: {
                time:1676441811559,
                url:'shdiasuiu'

            },
            computed:{
                fmTime(){
                    return dayjs(this.time). format('YYYY年MM月DD日 HH:mm:ss')
                }
            },
            methods: {
                getFmtTime(){
                    return dayjs(this.time). format('YYYY-MM-DD HH:mm:ss')
                }
            },
            //局部过滤器
            filters:{
                //ES6形参默认值 如果a有值 就用传递的值 如果没有 就直接使用默认值
                filterTime(val,a='YYYY-MM-DD HH:mm:ss'){//函数  返回值替换掉整个语法
                    console.log(val)
                    return dayjs(val). format(a)
                },
              
            }

        });
       new Vue({ 
        el: '#root2',
        data: {
            name:"ssssxxxxx"

        },
        
       });
    </script>
</body>

</html>

过滤器:对要显示的数据进行特定格式化后再显示(适用于一些简单的逻辑处理)

1、注册全局过滤器 Vue.filter(名字,回调函数)

局部过滤器 new Vue{filters:{名字,回调函数}}

2、使用过滤器:{{xxx|过滤器名字}} 或者 v-bind:属性="xxx|过滤器名"

3、过滤器可以接收额外参数、多个过滤器也可以串联

4、并没有改变原本数据,时产生新的对应数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值