Vue实例和数据绑定
- 更新时间:2020-03-13 12:57:44
- 编辑:尚凯复
为什么绑定
简单的数据渲染,包括表达式、函数在内。其实都只是在标签中渲染,如果遇到以下情况怎么办呢:
需要在标签内部进行某种 "骚操作" 。
需要控制流来控制不同数据下的不同渲染效果。
需要渲染一个数组。
这时候简单渲染就不能很好的解决问题了,怎么办 ?
来一发数据绑定吧!
绑定是什么
在了解绑定是什么之前,先了解一下什么是指令:
在 " vue" 中,指令是带有 v-
前缀的特殊属性,用来修饰标签的(自定义组件在这里也统一归为标签,因为其使用方式和原生标签一样),其值的约束和模板语法一样,支持表达式、变量。
指令会监测其值的变化,并将其的变化反应给所处的DOM
我们来看一下上一章最后的例子:
<h1>{{ if(msg == '1') return time }}</h1>
在这里我们是想利用控制流来控制是否显示时间,但是很遗憾,模板语法并不支持js语法。
但是 " vue" 中有这样一个指令来弥补模板语法不支持 js语法的遗憾:
v-if
下面看看修改后的代码:
<h1 v-if="msg=='1'">{{ formatTime(time) }}</h1>
先将 msg
的值赋值为1
:
然后再修改一下 msg
的值看看:
什么也没有显示,因为我们 msg
的值并不是 1
。
v-if
指令很完美的解决了我们最开始提出来的第二个问题:
需要控制流来控制不同数据下的不同渲染效果。
让我们回到最开始的话题。
这就是指令,而在官方原生的指令中,有一个指令是专门用来绑定标签属性的:
v-bind
命名很形象,bind
直译就是绑定的意思。
如何绑定
这里利用 div
标签展示一下 v-bind
的使用方式,用在其它标签上同理:
<div v-bind:属性名="表达式"></div>
我们拿第一个问题举例实践一下:
需要在标签内部进行某种 "骚操作"。
这里我们就根据 isDark
的值来确定时间显示的背景色吧
当 isDark
为 true 的时候,背景色变成黑色,文字变成白色。
当 isDark
为 false的时候,背景色变成白色,文字变成黑色。
先来定义 isDark
:
data() { return { msg: 'hello vue', time: new Date(), isDark: False } }
然后添加一下两种条件下的样式:
<style> .dark{ background-color: black; color: white; } .light{ background-color: white; color: black; } </style>
接下来给 h1
标签加上绑定指令:
<h1 v-bind:class="isDark ? 'dark' : 'light'">{{ formatTime(time) }}</h1>
效果如下:
我们将 isDark
的值修改成 true:
很完美的达到了所需求的效果。
这就是指令的魅力。
最后一个问题
上述两个指令解决了我们最初提出来三个问题中的两个,那么剩下一个呢?
需要渲染一个数组。
当我们需要渲染表格的时候就会遇到这个场景,如何去渲染一个数组呢?模板语法又并不支持这么复杂的操作。
请出本章最后一个指令:
v-for
嗯,还是很形象。js里面也有 for 嘛~
先看看它是做什么的:
v-for
会为数据源(绑定的列表)中的每一项,生成一个同类的标签。
然后看看怎么用,这里用 a 标签做说明,其他标签类似:
<!-- 写法1 --> <a v-for="别名 in 数据源" v-bind:key="唯一标识">{{ 别名.字段 }}</a> <!-- 写法2 --> <a v-for="(下标, 别名) in 数据源" v-bind:key="唯一标识">{{ 别名.字段 }}</a>
因为新版本的 vue
要求使用 v-for
指令渲染的标签必须绑定一个key用做唯一标识,大多数情况下我们可以直接使用下标来进行标识
继续使用我们之前的代码进行演示,先定义一个 url的数组:
data() { return { msg: 'hello vue', time: new Date(), isDark: true, urlList: [ { text: '链接1', url: '#1' }, { text: '链接2', url: '#2' }, { text: '链接3', url: '#3' } ] } }
然后渲染安排一波:
<a v-for="(item, index) in urlList" v-bind:key="index" v-bind:href="item.url" rel="external nofollow" >{{item.text}}</a>
效果如下:
渲染的结果是三个 a
标签,非常正确~
很完美的解决了最后一个问题。
还有些什么指令呢?
官方还有其他的指令,这里再提一个:
v-on
v-on
指令可以绑定事件,比如说按钮的点击事件。
像上面切换背景的例子中,可以通过一个按钮的点击事件来修改 isDark
的值,从而控制背景的改变。就不需要每次都手动来修改下 isDark
的值了。
感谢大家学习以上知识点内容和对码农之家的支持。
相关教程
-
vue和react等项目中更简单的实现展开收起更多等效果示例
这篇文章主要介绍了vue和react等项目中更简单的实现展开收起更多等效果示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
发布时间:2019-07-25
-
自定义类似于jQuery UI Selectable 的Vue指令v-selectable
这篇文章主要介绍了自定义类似于jQuery UI Selectable 的Vue指令v-selectable的相关资料,需要的朋友可以参考下
发布时间:2019-07-24
-
Vue企业开发实战
本书以Vue.js 2为基础,以项目实战的方式引导读者渐进式学习Vue.js框架。本书分为项目起步、Vue.js介绍、项目插件、项目梳理等部分。
大小:109.6 MBVue.js实战电子书
-
Vue.js项目实战
Vue实用、灵便、更快,为搭建详细的当代Web运用出示了需要的全部作用,其渐进式的特性也让开发人员可以轻轻松松入门,发布后快速获得了前端工程师工作人员的亲睐。这书由Vue.js关键精英
大小:141 MBVue
-
Spring Boot+Spring Cloud+Vue+Element项目实战:手把手教你开发权限管理系统
本书从项目实践出发,手把手、心贴心地带领读者从零开始,一步一步地开发出功能相对完整的权限管理系统,从而深入掌握当前主流的Spring Boot + Spring Cloud + Vue前后端集成开发技术。 全书分为三篇共32章。第一篇为系统介绍篇,对系统的功能、架构和界面进行介绍,对系统的安装运行给出指南,对涉及的关键技术进行简单介绍。第二篇为后端实现篇,从数据库设计和搭建开发环境开始,全面细致地讲解权限管理系统的后端实现全过程。第三篇为前端实现
大小:132979 MB 项目实战
-
Vue.js快速入门
目前单页应用框架层出不穷,其中Vue.js是十分耀眼的项目之一,受到国内外开发人员的极度推崇。
大小:186.6 MBWeb前端电子书
-
Spring Boot+Vue全栈开发实战
传统的JavaEE开发效率低下、配置臃肿、调试不便,严重制约了程序员的生产力。Spring Boot致力于简化开发配置,并为企业级开发提供一系列非业务性功能;而Vue则采用数据驱动视图的方式将程序
大小:196.3 MBSpring电子书
-
Vue.js实战
尤雨溪推荐 随书附赠示例代码下载资源 vue社区iView组件贡献者 前端大神梁灏编写 突出实战 应用为王 大鹏展趐 鹰击长空 Vue.js实战助你攀上前端之巅
大小:196.7 MBVue电子书
-
Vue.js快速入门
目前单页应用框架层出不穷,其中Vue.js是十分耀眼的项目之一,受到国内外开发人员的极度推崇。 全书分为8章,内容包括Vue.js概述、Vue.js的安装、定义页面、渲染视图、路由、发送HTTP请求、表单的绑定和提交、打包、部署、解决js的跨域问题、Debug、Component、Mixin、Vuex、页面的生命周期等,最后还给出一个实战案例供读者了解Vue.js项目开发过程。 本书适合Vue.js初学者、Web前端开发人员,也适合高等院校和培训学校的师生教学参考。
大小:26581 MB MVue.js入门
-
JavaScript+Vue+React全程实例
这书根据基础知识与开发实践活动紧密结合的观念,选萃当今简易、好用和时兴的百余个JavaScript编码案例,协助阅读者学习培训把握JavaScript开发语言。本书內容详实、重中之重突显、浅显易懂,包含了JavaScript前端开发开发的各个方面。
大小:59150 MB MJS实例