Vue1.0学习总结(1)———指令、事件、绑定属性、模板、过滤器

vue: 一个mvvm框架(库),和angular相似
比价容易上手,小巧
----------------------------------------------------------------

vue与angular 的区别:
  vue——简单,易学
  指令以v-xxx;
  一片html代码,配合上json,再new出来vue示例
  是个人维护项目

  适合:移动端项目,小巧

  vue的发展的势头很猛(github上)

  angular——上手比较难
  指令以ng-xxx;
  所有的属性和方法都挂到$scope身上
  angular由Google维护

  适合pc端的项目

vue与angular的共同点:都不兼容低版本的IE(IE8以下不兼容)

----------------------------------------------------------------------
vue里的常见指令:
指令是指:扩展了html标签功能,
angular的指令:ng-model ng-controller

1)v-model: 一般用于表单元素(input) 双向数据绑定


2)v-for(循环):
  v-for='name in arr' {{name}} {{$index}}
  v-for='name in json' {{$key}} {{name}} {{$index}}  

  关于循环的补充:
  v-for="value in data"
  但是在某些情况下循环会有重复的数据,v-for循环中重复数据默认是不能重复添加的
  解决这个问题需要使用track-by="索引"即可
  如:在下面的例子中如果没有track-by="$index",当第一单击按钮时能够push进去数据,
  从而使视图也更新,但是当第二次再点击按钮时,就不能更再添加数据了,
  所以要使用track-by="$index"来添加重复数据

  <div id="box">
    <input type="button" value="按钮" @click="add">
    <ul>
      <li v-for="val in arr" track-by="$index">{{val}}</li>
    </ul>
  </div>

  var vm = new Vue({
    data:{
      arr:['apple','pear','banana']
    },
    methods:{
      add:function(){
        this.arr.push('tomato');
      }
    }
  }).$mount('#box');

注:track-by="$index/uid" 索引可以是$index也可以是数据库的id等


3)v-text指令:可以防止花括号出现
  在我们数据加载的过程中,由于数据加载需要一些时间,常常会出现模板{{}}闪现的不好体验,
  而用v-text指令代替{{}}可以很好的解决这个问题。
  使用模板的写法:<span>{{msg}}</span>
  使用v-text指令的写法:<span v-text="msg"></span> 可以防止花括号出现


4)v-html指令:是一个转义指令,当我们的数据或者用户输入中,含有标签等可以转义的字符,
  v-html就可以将里面的标签进行转义,不会原样输出,造成一些不好的用户体验。
  a) <span v-html="msg"></span> --->v-html进行转义和防止花括号出现
  b) {{{msg}}} <span>{{{msg}}}</span> --->另一种对数据进行转义的方法,与v-html的转义效果相同

  补充:防止花括号闪烁的另外一种方法:
  当访问响应慢时用户有时会看到花括号的标记,这时为最外层div加上v-cloak属性,
  再为v-cloak属性写一个display:none的样式,防止看到花括号的出现
  v-cloak:一般用在比较大的段落

 

  <style>
    /*css属性选择器*/
    [v-cloak]{
      display: none;
    }
  </style>

 

  <div class="reply" v-for="item in msgData" v-cloak>
    <p class="replyContent">{{item.content}}</p>
    <p class="operation">
    <span class="replyTime">{{item.time|date}}</span>
    <span class="handle">
      <a href="javascript:;" class="top">{{item.acc}}</a>
      <a href="javascript:;" class="down_icon">{{item.ref}}</a>
      <a href="javascript:;" class="cut">删除</a>
    </span>
  </p>
</div>

 


5)自定义指令:
  a)自定义属性指令:
    Vue里面通过Vue.directive自定义属性
    Vue.directive('名称',function(参数){ //默认调用的是bind,可以简写,
      //操作;
      //(this.el -->原生的DOM元素)
    });

  <div v-red="参数"></div> //可传参,参数可来自于vue里的data
  指令名称:v-red -->red
  *注意:指令名称必须以v-开头


  示例1:自定义指令,改变背景色
  <div id="box">
  <span v-red="msg">11111111111</span>
  </div>
  <script type="text/javascript">
    Vue.directive('red',function(){ //dom里面是v-red,这里是red
      this.el.style.background='red';
    });
    var vm = new Vue({
      el:'#box',
      data:{
        msg:'welcome'
      }
    });
  </script>


