Vue.js中数据绑定的语法教程
数据绑定语法
vue.js 的模板是基于 dom 实现的。这意味着所有的 vue.js 模板都是可解析的有效的 html,且通过一些特殊的特性做了增强。vue 模板因而从根本上不同于基于字符串的模板,请记住这点。
插值
文本
数据绑定最基础的形式是文本插值,使用 “mustache” 语法(双大括号):
<span>message: {{ msg }}</span>
mustache 标签会被相应数据对象的 msg 属性的值替换。每当这个属性变化时它也会更新。
你也可以只处理单次插值,今后的数据变化就不会再引起插值更新了:
<span>this will never change: {{* msg }}</span>
原始的 html
双 mustache 标签将数据解析为纯文本而不是 html。为了输出真的 html 字符串,需要用三 mustache 标签:
<div>{{{ raw_html }}}</div>
内容以 html 字符串插入——数据绑定将被忽略。如果需要复用模板片断,应当使用partials。
在网站上动态渲染任意 html 是非常危险的,因为容易导致 xss 攻击。记住,只对可信内容使用 html 插值,永不用于用户提交的内容。
html 特性
mustache 标签也可以用在 html 特性 (attributes) 内:
<div id="item-{{ id }}"></div>
注意在 vue.js 指令和特殊特性内不能用插值。不必担心,如果 mustache 标签用错了地方 vue.js 会给出警告。
绑定表达式
放在 mustache 标签内的文本称为绑定表达式。在 vue.js 中,一段绑定表达式由一个简单的 javascript 表达式和可选的一个或多个过滤器构成。
javascript 表达式
到目前为止,我们的模板只绑定到简单的属性键。不过实际上 vue.js 在数据绑定内支持全功能的 javascript 表达式:
{{ number + 1 }} {{ ok ? 'yes' : 'no' }} {{ message.split('').reverse().join('') }}
这些表达式将在所属的 vue 实例的作用域内计算。一个限制是每个绑定只能包含单个表达式,因此下面的语句是无效的:
<!-- 这是一个语句,不是一个表达式: --> {{ var a = 1 }} <!-- 流程控制也不可以,可改用三元表达式 --> {{ if (ok) { return message } }}
过滤器
vue.js 允许在表达式后添加可选的“过滤器 (filter) ”,以“管道符”指示:
{{ message | capitalize }}
这里我们将表达式 message 的值“管输(pipe)”到内置的 capitalize 过滤器,这个过滤器其实只是一个 javascript 函数,返回大写化的值。vue.js 提供数个内置过滤器,在后面我们会谈到如何开发自己的过滤器。
注意管道语法不是 javascript 语法,因此不能在表达式内使用过滤器,只能添加到表达式的后面。
过滤器可以串联:
{{ message | filtera | filterb }}
过滤器也可以接受参数:
{{ message | filtera 'arg1' arg2 }}
过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算。这里,字符串 'arg1' 将传给过滤器作为第二个参数,表达式 arg2 的值在计算出来之后作为第三个参数。
指令
指令 (directives) 是特殊的带有前缀 v- 的特性。指令的值限定为绑定表达式,因此上面提到的 javascript 表达式及过滤器规则在这里也适用。指令的职责就是当其表达式的值改变时把某些特殊的行为应用到 dom 上。我们来回头看下“概述”里的例子:
<p v-if="greeting">hello!</p>
这里 v-if 指令将根据表达式 greeting 值的真假删除/插入 <p> 元素。
参数
有些指令可以在其名称后面带一个“参数” (argument),中间放一个冒号隔开。例如,v-bind 指令用于响应地更新 html 特性:
<a v-bind:href="url" rel="external nofollow" rel="external nofollow" rel="external nofollow" ></a>
这里 href 是参数,它告诉 v-bind 指令将元素的 href 特性跟表达式 url 的值绑定。可能你已注意到可以用特性插值 href="{{url}}" rel="external nofollow"
获得同样的结果:这样没错,并且实际上在内部特性插值会转为 v-bind 绑定。
另一个例子是 v-on 指令,它用于监听 dom 事件:
<a v-on:click="dosomething">
这里参数是被监听的事件的名字。我们也会详细说明事件绑定。
修饰符
修饰符 (modifiers) 是以半角句号 . 开始的特殊后缀,用于表示指令应当以特殊方式绑定。例如 .literal 修饰符告诉指令将它的值解析为一个字面字符串而不是一个表达式:
<a v-bind:href.literal="/a/b/c"></a>
当然,这似乎没有意义,因为我们只需要使用 href="/a/b/c" rel="external nofollow"
而不必使用一个指令。这个例子只是为了演示语法。后面我们将看到修饰符更多的实践用法。
缩写
v- 前缀是一种标识模板中特定的 vue 特性的视觉暗示。当你需要在一些现有的 html 代码中添加动态行为时,这些前缀可以起到很好的区分效果。但你在使用一些常用指令的时候,你会感觉一直这么写实在是啰嗦。而且在构建单页应用(spa )时,vue.js 会管理所有的模板,此时 v- 前缀也没那么重要了。因此vue.js 为两个最常用的指令 v-bind 和v-on 提供特别的缩写:
v-bind 缩写
<!-- 完整语法 --> <a v-bind:href="url" rel="external nofollow" rel="external nofollow" rel="external nofollow" ></a> <!-- 缩写 --> <a :href="url" rel="external nofollow" rel="external nofollow" rel="external nofollow" ></a> <!-- 完整语法 --> <button v-bind:disabled="somedynamiccondition">button</button> <!-- 缩写 --> <button :disabled="somedynamiccondition">button</button>
v-on 缩写
<!-- 完整语法 --> <a v-on:click="dosomething"></a> <!-- 缩写 --> <a @click="dosomething"></a>
它们看起来跟“合法”的 html 有点不同,但是它们在所有 vue.js 支持的浏览器中都能被正确地解析,并且不会出现在最终渲染的标记中。缩写语法完全是可选的,不过随着一步步学习的深入,你会庆幸拥有它们。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
上一篇: asp.net下实现URL重写技术的代码
推荐阅读
-
PHP中数据类型转换的三种方式,数据类型三种方式_PHP教程
-
Symfony2实现在doctrine中内置数据的方法,symfony2doctrine_PHP教程
-
解析Java的Jackson库中对象的序列化与数据泛型绑定
-
为什么无法使用php中mysqli的准备语句进行数据库中数据的查询(绑定参数或者绑定结果),项目急用!该如何处理
-
可视化Swing中JTable控件绑定SQL数据源的两种方法深入解析
-
ASP.NET中DropDownList下拉框列表控件绑定数据的4种方法
-
C#中WPF ListView绑定数据的实例详解
-
可视化Swing中JTable控件绑定SQL数据源的两种方法深入解析
-
总结Visual Studio下ASP.NET模板化控件中的数据绑定
-
Vue模板语法中数据绑定的实例代码