vue.js模板语法

一、插值

1.文本

数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插值:

<span>Message: {{ msg }}</span>
data:{
    msg:'显示'
}

无论何时,绑定的数据对象上 msg 属性发生了改变,插值处的内容都会更新。
v-once 指令
执行一次性地插值,当数据改变时,插值处的内容不会更新。但请留心这会影响到该节点上的其它数据绑定:

<span v-once>这个将不会改变: {{ msg }}</span>

2.原始 HTML

双大括号会将数据解释为普通文本,而非 HTML 代码。为了输出真正的 HTML,你需要使用 v-html 指令:

//使用v-html会将语句解释成HTML语言
<p>Using mustaches: {{ rawHtml }}</p>
<p>Using v-html directive: <span v-html="rawHtml"></span></p>

3.特性

Mustache (双大括号)语法不能作用在 HTML 特性上,遇到这种情况应该使用 v-bind 指令:

v-bind:只能用于属性,他的值是一个 JavaScript 表达式,和 {{ }} 里面的语法一致,
唯一的区别就是:{{ }}用于标签文本绑定,v-bind 用于标签属性绑定。
<button v-bind:disabled="isButtonDisabled">Button</button>
<a v-bind:href="foo">{{ foo }}</a>//两个foo的值都是www.baidu.com
data:{
    foo:'www.baidu.com'
}

如果 isButtonDisabled 的值是 null、undefined 或 false,则 disabled 特性甚至不会被包含在渲染出来的button元素中。

4.使用 JavaScript 表达式

迄今为止,在我们的模板中,我们一直都只绑定简单的属性键值。但实际上,对于所有的数据绑定,Vue.js 都提供了完全的 JavaScript 表达式支持。

{{ number + 1 }}

{{ ok ? 'YES' : 'NO' }}

{{ message.split('').reverse().join('') }}

<div v-bind:id="'list-' + id"></div>

这些表达式会在所属 Vue 实例的数据作用域下作为 JavaScript 被解析。有个限制就是,每个绑定都只能包含单个表达式,所以下面的例子都不会生效。

<!-- 这是语句,不是表达式 -->
{{ var a = 1 }}

<!-- 流控制也不会生效,请使用三元表达式 -->
{{ if (ok) { return message } }}
模板表达式都被放在沙盒中,只能访问全局变量的一个白名单,如 Math 和 Date 。
你不应该在模板表达式中试图访问用户定义的全局变量。

猜你喜欢

转载自blog.csdn.net/ooo123lll/article/details/80245316