Vue学习日记--捌

组件生命周期

beforeCreated:在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。

created:在实例创建完成后被立即调用。在这一步,实例已完成以下的配置:数据观测 (data observer),property 和方法的运算,watch/event 事件回调。(挂载阶段还没开始,$el property尚不可用。)

beforeMount:在挂载开始之前被调用:相关的 render 函数首次被调用。该钩子在服务器端渲染期间不被调用。

mounted:实例被挂载后调用,这时 el 被新创建的 vm.$el 替换了。如果根实例挂载到了一个文档内的元素上,当 mounted 被调用时 vm.$el 也在文档内。mounted 不会保证所有的子组件也都一起被挂载。如果你希望等到整个视图都渲染完毕,可以在 mounted 内部使用 vm.$nextTick:

mounted: function () {
    
    
  this.$nextTick(function () {
    
    
    // Code that will run only after the
    // entire view has been rendered
  })
}

beforeUpdate:数据更新时调用,发生在虚拟 DOM 打补丁之前。这里适合在更新之前访问现有的 DOM,比如手动移除已添加的事件监听器。

updated:由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。

activated:被 keep-alive 缓存的组件激活时调用。该钩子在服务器端渲染期间不被调用。

deactivated:被 keep-alive 缓存的组件停用时调用。该钩子在服务器端渲染期间不被调用。
构建组件 - keep-alive: 能在组件的切换过程中将状态保存到内存中,防止重复渲染DOM

beforeDestroy: 实例销毁之前调用。在这一步,实例仍然完全可用。该钩子在服务器端渲染期间不被调用。

destroyed:实例销毁后调用。该钩子被调用后,对应 Vue 实例的所有指令都被解绑,所有的事件监听器被移除,所有的子实例也都被销毁。该钩子在服务器端渲染期间不被调用。

Vue.component('Test',{
    
    
            data:function(){
    
    
                return{
    
    
                    msg:"hello world"
                }
            },
            template:'<div>' +
            '<div>{
    
    {msg}}</div>' +
            '<button @click="changeHandler">改变</button>' +
            '</div>',
            methods:{
    
    
                changeHandler:function(){
    
    
                    this.msg=this.msg+"Hi,Vincent";
                }
            },
            beforeCreate:function(){
    
    
//                  组件创建之前
                console.log(this.msg);//undefine
        },
            created:function(){
    
    
//                组件创建
                console.log(this.msg);
//                使用该组件,就会调用created
//                在created这个方法中可以操作后端的数据 数据驱动视图
//                应用:发送ajax请求
            },
            beforeMount: function () {
    
    
            //挂在数据到DOM之前会调用
                console.log(document.getElementById('app'));
            },
            mounted: function () {
    
    
                //挂在数据到DOM之后会调用Vue作用后的DOM
                console.log(document.getElementById('app'));
            },
            beforeUpdate: function () {
    
    
//                在更新DOM之前 调用该钩子,应用:可以获取原始的DOM
                console.log(document.getElementById('app').innerHTML);
            },
            updated:function(){
    
    
//                在更新DOM之后 调用该钩子,应用:可以获取最新的DOM
                console.log(document.getElementById('app').innerHTML);
            },
            beforeDestroy:function(){
    
    
              console.log('beforeDestroy');
            },
            destroyed: function () {
    
    
                console.log('destroyed');
            },
            activated:function(){
    
    
                console.log('activated');
            },
            deactivated: function () {
    
    
                console.log('deactivated');
            }
        });

	        var App={
    
    
            data: function () {
    
    
                return{
    
    
                    isShow:true
                }
            },
//            vue内置组件<keep-alive>
//            能在组件的切换过程中将状态保存到内存中,防止重复渲染DOM
            template:'<div class="app">' +
            '<keep-alive>' +
            '<Test v-if="isShow"/>' +
            '</keep-alive>' +
            '<button @click="isShow=!isShow">改变生死</button>' +
            '</div>'
        };

猜你喜欢

转载自blog.csdn.net/weixin_41481695/article/details/106244996