双花括号文本插值

先来个最简单的例子,看完之后立马会用Vue了,是不是很有成就感

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<!-- 引用官网的Vue.js库 -->
<script src="https://unpkg.com/vue"></script>
</head>
<body>
<!-- HTML部分 -->
<div id="app-1">
<!-- “mustache” 语法(双花括号)的文本插值 -->
<span>{{ content }}</span>
</div>
<!-- JS部分 -->
<script type="text/javascript">
var vm1 = new Vue({
el: '#app-1', //关联元素
data: {
content: 'Hello, TanSea!' //变量赋值
}
})
</script>
</body>
</html>

https://unpkg.com/vue是官方的地址,直接引用能随时保持使用的是最新版本,但是缺点是外国的网站,访问速度有点慢。当然也可以下载到本地来使用

这里Vue对象实例化仅仅给了2个参数,el(元素)和data(数据),其他的参数在后面的笔记中会说明

在浏览器的控制台输入vm1.content = 'Hello, World',对变量进行重新赋值,页面上的值也跟着一起变更。如果只需要第一次绑定,不要后续变更,可以使用v-once指令

给span标签添加v-once指令

<!-- HTML部分 -->
<div id="app-1">
<!-- 当变量发生变更时,内容不会随着更新 -->
<span v-once>{{ content }}</span>
</div>

Vue的所有指令约定都是以v-开头,包括之后的自定义指令也推荐使用这种命名习惯

原始HTML

<!-- HTML部分 -->
<div id="app-2">
<span v-html="rawHtml"></span>
</div>
<!-- JS部分 -->
<script type="text/javascript">
var vm2 = new Vue({
el: '#app-2',
data: {
rawHtml: '<div style="color: red">Hello, TanSea!</div>'
}
})
</script>

v-html指令直接插入原始HTML,直接插入HTML代码容易受到XSS攻击,不建议使用

属性

在HTML属性中无法使用“mustache” 语法了,需要使用v-bind指令,这也是Vue使用得最多的指令

<!-- HTML部分 -->
<div id="app-3">
<a v-bind:href="url" v-bind:target="target">双子宫殿</a>
</div>
<!-- JS部分 -->
<script type="text/javascript">
var vm3 = new Vue({
el: '#app-3',
data: {
url: 'http://www.tansea.cn',
target: '_blank'
}
})
</script>

使用v-bind指令绑定HTML属性,给HTML属性插值

JavaScript表达式

<!-- HTML部分 -->
<div id="app-4">
<span :id="'site-' + (id + 1)">{{ isVisible ? '我是可见的' : '我是隐藏的' }}</span>
</div>
<!-- JS部分 -->
<script type="text/javascript">
var vm4 = new Vue({
el: '#app-4',
data: {
id: 1,
isVisible: true
}
})
</script>

这里,我们看到了一个陌生的东西:id,他其实就是v-bind:id的简写方式

通过表达式的计算,span标签最终的结果是

<span id="site-2">我是可见的</span>

Vue目前只支持单条表达式,所以以下的示例都无法运行

<!-- 这是语句,不是表达式 -->
{{ var a = 1 }}
<!-- 流控制也无法运行,请使用三元表达式 -->
{{ if (ok) { return message } }}

如果熟悉拉姆达表达式的话,这一块的内容就很好理解了

双向绑定

双向绑定是Vue的一个最主要的功能,他能很方便的实现实时预览的效果

<!-- HTML部分 -->
<div id="app-5">
<p>{{ content }}</p>
<input v-model:value="content">
</div>
<!-- JS部分 -->
<script type="text/javascript">
var vm5 = new Vue({
el: '#app-5',
data: {
content: 'TanSea'
}
})
</script>

将input标签的值属性双向绑定到content上,当input标签的值属性发生改变时,p标签也会同步发生改变

