0
点赞
收藏
分享

微信扫一扫

Vue2.0介绍(二)

一天清晨 2022-03-24 阅读 86
vue.js

一、生命周期

将要创建 ===>  调用beforeCreate函数
创建完毕 ===> 调用created函数
将要挂载 ===>调用beforeMount函数
挂载完毕 ===> 调用mounted函数(重要钩子) 
将要更新 ===> 调用beforeUpdate函数
更新完毕 ===> 调用updated函数 
将要销毁 ===> 调用beforeDestroy函数(重要钩子)
销毁完毕 ===>调用destroyed函数

在这里插入图片描述

二、Vue组件化编程

1.模块

	理解:向外提供特定功能的js程序,一般就是一个js文件。
  	作用:复用js,简化js的编写,提高js运行效率。

2.组件

	理解:用来实现局部(特定)功能效果的代码集合(html\css\js\image\...)
	作用:复用编码,简化项目编码,提高运行效率。

3.模块化

	当应用中的js都以模块来编写的,那这个应用就是一个模块化的应用。

4.组件化

	当应用中的功能都是多组件的方式来编写的,那这个应用就是一个组件化的应用。

三、关于不同版本的Vue

vue.js与vue.runtime.xxx.js的区别

   (1)vue.js是完整版的Vue,包含:核心功能+模板解析器。
   (2)vue.runtime.xxx.js是运行版的Vue,只包含:核心功能,没有模板解析器。
   	因为vue.runtime.xxx.js没有模板解析器,所以不能使用template配置项,需要使用render函数接收到的createElement函数去指定具体内容。

四、ref属性

1.被用来给元素或子组件注册引用信息(id的替代者)
2.应用在html标签上获取的是真实DOM元素,应用在组件标签上是组件实例对象(VueComponent)。
3.使用方式
        打标识:<Dome ref="xxx"></Dome>
        获取:this.$refs.xxx

五、props配置项

功能:让组件接收外部传过来的数据。

六、mixin(混入)

功能:可以把多个组件公用的配置提取成一个混入对象。

七、插件

功能:用于增强Vue

八、scoped样式

作用:让样式在局部生效,防止冲突。

九、webStorage

十、组件的自定义事件

1.一种组件间通信的方式,适用于:子组件 ===> 父组件。
2.使用场景:A是父组件,B是子组件,B想给A传数据,那么就要在A中给B绑定自定义事件(事件的回调在A中)。
3.绑定自定义事件:
第一种方式:在父组件中:<Demo @dhlsp="test"/><Demo dhlsp="test"/>
第二种方式:在父组件中:

<Demo ref="xxx"/>
......
mounted() {
	this.$refs.xxx.$on('dhlsp',this.test);
}

若想让自定义事件只能触发一次,可以使用once修饰符,或$once方法。
4.触发自定义事件:this.$emit('test',data)
5.解绑自定义事件:this.$off('test')
6.组件上也可以绑定原生DOM事件,需要使用native修饰符。
7.注意:通过this.$refs.xxx.$on('test',回调)绑定自定义事件时,回调要么配置在methods中,要么用箭头函数,否则this指向会指向Windows。

十一、全局事件总线(GlobalEventBus)

1.一种组件间通信的方式,适用于任意组件间通信。
2.安装全局事件总线:

new Vue({
	......
	beforeCreate() {
		Vue.prototype.$bus = this // 安装全局事件总线,$bus就是当前应用的Vue实例对象
	}
	......
})

3.使用事件总线:

4.最好在beforeDestroy钩子中,用$off去解绑当前组件所用到的事件。

十二、消息订阅与发布(pubsub)

1.一种组件间通信的方式,适用于任意组件间通信。
2.使用步骤:

4.提供数据:pubsub.publish('xxx',data)
5.最好在beforeDestroy钩子中,用pubsub.unsubscribe(pid)去取消订阅。

十三、nextTick

1.语法:this.$nextTick(回调函数)
2.作用:在下一次DOM更新结束后执行其指定的回调。
3.什么时候用:当改变数据后,要基于更新后的新DOM进行某些操作时,要在nextTick所指定的回调函数中执行。

举报

相关推荐

0 条评论