01.vue数据绑定
Vue特点
渐进式: 渐进, 可以理解成一步一步的. 在使用Vue的时候, 我们不需要把整个Vue框架的东西都用上, 可以一步一步的根据需要慢慢的替换之前的代码。
自底向上逐层应用: 由底层开始, 把基础的东西先写好, 逐层往上增加新的或者复杂的功能。
MVVM设计模式: Model(模型)-View(视图)-VM(视图模型), 这是一种基于前端开发的架构模式,其核心是
提供View和Model的双向数据绑定, 这里的Model状态能直接影响View而View的变化在某些情况下也能影响Model。
声明式渲染: Vue允许我们用简洁的语法将数据与DOM绑定在一起。
数据绑定
1. 值绑定
1.1 插值表达式
{{}}(mustache 大胡子语法),{{}}里面是Vue的编译环境,里面可以填data里的变量,表达式,函数调用。
1 <div id="app">
2 <p>{{message}}</p>
3 <p>{{1<2?true:false}}</p>
4 <p>{{sumFunc(1,2)}}</p>
5 </div>
1 let app = new Vue({
2 //el字段,用来挂载dom元素,指定Vue实例的作用域
3 el: '#app',
4 //data字段,指定Vue实例的数据源
5 data: {
6 message: 'Hello Vue!',
7 sumFunc(a, b) {
8 return a + b;
9 }
10 }
11 });

1.2 v-text或者v-html指令
二者区别:
当数据里有html字符串时,v-html能直接解析,而v-text和{{}}会原样输出。
注意:vue指令中的""(双引号)里面也是Vue的编译环境,想直接写字符串的话要用单引号''。
1 <div id="app">
2 <p v-html="msg"></p>
3 <p v-text="msg"></p>
4 <p>{{msg}}</p>
5 </div>
let app = new Vue({
el: '#app',
data: {
msg: '这是a链接:<a href="http://www.baidu.com">点击跳转至百度首页</a>',
},
});
2.属性绑定
语法:v-bind:属性名=""
简写模式(语法糖)::属性名=""
动态绑定style属性:
语法::style="数组/对象(常用)/行间样式字符串"
动态绑定class属性:
语法::class="数组/对象"
1 .p_style {
2 color: #ffffff;
3 background-color: red;
4 }
1 <div id="app">
2 <p v-bind:title="msg">v-bind</p>
3 <p :title="msg">v-bind</p>
4
5 <div :style="divStyle1"></div>
6 <div :style="divStyle2"></div>
7 <div :style="divStyle3"></div>
8
9 <p :class="className">这是段落1标签</p>
10 <p :class="{p_style:true}">这是段落2标签</p>
11 <p :class="{p_style:isAddClass}">这是段落3标签</p>
12 </div>
1 let app = new Vue({
2 el: '#app',
3 data: {
4 msg: '鼠标悬停几秒钟查看此处动态绑定的提示信息!',
5 divStyle1: {width: '500px', height: '15px', background: 'red'},
6 divStyle2: [{width: '500px'}, {height: '15px', background: 'green'}],
7 divStyle3: "width: 500px;height: 15px; background: blue",
8 className: {p_style: true},
9 isAddClass: true,
10 },
11 });

