gitHub地址:https://github.com/manlili/vue_learn里面lesson04

一 双括号用来数据绑定

(1)写法一: {{message}},这种可以实时响应

(2)写法二: {{*message}},单次插值,今后的数据变化就不会再引起插值更新了

(3)双括号标签也可以用在属性上

举个栗子:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue插值</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<style type="text/css">
.lili-xiaoman {
color: red;
}
</style>
</head>
<body>
<div class="test">
<p>{{message}}</p> <!--这个值可以实时响应-->
<p>{{*message}}</p> <!--单次插值,今后的数据变化就不会再引起插值更新了,例如在控制台写入:myVue.message=123-->
<p class="lili-{{message}}">双括号标签也可以用在属性上</p>
</div>
<script type="text/javascript">
var myVue = new Vue({
el: ".test",
data: {
message:"xiaoman"
}
})
</script>
</body>
</html>

当我在控制台改变message时,{{*message}}不会跟着改变值

二 双括号里面可以为javascript单元表达式

比如(只支持单元表达式)

{{ number + 1 }}

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

但是不支持

<!-- 这是一个语句,不是一个表达式: -->

{{ var a = 1 }}

<!-- 流程控制也不可以,可改用三元表达式 -->

{{ if (ok) { return message } }}

完整测试代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue双括号里面的内容</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
</head>
<body>
<div class="test">
<p>{{message+1}}</p> <!--JavaScript 表达式,但是只支持单元表达式-->
</div>
<script type="text/javascript">
var myVue = new Vue({
el: ".test",
data: {
message:12
}
}); </script>
</body>
</html>

上面的输出是13

三 双括号可以放过滤器

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue数据绑定</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
</head>
<body>
<div class="test">
<p>{{message | sum}}</p>
</div>
<script type="text/javascript">
Vue.filter("sum", function(value) { //全局方法 Vue.filter() 注册一个自定义过滤器,必须放在Vue实例化前面
return value + 4;
}); var myVue = new Vue({
el: ".test",
data: {
message: 12
}
}); </script>
</body>
</html>

上面代码的输出值是16

四 用指令绑定数据( 指令 是特殊的带有前缀 v- 的特性)

举个v-if的例子:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue数据绑定</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
</head>
<body>
<div class="test">
<p v-if="isShow">isShow控制着我是否显示1</p>
<p v-if="!isShow">isShow控制着我是否显示2</p>
</div>
<script type="text/javascript">
var myVue = new Vue({
el: ".test",
data: {
isShow: true,
}
});
</script>
</body>
</html>

上面只显示第一个div

五 v-bind绑定数据

需要注意事项:

(1) 直接在属性里面写{{}}也是正确的,因为Vue内部渲染的时候会把属性里面的双括号转为v-bind,这样会比直接用v-bind效率效率稍微慢一点

(2) v-bind可简写为 :

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue数据绑定</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
</head>
<body>
<div class="test">
<a href={{url}}>点击我跳到百度首页</a> <!--这种写法没错,实际上在内部特性插值会转为 v-bind 绑定,这样会稍微降低效率-->
<a v-bind:href="url">点击我跳到百度首页</a> <!--简写为:href--> <div style="color: {{colorA}}">我是红色</div> <!--这种写法没错,实际上在内部特性插值会转为 v-bind 绑定,这样会稍微降低效率-->
<div v-bind:style="{color: colorB}">我是绿色</div> <!--简写为:style-->
</div>
<script type="text/javascript">
var myVue = new Vue({
el: ".test",
data: {
url: "https://www.baidu.com/",
colorA: 'red',
colorB: 'green'
}
});
</script>
</body>
</html>

六 v-on绑定数据

(1) v-on是在vue的methods里面实现的

(2) v-on可以简写为 @

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue数据绑定</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
</head>
<body>
<div class="test">
<button v-on:click="goAction()"> <!--可以简写为@click-->
点击我跳到百度
</button>
</div>
<script type="text/javascript">
var myVue = new Vue({
el: ".test",
methods: {
goAction: function () {
location.href = "https://www.baidu.com/";
}
}
});
</script>
</body>
</html>

