一、自定义指令的创建和使用
Vue自带的指令很多,v-for/v-if/v-else/v-else-if/v-model/v-bind/v-on/v-show/v-html/v-text...
但是这些指令都是比较偏向于工具化,有些时候在实现具体的业务逻辑的时候,发现不够用,如何来自定义指令。
①注册自定义指令
new Vue({
directives: { //注册指令,类似于注册组件
change: { //定义名为change的指令
bind: function () {},
update: function () {},
unbind: function () {}
}
}
})
在自定义指令时,在指令对应的配置对象中有3个处理函数指令对应的操作
bind:指令在绑定到元素要执行的操作,只调用一次
update:如果在调用指令时候,传了参数,当参数变化时候,就会执行update所指定的方法
unbind:解绑要执行的操作
②使用自定义指令
v-change
注意事项:
建议在给指令的命名采用小驼峰式的命名方式,比如changeBackgroundColor,在使用的时候,采用烤串式写法 v-change-background-color
练习:实现自定义指令v-time,在微博朋友圈中常见的将用户发布某些内容的时间改为“刚刚”,“XX分钟前”等。
时间转换逻辑:
1分钟以前:显示“刚刚”
1分钟-1小时之间:显示“XX分钟前”
1小时-1天之间:显示“XX小时前”
1天-1个月(31天)之间,显示“XX天前”
大于1个月,显示“XX年XX月XX日”
二、自定义过滤器的创建和使用
vue支持在{{}}插值的尾部添加一个管道符“|”对数据进行过滤,经常用于格式化文本比如字母大小写,货币千位使用逗号分隔等等。
过滤器的作用:实现数据的筛选、过滤、格式化。
vue1.版本是有内置的过滤器,但是在vue2.所有的版本都已经没有自带的过滤器了。
1、过滤器创建
过滤器的本质是一个有参数有返回值的方法。
export default {
data() {
return {
price:500,
};
},
filters: {
myCurrency: function (myInput) {
return myInput+100; //返回处理后的数据
}
}
};
2、过滤器使用
<any>{{price | myCurrency}}</any>
3、过滤器高级用法
在使用过滤器的时候,还可以指定参数,来告诉过滤器按照参数进行数据的过滤。
①如何给过滤器传参?
<h1>{{price | myCurrency('¥',true)}}</h1>
②如何在过滤器中接收到?
export default {
data() {
return {};
},
filters: {
//myInput是通过管道传来的数据
//arg1在调用过滤器时在圆括号中第一个参数
//arg2在调用过滤器时在圆括号中第二个参数
myCurrency: function (myInput, arg1, arg2) {
return 处理后的数据;
}
}
};
常用过滤器链接 https://blog.csdn.net/dylan_zeng92/article/details/77850143
三、组件
w3c为什么有组件概念?
现在的前端领域,对于代码的质量和数量有着非常高的要求,特别容易出问题。
通过组件的方式来完成代码的管理和编写。
组件:是一个可以被反复使用的 带有指定功能的 视图
组件化编程 一切都是组件component,把可以被反复使用的任何的视图 都可以封装成组件
组件化的好处(封装):
①提高了代码的复用率
②提高开发速度
③降低测试难度
④降低整个应用的耦合度
1、组件的创建
组件需要注册以后才可以使用,注册分为全局注册和局部注册,全局注册,任何Vue实例都可以使用。
Vue.component('my-component', {//全局注册
template: '<h1>it is a component</h1>'
})
export default {//局部注册
data() {
return {
};
},
components: {
'my-component':myComponent
},
};
2、组件的使用
组件的使用就像是使用普通的html标签一样
<my-component> </my-component>
建议:组件的命名和使用建议来使用烤串式命名规则。
(如果组件的名字写成驼峰式 myComponent,使用依然还得是烤串式)
注意:
①如果一个组件要渲染多个元素,将多个元素放到一个顶层标签;否则会报错。
3、复合组件
组件可以像vue实例那样使用其他选项,比如data,computed,methods,只是在使用data时和实例稍有区别,这里的data必须是函数,然后将数据return出去。
组件可以像html一样来使用,复合组件并不是一个新的概念,就是一个组件,只不过该组件中又调用了其它的组件。
一个完整的Vue的项目,可以比作是一颗组件树,组件树的根 就是 根组件(my-article)....
组件树可以帮助我们降低业务的复杂度,避免出现一些错误,提高开发速度。
4、组件的生命周期
分为4个阶段:create/mount/update/destroy
,每一个阶段都对应着有自己的处理函数。
create: beforeCreate created 初始化
mount: beforeMount mounted 和挂载相关的处理
update: beforeUpdate updated 根据要更新的数据 做逻辑判断
destroy:beforeDestroy destroyed 清理工作
在Vue的实例或者在组件,都有哪些属性?
el
data
methods
directives
filters
watch