3.事件绑定
语法:
v-on:事件名="函数名/函数名()/简单的语句"
语法糖:
@事件名="函数名/函数名()/简单的语句"
注意:
a. 绑定函数时,函数名后的小括号可加可不加,取决于是否需要传递参数,如果需要传参,必须加小括号。
b. 绑定函数时,没加小括号,系统默认第一个形参为事件对象。
c. 绑定函数时,加了小括号,需要通过传入$event获取事件对象。
d. 事件函数里可以直接同过this.变量名获取data里的数据源变量。
1 <div id="app">
2 <button v-on:click="btnClick1">按钮1,无参</button>
3 <button v-on:click="btnClick2(1,msg,'abc')">按钮2,有参</button>
4 <button @click="btnClick3">无小括号获取事件对象</button>
5 <button @click="btnClick4(1,2,$event)">有小括号获取事件对象</button>
6 <button @click="changeData">点击修改data数据源</button>
7 </div>
1 let app = new Vue({
2 el: '#app',
3 data: {
4 msg: 'Hello World!',
5 },
6 //事件对应的触发函数,写到methods字段里
7 methods: {
8 btnClick1() {
9 console.log('按钮1被点击了!');
10 },
11 btnClick2(a, b, c) {
12 console.log(a, b, c);//1,"Hello World!","abc"
13 },
14 btnClick3(e) {
15 console.log(e);//event
16 },
17 btnClick4(a, b, c) {
18 console.log(a, b, c);//1,2,event
19 },
20 changeData() {
21 this.msg = 'Hello Vue!';
22 },
23 }
24 });
如何解决vue里面的文本闪烁问题?
文本闪烁:当加载vue.js文件不及时时,会导致vue的语法无法继续加载,页面会显示vue的原始语法,用户体验不好。
解决办法:我们可以使用v-cloak指令解决,当vue.js文件没加载时,v-bloak会被识别为普通的自定义属性,
我们让添加了该属性的元素display:none;一旦vue.js加载完毕,v-bloak就会被vue识别为指令,
然后将v-bloak属性去除,则display:none;样式失效,进而显示内容。
1 [v-bloak] {
2 display: none;
3 }
1 <p v-cloak>{{'Hello Vue!'}}</p>
01.vue数据绑定的更多相关文章
- Vue数据绑定
gitHub地址:https://github.com/lily1010/vue_learn/tree/master/lesson04 一 双括号用来数据绑定 (1)写法一: {{message}}, ...
- 浅析vue数据绑定
前言:最近团队需要做一个分享,脚进脑子,不知如何分享.最后想着之前一直想研究一下 vue 源码,今天刚好 "借此机会" 研究一下. 网上研究vue数据绑定的文章已经非常多了,但是自 ...
- vue.js 2.0 官方文档学习笔记 —— 01. vue 介绍
这是我的vue.js 2.0的学习笔记,采取了将官方文档中的代码集中到一个文件的形式.目的是保存下来,方便自己查阅. !官方文档:https://cn.vuejs.org/v2/guide/ 01. ...
- Vue数据绑定和响应式原理
Vue数据绑定和响应式原理 当实例化一个Vue构造函数,会执行 Vue 的 init 方法,在 init 方法中主要执行三部分内容,一是初始化环境变量,而是处理 Vue 组件数据,三是解析挂载组件.以 ...
- 17: VUE数据绑定 与 Object.defineProperty
VUE数据绑定原理:https://segmentfault.com/a/1190000006599500?utm_source=tag-newest Object.defineProperty(): ...
- Vue数据绑定(一)
Contents Vue作为当下炙手可热的前端三大框架之一,一直都想深入研究一下其内部的实现原理,去学习MVVM模式的精髓.如果说MVVM是当下最流行的图形用户界面开发模式,那么数据绑定则是这一模式的 ...
- (三)vue数据绑定及相应的命令
vue数据绑定及相应的命令 {{ Text }} 双括号进行数据渲染 动态绑定数据 例如:{{message}} data: { return{ message: 'Hello Vue!' } } 2 ...
- 「每日一题」有人上次在dy面试,面试官问我:vue数据绑定的实现原理。你说我该如何回答?
关注「松宝写代码」,精选好文,每日一题 时间永远是自己的 每分每秒也都是为自己的将来铺垫和增值 作者:saucxs | songEagle 来源:原创 一.前言 文章首发在「松宝写代码」 2020. ...
- vue数据绑定原理
一.定义 vue的数据双向绑定是基于Object.defineProperty方法,通过定义data属性的get和set函数来监听数据对象的变化,一旦变化,vue利用发布订阅模式,通知订阅者执行回调函 ...
随机推荐
- 设置Anaconda启动jupyter的默认目录
要解决的问题:安装好Anaconda后打开jupyter总是会自动跳到c:下的用户目录,通过以下方法可以修改其默认打开的目录 吐槽:竟然没有设置默认打开目录的选项,只能通过修改配置文件完成,让人不爽. ...
- Solon详解(四)- Solon的事务传播机制
在前面的篇章里我们已经见识了 Solon 对事务的控制,及其优雅曼妙的形态.该篇将对事务的传播机制做讲解.出于对用户的学习成本考虑,Solon 借签了Spring 的事务传播策略:并友好的支持多数据源 ...
- JavaFX桌面应用-SpringBoot + JavaFX
SpringBoot对于Java程序员来说可以是一个福音,它让程序员在开发的时候,大大简化了各种spring的xml配置. 那么在JavaFX项目使用SpringBoot会是怎么样的体验呢? 这次使用 ...
- Ajax、XMLHttpRequest、JSONP的区别
来自2020年搜狗的笔试题,第一题就不会
- oracle之回顾二
TCL 1. 事务(Transaction) 事务(Transaction)是一个操作序列.这些操作要么都做, 要么都不做, 是一个不可分割的工作单元, 是数据库环境中的最小工作单元. 1.1 事务 ...
- seo兼职顾问多少钱
http://www.wocaoseo.com/thread-199-1-1.html 随着近几年搜索引挚市场迅猛的发展,网络营销已成为企业销售的一大趋势,越来越多的企业开始投身于网络市 ...
- 【原创】Linux虚拟化KVM-Qemu分析(二)之ARMv8虚拟化
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: KVM版本:5.9 ...
- Vue根据条件添加 click 事件
方式一:在绑定事件中直接添加标示量clickFlag <div @click="clickFlag && addGoodsHandler()"> XXX ...
- day43:CSS样式相关
目录 1.高度和宽度 2.字体相关 3.字体对齐 4.颜色设置 5.背景 6.边框 7.盒子模型 8.display属性 9.伪元素选择器 10.伪类选择器 11.浮动 12.文字装饰 13.相对定位 ...
- 用于测试SqlAnalyzer1.00的十七个测试用例
SqlAnalyzer功能:解析SQL语句,具体到字段,表和条件,并将其整理后输出格式化文本. 1. 原文=select a from b 整理后文本= select a from b 2. 原文=s ...
