Vue对象解析:
1,对象属性
data、el、options、watch、computed
2,对象方法
生命周期之钩子函数
3,对象实例访问和调用属性和方法
A:实例属性调用:$options、$el、$data、$watch
这里着重说下$watch,它的一般语法为:
vm.$watch("监听的实例属性名",function() { // 对于监听数据变化后的业务处理代码 }); --浅度监听如果监听的属性是基本数据类型,上面用法是没有问题的,但如果监听的属性是对象,则对象内部的数据有变化,上面写法是监听不到的,需要进行一个参数进行深度监听,具体语法如下:
vm.$watch("监听的实例属性名",function() { // 对于监听数据变化后的业务处理代码 },{deep: true}); --深度监听B:实例方法调用:$mount()、$log()、$destroy()
4,自带过滤器&自定义过滤器
A:vue自带的过滤器有:
capitalize(首字母大写)、uppercase、currency、json( 相当于JSON.Stringify() )、debounce(后跟秒数,配合事件,延迟执行)
limitBy(参数1, 参数2) 常用语v-for数组,限制输出数量和从哪输出;参数1代表输出几个,参数2代表从第几个输出
filterBy(参数) 过滤数据,过滤含有参数的数据,配合input输入框,通过输入变量过滤,打到热搜索的效果
orderBy(参数) 对数据排序,参数为1时为正序,为-1时则倒序,其他什么参数呢?所以1和-1基本是常用情况
B:自定义过滤器语法 (对于时间戳的处理是比较常用的自定义过滤器)
Vue.filter("过滤器名称",function(参数...){ ... //业务处理 return ...; });5,自带指令和自定义指令
指令是对HTML语法的扩展,必须以v-开头,一般我们口中的指令实际是指属性指令,使用该属性指令的元素讲具有对应的属性功能,下面的C则是指元素指令,与属性指令有所区别
A:自带指令:v-if、v-show、v-else、v-module、v-text、v-html、v-bind、v-on、v-el、v-cloak...
这里着重说下v-text和v-cloak:在模板中我们调用实例属性数据时通常这样{{ 实例属性 }},这样在网速比较慢的情况下,页面出现闪烁的时候会把花括号和里面的原始内容显示出来,这样用户体验不好,处理这种情况有2种方式:
1, 在较大段落元素上使用v-clock指令,并设置该元素的css: display:none
2, 使用v-text/v-html代替花括号即可,Vue2.0也支持这样做,且花括号方式可能被取消
B:自定义指令语法:
Vue.directive("指令名称",function(..){ this.el.style.background = 'red'; //这里的this代表new出来的实例,this.el代表原生的dom元素 });模板中使用v-指令名称进行使用,或v-指令名称="参数",可以在调用指令是进行传参
定义指令名称时不加v-,模板使用时加v-
C: 自定义元素指令 (据说用处不大,可忽略跳过,它所想要达到的效果,组件已超越)
Vue.elementDirective("自定义元素名称",{ bind: function() {}; });它不支持B情况语法,但B情况语法却默认也是bind
6,自定义键盘信息
Vue.directive('on'),keyCodes.ctrl = 17; //17是ctrl的键码 等号前的ctrl是定义ctrl的别名,可以随便取,实际绑定的就是键盘上的ctrl键模板调用@keydown.ctrl ="自定义方法"