Vue.js学习笔记 第一篇 数据绑定的更多相关文章

  1. vue.js学习系列-第一篇

    VUE系列一 简介    vue是一个兴起的前端js库,是一个精简的MVVM.从技术角度讲,Vue.js专注于 MVVM 模型的 ViewModel 层.它通过双向数据绑定把 View 层和 Mode ...

  2. vue.js学习系列-第一篇(代码)

    <html> <head> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"> ...

  3. Vue.js学习笔记 第二篇 样式绑定

    Class绑定的对象语法 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  4. Vue.js学习笔记(2)vue-router

    vue中vue-router的使用:

  5. ActionBarSherlock学习笔记 第一篇——部署

    ActionBarSherlock学习笔记 第一篇--部署          ActionBarSherlock是JakeWharton编写的一个开源框架,使用这个框架,可以实现在所有的Android ...

  6. vue.js 学习笔记3——TypeScript

    目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...

  7. Vue.js学习笔记:在元素 和 template 中使用 v-if 指令

    f 指令 语法比较简单,直接上代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" " ...

  8. Vue.js 学习笔记 第2章 数据绑定和第一个Vue应用

    本篇目录: 2.1 Vue实例与数据绑定 2.2 指令与事件 2.3 语法糖 学习任何一种框架,从一个Hello World应用开始是最快了解该框架特性的途径. 我们先从一段简单的HTML代码开始,感 ...

  9. Vue.js——学习笔记

    Vue-自学笔记 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层,不仅 ...

随机推荐

  1. libsvm以概率输出单个test样例的判别结果

    在函数svmtrain和svmpredict的输入参数部分加入'-b 1'比如原先是 svmtrain -c 8.0 -g 0.0078125 a1a.scale 修改过后就是 svmtrain -b ...

  2. scikit-learn:3.4. Model persistence

    參考:http://scikit-learn.org/stable/modules/model_persistence.html 训练了模型之后,我们希望能够保存下来,遇到新样本时直接使用已经训练好的 ...

  3. LINQ 标准查询操作符

    本文介绍了LINQ标准查询操作符.没有这些操作符,LINQ就不会存在.本文为理解这些操作符的功能提供了很好的基础.了解它们将会很有帮助,因为LINQ的各种Provider都是基于这些操作符来完成各自丰 ...

  4. Python_selenium之执行JavaScript

    Python_selenium之执行JavaScript 一.简略的介绍selenium执行JavaScript 1. Example 1进入浏览器之后,弹出一个alert弹框 #coding:utf ...

  5. Apache Nifi 开发

    Apache NiFi是由美国过国家安全局(NSA)贡献给Apache基金会的开源项目.其设计目标是自己主动化系统间的数据流.基于其工作流式的编程理念.NiFi很易于使用,强大.可靠及高可配置. 两个 ...

  6. Android Studio中debug和release模式默认的参数配置

    The possible properties and their default values are: debuggable:表示是否可以在手机上调试程序. 在Eclipse中,只有android ...

  7. Uva12663

    题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=110383#problem/C 题目大意:有一些不同高度的桥,会涨几次水,水流初 ...

  8. EasyNVR现场部署搭配EasyNVS云端集中控制应用于幼儿园直播场景的最佳方案!

    在之前的介绍中,我们已经介绍了很多EasyNVR成功应用于幼儿园类教育直播的场景,例如<EasyDarwin幼教云视频平台在幼教平台领域大放异彩!>.<基于EasyDarwin云视频 ...

  9. git的安装-环境变量配置

    windows安装git和环境变量配置 2015.10.12 评论(0) 10,729 点此嗨一下 Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git是一个开源 ...

  10. 洛谷 P2261 [CQOI2007]余数求和

    洛谷 一看就知道是一个数学题.嘿嘿- 讲讲各种分的做法吧. 30分做法:不知道,这大概是这题的难点吧! 60分做法: 一是直接暴力,看下代码吧- #include <bits/stdc++.h& ...