Vue.js学习笔记 第一篇 数据绑定
双花括号文本插值
先来个最简单的例子,看完之后立马会用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学习笔记 第一篇 数据绑定的更多相关文章
- vue.js学习系列-第一篇
VUE系列一 简介 vue是一个兴起的前端js库,是一个精简的MVVM.从技术角度讲,Vue.js专注于 MVVM 模型的 ViewModel 层.它通过双向数据绑定把 View 层和 Mode ...
- vue.js学习系列-第一篇(代码)
<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"> ...
- Vue.js学习笔记 第二篇 样式绑定
Class绑定的对象语法 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
- Vue.js学习笔记(2)vue-router
vue中vue-router的使用:
- ActionBarSherlock学习笔记 第一篇——部署
ActionBarSherlock学习笔记 第一篇--部署 ActionBarSherlock是JakeWharton编写的一个开源框架,使用这个框架,可以实现在所有的Android ...
- vue.js 学习笔记3——TypeScript
目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...
- Vue.js学习笔记:在元素 和 template 中使用 v-if 指令
f 指令 语法比较简单,直接上代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" " ...
- Vue.js 学习笔记 第2章 数据绑定和第一个Vue应用
本篇目录: 2.1 Vue实例与数据绑定 2.2 指令与事件 2.3 语法糖 学习任何一种框架,从一个Hello World应用开始是最快了解该框架特性的途径. 我们先从一段简单的HTML代码开始,感 ...
- Vue.js——学习笔记
Vue-自学笔记 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层,不仅 ...
随机推荐
- WPF绑定Binding及模式
绑定,就是把一个对象属性的值绑定在别的对象的属性上 1. 默认绑定 public class Company { public string Name { get; set; } } XAML代码 1 ...
- day8笔记
一.上节回顾 1,id() 内存地址2, == 比较的是值 is 比较的是内存地址 数字,字符串,有小数据池, #内存地址一样的 int -5--256 str:1,不能有空格. 2,长度不能超过20 ...
- 制作dos启动u盘
需要准备的工具: 空U盘的U盘HP优盘启动盘格式化工具 链接:https://pan.baidu.com/s/1i59wgUp 密码:l5ke 1.1插入U盘,打开 HP优盘启动盘格式化工具 1. ...
- JAVA学习第六十三课 — 关于client服务端 && URL类 & URLConnection
常见的client和服务端 client: 浏览器:IE:弹窗体,猎豹:弹窗体.多标签,争强效果 服务端: server:TomCat:1.处理请求 2.给予应答 想让TomC ...
- Flow Problem(最大流模板)
Flow Problem Time Limit: 5000/5000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Tota ...
- 【RSS】我的RSS使用介绍
早就想写一个有关RSS的文章,一直没时间,今天刚好被现DL说了一波,那就先整理出一篇教程吧.后续说不定还有分享: 分享相关PPT: 一.我使用的服务: Feedly:https://feedly.co ...
- view {display:block}
view {display:block}
- $(document).ready() $(window).load 及js的window.onload
1.$(document).ready() 简写为$(function(){}) DOM结构绘制完成执行,而无需等到图片或其他媒体下载完毕. 2.$(window).load 在有时候确实我们有需 ...
- 使用Sentry集中化日志管理
在调试程序中,通过日志分期来排查BUG是一个重要手段,它可以说是程序调试的利器. 关于日志管理 随着应用组件变多,那么各coder对输出日志五花八门,有写入stdout,有写stderr, 有写到sy ...
- Model的save方法的使用
在使用类方法创建对象的时候发生save()总提示缺少self参数的错误: class BookInfo(models.Model): #创建书本信息类,继承models.Model booktitle ...