示例2:自定义指令,完成拖拽:
  <div id="box">
    <div class="box2" :style="{width: 100px;height: 100px;background: blue;position: absolute;right: 0;top: 0;}" v-drag></div>
  </div>
  <script type="text/javascript">
    Vue.directive('drag',function(){ //以下是完成拖拽效果的代码
      var odDiv=this.el;
      odDiv.onmousedown=function(ev){
        var disX=ev.clientX-odDiv.offsetLeft;
        var disY=ev.clientY-odDiv.offsetTop;
        document.onmousemove=function(ev){
        var l=ev.clientX-disX;
        var t=ev.clientY-disY;
        odDiv.style.left=l+'px';
        odDiv.style.top=t+'px';
      };
      document.onmouseup=function(ev){
        document.onmousemove=null;
        document.onmouseup=null;
      };
    };
  });
    var vm = new Vue({
      el:'#box',
      data:{

      }
    });
  </script>


b)自定义元素指令:(用的很少,了解即可)
Vue1.0通过Vue.elementDirective自定义元素指令
Vue.elementDirective('元素名称',{
  bind:function(){ //这里不再遵循上面自定义属性指令的简写方式
    //javascript语句;
  }
});


示例:自定义元素指令
css:
zns-red{
  width: 100px;
  height: 100px;
  background: #ccc;
  display: block;
}

html代码:
<div id="box">
  <zns-red></zns-red>
</div>

vue代码:
Vue.elementDirective('zns-red',{
  bind:function(){
    this.el.style.background='red';
  }
});
var vm = new Vue({
  el:'#box',
  data:{

  }
});
--------------------------------------------------------------------------------
事件:
1)基本的事件:v-on:click='show()' 推荐使用 @click='show()'
还有v-onmouseover v-onkeyup/down 等等


2)显示隐藏事件:v-show="false/true"


3)事件对象:@click="show($event,12)" //$event 包含了这个事件的所有的方法
例:methods:{
show:function(ev,b){ //可传一个参数,也可传两个参数,但是顺序不能弄颠倒
alert(ev.client.X)
}
}


4)事件冒泡:
阻止冒泡:在内层阻止,和事件对象$event一起使用
@click="show($event)"
methods:{
show:function(ev){ //可传一个参数,也可传两个参数,但是顺序不能弄颠倒
alert(ev.client.X);
ev.cancelBubble=true;
//ev.stopPropagation();
}
}
推荐使用:@click.stop="show($event)"


5)默认行为(事件):
阻止默认行为:a) ev.preventDefault();
b) @contextmenu.prevent 推荐使用


6)键盘事件:@keydown/keyup $event ev.keycode(捕获任何一个键的键码)
常用键: 回车:a) if(ev.keycode)==13
b) @keyup.13="show()";
c) @keyup.enter="show()" 推荐使用
上、下、左、右
@keyup/keydown.left="show()"
@keyup/keydown.right="show()"
@keyup/keydown.up="show()"
@keyup/keydown.down="show()"


7)自定义键盘事件(键盘上的按键vue没有全部封装)
上面介绍的事件vue封装了:
@keydown.up/down
@keyup.up/down
@keydown.enter
@keydown.a/b/c........

有些键盘按键vue并没有完全封装:
@keydown.ctrl没有封装:
<input type="text" @keydown.ctrl="show()">
@keydown.17封装了(ctrl的键码为17)
<input type="text" @keydown.17="show()">

自定义键盘事件:
Vue.directive('on').keyCodes.ctrl=17;
<input type="text" @keydown.ctrl="show()">
<input type="text" @keydown.ctrl="show() |debounce 2000"> //延迟输出
------------------------------------------------------------------------------------

绑定属性:用v-bind绑定属性 v-bind:src="url" :width/height/src/title="wd"
1)不同绑定属性方法的优缺点:
<img src="{{url}}" alt=""> 效果能出来,但是在控制台会报一个404的错误
<img v-bind:src="url" alt=""> 效果能出来,不会出现404的错误
<img :src="url" alt=""> 推荐使用简写


2)特殊属性:class和style
1) :class="[red,b]"   []括住,表示red和b都是data里的数据
2) :class="{red:true,blue:false}"    {}括住,表示red和blue是class
  :class="{red:a,blue:b}"   red和blue的值可以是true或false,也可以是数据