Vue数据绑定的更多相关文章

  1. 浅析vue数据绑定

    前言:最近团队需要做一个分享,脚进脑子,不知如何分享.最后想着之前一直想研究一下 vue 源码,今天刚好 "借此机会" 研究一下. 网上研究vue数据绑定的文章已经非常多了,但是自 ...

  2. Vue数据绑定和响应式原理

    Vue数据绑定和响应式原理 当实例化一个Vue构造函数,会执行 Vue 的 init 方法,在 init 方法中主要执行三部分内容,一是初始化环境变量,而是处理 Vue 组件数据,三是解析挂载组件.以 ...

  3. 17: VUE数据绑定 与 Object.defineProperty

    VUE数据绑定原理:https://segmentfault.com/a/1190000006599500?utm_source=tag-newest Object.defineProperty(): ...

  4. Vue数据绑定(一)

    Contents Vue作为当下炙手可热的前端三大框架之一,一直都想深入研究一下其内部的实现原理,去学习MVVM模式的精髓.如果说MVVM是当下最流行的图形用户界面开发模式,那么数据绑定则是这一模式的 ...

  5. (三)vue数据绑定及相应的命令

    vue数据绑定及相应的命令 {{ Text }} 双括号进行数据渲染 动态绑定数据 例如:{{message}} data: { return{ message: 'Hello Vue!' } } 2 ...

  6. 「每日一题」有人上次在dy面试,面试官问我:vue数据绑定的实现原理。你说我该如何回答?

    关注「松宝写代码」,精选好文,每日一题 ​时间永远是自己的 每分每秒也都是为自己的将来铺垫和增值 作者:saucxs | songEagle 来源:原创 一.前言 文章首发在「松宝写代码」 2020. ...

  7. vue数据绑定原理

    一.定义 vue的数据双向绑定是基于Object.defineProperty方法,通过定义data属性的get和set函数来监听数据对象的变化,一旦变化,vue利用发布订阅模式,通知订阅者执行回调函 ...

  8. vue 数据绑定实现的核心 Object.defineProperty()

    vue深入响应式原理 现在是时候深入一下了!Vue 最独特的特性之一,是其非侵入性的响应式系统.数据模型仅仅是普通的 JavaScript 对象.而当你修改它们时,视图会进行更新.这使得状态管理非常简 ...

  9. vue数据绑定数组,改变元素时不更新view问题

    关于这个问题,官网上说的很清楚官方文档  写个例子HTML<body> <div class="box"> <div v-for="aa i ...

随机推荐

  1. BaaS服务的定义、发展以及未来

    BaaS(Backend as a Service)是一种新型的云服务,旨在为移动和Web应用提供后端云服务,包括云端数据/文件存储.账户管理.消息推送.社交媒体整合等.BaaS是垂直领域的云服务,随 ...

  2. MVC学习中遇到问题

    1:无法连接到localdb数据库 解决方案:下载localdb安装软件 2:运行程序时提示数据库已存在,请更改连接名 解决方案:因为在两个不同的解决方案中使用了同样的连接字符串造成生成了同样的数据库 ...

  3. 利用SSIS发送邮件

    璎Nicole珞 博客园 闪存 首页 新随笔 联系 管理 订阅 随笔- 15  文章- 0  评论- 0  SSIS 利用发送邮件服务 Send Email Task   1. 在SSIS中如何发送邮 ...

  4. Android UI开发第四十一篇——墨迹天气3.0引导界面及动画实现

    周末升级了墨迹天气,看着引导界面做的不错,模仿一下,可能与原作者的代码实现不一样,但是实现的效果还是差不多的.先分享一篇以前的文章,android动画的基础知识,<Android UI开发第十二 ...

  5. WCF学习日记

    图书馆借阅了<WCF高级编程>,从6.11开始学习wcf,希望尽快熟悉原理和编程模型以及常用编程方法.     WCF是一个平台,也是一个框架,从Net.3.0 就在Net framewo ...

  6. REHL5.5 linux的postfix的邮件服务器配置 (笔记)

    一.发送邮件服务器(smtp服务器) 1.系统安装时已经有postfix. 2.修改配置 1)vi main.cf //你可以先备份一下配置文件 myhostname = INMSC2//修改为你的主 ...

  7. mongodb 监控分析命令

    1. bin/mongostate 2.开启慢查询用于调试 正式要关闭 可以在客户端调用db.setProfilingLevel(级别) 命令来实时配置.可以通过db.getProfilingLeve ...

  8. So Easy!让开发人员更轻松的工具和资源

    这篇文章给大家分享让开发人员生活更轻松的免费工具和资源.所以,如果你正在寻找一些为迅速解决每天碰到的设计和开发问题的工具和资源,不要再观望,试试这些工具吧.这些奇妙的工具不仅会加快您的生产,也让你的工 ...

  9. IOS开发UI基础UIImageView属性属性

    UIImageView属性 1.Image 设置图片,默认显示 UIImageView *_imageView = [[UIImageView alloc]init]; _imageView.imag ...

  10. Web 前端颜色值--字体--使用,整理整理

    做网页时经常挑选不好颜色吧...多看看颜色值,或者自己配吧.... 颜色值 CSS 颜色使用组合了红绿蓝颜色值 (RGB) 的十六进制 (hex) 表示法进行定义.对光源进行设置的最低值可以是 0(十 ...