1.实例生命周期钩子
之前学习了创建Vue实例以及数据与方法,本次我将接着上次来学习,本次我学习的内容是实例生命周期钩子。概念:每个 Vue 实例在被创建时都要经过一系列的初始化过程,例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会。示例:比如 created[类型:Function,
详细:在实例创建完成后被立即调用。在这一步,实例已完成以下的配置:数据观测 (data observer),property 和方法的运算,watch/event 事件回调。然而,挂载阶段还没开始,$el property 目前尚不可用
]钩子可以用来在一个实例被创建之后执行代码:
new Vue({ data: { a: 1 }, created: function () { // `this` 指向 vm 实例 console.log('a is: ' + this.a) }})// => "a is: 1" |
也有一些其它的钩子,在实例生命周期的不同阶段被调用,如 mounted、updated 和 destroyed。生命周期钩子的 this 上下文指向调用它的 Vue 实例。不要在选项 property 或回调上使用箭头函数,比如 created: () => console.log(this.a) 或vm.$watch('a', newValue => this.myMethod())。因为箭头函数并没有 this,this 会作为变量一直向上级词法作用域查找,直至找到为止,经常导致 Uncaught TypeError: Cannot read property of undefined 或 Uncaught TypeError: this.myMethod is not a function 之类的错误。个人理解:生命周期钩子函数,给了用户在不同阶段添加自己的代码的机会,也就是说中有实例被创建时就已经存在于 data 中的 property才可以通过数据与方法来改变值( 响应式)。不能直接添加,而现在我们通过生命周期钩子函数,给了用户在不同阶段添加自己的代码的机会。2模块语法插值1 文本数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插值:
<span>Message: {{ msg }}</span> |
标签将会被替代为对应数据对象上 msg property 的值。无论何时,绑定的数据对象上 msg property 发生了改变,插值处的内容都会更新。通过使用 v-once 指令,你也能执行一次性地插值,当数据改变时,插值处的内容不会更新。但请留心这会影响到该节点上的其它数据绑定:
<spanv-once>这个将不会改变: {{ msg }}</span> |
数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插,值绑定的数据对象上 msg property 发生了改变,插值处的内容都会更新(我认为可以理解为单方向响应式,一个随着另一个改变)。如果加上v-once 指令,就是执行一次性地插值,这样一来,插值一次之后msg property再改变对之前插值没有有影响,始终不变。2 原始HTML双大括号会将数据解释为普通文本,而非HTML 代码。为了输出真正的 HTML,你需要使用v-html 指令:
<p>Using mustaches: {{ rawHtml }}</p><p>Using v-html directive: <span v-html="rawHtml"></span></p> |
这个 span 的内容将会被替换成为 property 值 rawHtml,直接作为 HTML——会忽略解析 property 值中的数据绑定。注意,你不能使用 v-html 来复合局部模板,因为 Vue 不是基于字符串的模板引擎。反之,对于用户界面 (UI),组件更适合作为可重用和可组合的基本单位。本次就简单介绍到这里,由于时间比较仓促,学习不够深入,并且本文是参考vue官网上的介绍加上一些自己的理解完成的,如理解有误还请指教。