前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端|Vue实例与模板语法

前端|Vue实例与模板语法

作者头像
算法与编程之美
发布2020-09-08 17:09:50
6540
发布2020-09-08 17:09:50
举报
文章被收录于专栏:算法与编程之美

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官网上的介绍加上一些自己的理解完成的,如理解有误还请指教。

END

主 编 | 张祯悦

责 编 | 舒寒同行JT

where2go 团队


本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-08-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 算法与编程之美 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档