2018-09-14vue.js filter过滤器、保留两位小

2018-09-14  本文已影响0人  梁萌0328

一、filter过滤器

过滤器:把要显示在页面上的数据进行筛选或重新操作,分为全局过滤和局部过滤
body部分:

<div id="itany">
     <p>{{6|addZero}}</p>
  </div>

js部分:

<script src="js/vue.js"></script>
<script>
  //   全局过滤
//  Vue.filter('addZero',function(data){
     //   if(data<10){
      //       return '0'+data
      //   }else{
     //      return data
   //   }
  //})
    //局部过滤
    new Vue({
        el:"#itany",
        data:{},
        methods:{},
        filters:{
            addZero:function(data){
                if(data<10){
                    return '0'+data
                }else{
                    return data
                }
            }
        }
    })
</script>

二、保留两位小数练习
body部分:

  <div id="itany">
       <p>{{78.467|number}}</p>
 </div>

js部分:

 <script src="js/vue.js"></script>
<script>
    //全局过滤
    //Vue.filter('number',function(data){
          // return data.toFixed(2)
    //})
    new Vue({
        el:"#itany",
       // 局部过滤
        filters:{
            number:function(data){
                return data.toFixed(2)
            }
        }
        
    })
</script>

效果图:


保留两位小数.png

三、日期时间过滤练习
body部分:

     <div id="itany">
         <p>{{new Date()|time}}</p>
   </div>

js部分:

<script src="js/vue.js"></script>
<script>
    //全局过滤
//Vue.filter('time',function(data){
  //return data.getFullYear()+'年'+data.getMonth()+'月'+data.getDate()+'日,星期'+data.getDay()+data.getHours()+'点'+data.getMinutes()+'分'+data.getSeconds()+'秒'
 // })
  var vm=  new Vue({
        el:'#itany',
//  data:{
// num:new Date(),
 //mon:new Date().getMonth()+1
   // },
 // 局部过滤
        filters:{
            time:function(data){
                       //  var mon=new Date().getMonth()+1
                
           //  return data.getFullYear()+'年'+mon+'月'+data.getDate()+'日,星
             期'+data.getDay()+data.getHours()+'点'+data.getMinutes()+'分'
            +data.getSeconds()+'秒'
                return data.getFullYear()+'年'+(data.getMonth()+1)+'月'+data.getDate()+'日,星期'+data.getDay()+data.getHours()+'点'+data.getMinutes()+'分'+data.getSeconds()+'秒'
            }
        }
    })
</script>

四、vue.js实例的属性
(1) el 获取vue绑定的元素的 (2)data 获取vue实例中的数据
(3) options 获取vue实例中的自定义属性 (4)refs 获取所有带ref属性的元素
案例:
body部分:

<div id="itany">
     {{msg}}
   <h1 ref="box">你好</h1>

  </div>

js部分:

<script src="./js/vue.js"></script>
<script>
     var vm=new Vue({
        el:"#itany",
        data:{
           msg:'hello vue' 
        },
        uname:'jack',
        age:18,
        sex:'男'
    })
//  $el
    console.log(vm.$el);
   vm.$el.style.color='red';
//   $data
    console.log(vm.$data);
 // $options
    console.log(vm.$options);
    console.log(vm.$options.uname);
    console.log(vm.$options.age);
    console.log(vm.$options.sex);
   //  $refs
    console.log(vm.$refs);
    console.log(vm.$refs.box);
 </script>

五、vue.js的计算属性
body部分:

 <div id="itany">
      <h3>{{msg}}</h3>
      <a href="#">{{revemg}}</a>
 </div>

js部分:

<script src="js/vue.js"></script>
<script>
    new Vue({
        el:"#itany",
        data:{
            msg:'hello vue'//vue===hello
        },
        computed:{
            revemg:function(){
                return this.msg.split(' ').reverse().join("===")
            }
        }
    })
</script>

效果图:


计算属性.png
上一篇下一篇

猜你喜欢

热点阅读