3) :class="json"
data:{
  json:{red:true,blue:false}
}
a) :style="[c]"
b) :style="[c,d]"    注意:复合样式采用驼峰命名法例如backgroundColor
c) :style="json"


-------------------------------------------------------------------

模板:
{{msg}} 数据更新,模板也更新
{{*msg}} 这个数据不会被绑定,数据更新时,模板不会更新
{{{msg}}} html转义输出

---------------------------------------------------------------------

Vue1.0常见的过滤器-->过滤模板数据
1)系统提供的一些过滤器
{{msg|filterA}} {{msg|filterA|filterB}}
{{'welcome'|uppercase}} 小写转换成大写
{{'WELCOME'|lowercase}} 大写转换成小写
{{'welcome'|capitalize}} 首字母转换成大写
{{a|json}} json过滤器,使json对象能够显示出来
{{'WELCOME'|uppercase|capitalize}} 多个过滤器同时使用
钱的标志:{{12|currency}} --->$12.00
传参:{{12|currency "¥"}} ----> ¥12.00


2)与事件配合使用的过滤器
debounce -->配合事件使用,表示延迟
<input type="text" @keyup="add|debounce 2000">


3)与数据配合使用的过滤器
a)limitBy -->限制几个数据,可接受两个参数
limitBy(取几个 从第几个开始取) 默认从0开始取,一般与数组结合使用
<li v-for="val in arr | limitBy 2">{{val}}</li> //显示两条数据1,2
<li v-for="val in arr | limitBy 2 1">{{val}}</li> //显示两条数据2,3
<li v-for="val in arr | limitBy 2 arr.length-2">{{val}}</li> //显示两条数据4,5
data:{
  arr:[1,2,3,4,5]
}


b)filterBy -->过滤数据
filterBy接受的参数既可以是数据,也可以是变量
<li v-for="val in arr | filterBy 'o'">{{val}}</li> //显示含有'o'的数据
<input type="text" v-model="arr"> //显示含有文本框中内容的数据
<li v-for="val in arr | filterBy a">{{val}}</li>
data:{
  arr:['with','height','background','oppo'],
  a:''
}


c)orderBy -->对数据进行排序
<li v-for="val in arr | orderBy 1">{{val}}</li> //按正序进行排序
<li v-for="val in arr | orderBy -1">{{val}}</li> //按倒序进行排序
<input type="text" v-model="arr"> //按文本框中输入内容进行排序(输入1或-1)
<li v-for="val in arr | orderBy a">{{val}}</li>
data:{
  arr:['with','height','background','oppo'],
  a:''
}


4)自定义过滤器
如何自定义过滤器?
Vue.filter('名称',function(input){ //默认接收的第一个参数是input,是输入的意思
  return 操作
});


示例1:
<div id="box">{{a | toDoch}}</div>
<script>
Vue.filter('toDoch',function(input){ //默认接收的第一个参数是input,是输入的意思
  return input<10?'0'+input:''+input;
});
var vm = new Vue({
  el:'#box',
  data:{
    a:9
  }

});

</script>


示例2:时间转化器:
<div id="box">
{{a |date}}
</div>

<script type="text/javascript">
Vue.filter('date',function(input){ //自定义时间过滤器
  var odate=new Date(input);
  return odate.getFullYear()+'-'+(odate.getMonth()+1)+'-'+odate.getDate()+' '+
odate.getHours()+':'+odate.getMinutes()+':'+odate.getSeconds();
});
var vm = new Vue({
  data:{
    a:Date.now() //获取一个时间戳
  }
}).$mount('#box');
</script>


示例3:过滤html标记
需要用-->双向过滤器(用的比较少)
数据-->视图 model-->view
视图-->数据 view-->model
<div id="box">
  <input type="text" v-model="msg | filterHtml">
  <br/>
  <span v-html="msg"></span>
</div>

Vue.filter('filterHtml',{
  read:function(input){ //view-->model
    return input.replace(/<[^<]+>/g,''); //正则表达式,将html标签替换成空
  },
  write:function(input){ //model-->view
    return input.replace(/<[^<]+>/g,'');
  }
});
var vm = new Vue({
  el:'#box',
  data:{
    msg:'<strong>welcome</strong>'
  }
});

posted @ 2017-03-11 16:49  夏至未至~  阅读(5731)  评论(0编辑  收藏  举报