Vue数据绑定实例写法
前端  /  管理员 发布于 4年前   261
为什么绑定
简单的数据渲染,包括表达式、函数在内。其实都只是在标签中渲染,如果遇到以下情况怎么办呢:
需要在标签内部进行某种 "骚操作" 。
需要控制流来控制不同数据下的不同渲染效果。
需要渲染一个数组。
这时候简单渲染就不能很好的解决问题了,怎么办 ?
来一发数据绑定吧!
绑定是什么
在了解绑定是什么之前,先了解一下什么是指令:
在 " vue" 中,指令是带有 v-
前缀的特殊属性,用来修饰标签的(自定义组件在这里也统一归为标签,因为其使用方式和原生标签一样),其值的约束和模板语法一样,支持表达式、变量。
指令会监测其值的变化,并将其的变化反应给所处的DOM
我们来看一下上一章最后的例子:
{{ if(msg == '1') return time }}
在这里我们是想利用控制流来控制是否显示时间,但是很遗憾,模板语法并不支持js语法。
但是 " vue" 中有这样一个指令来弥补模板语法不支持 js语法的遗憾:
v-if
下面看看修改后的代码:
{{ formatTime(time) }}
先将 msg
的值赋值为1
:
然后再修改一下 msg
的值看看:
什么也没有显示,因为我们 msg
的值并不是 1
。
v-if
指令很完美的解决了我们最开始提出来的第二个问题:
需要控制流来控制不同数据下的不同渲染效果。
让我们回到最开始的话题。
这就是指令,而在官方原生的指令中,有一个指令是专门用来绑定标签属性的:
v-bind
命名很形象,bind
直译就是绑定的意思。
如何绑定
这里利用 div
标签展示一下 v-bind
的使用方式,用在其它标签上同理:
我们拿第一个问题举例实践一下:
需要在标签内部进行某种 "骚操作"。
这里我们就根据
isDark
的值来确定时间显示的背景色吧当
isDark
为 true 的时候,背景色变成黑色,文字变成白色。当
isDark
为 false的时候,背景色变成白色,文字变成黑色。先来定义
isDark
:data() { return { msg: 'hello vue', time: new Date(), isDark: False } }
然后添加一下两种条件下的样式:
接下来给
h1
标签加上绑定指令:{{ formatTime(time) }}
效果如下:
我们将
isDark
的值修改成 true:很完美的达到了所需求的效果。
这就是指令的魅力。
最后一个问题
上述两个指令解决了我们最初提出来三个问题中的两个,那么剩下一个呢?
需要渲染一个数组。
当我们需要渲染表格的时候就会遇到这个场景,如何去渲染一个数组呢?模板语法又并不支持这么复杂的操作。
请出本章最后一个指令:
v-for
嗯,还是很形象。js里面也有 for 嘛~
先看看它是做什么的:
v-for
会为数据源(绑定的列表)中的每一项,生成一个同类的标签。然后看看怎么用,这里用 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' } ] } }
然后渲染安排一波:
{{item.text}}
效果如下:
渲染的结果是三个
a
标签,非常正确~很完美的解决了最后一个问题。
还有些什么指令呢?
官方还有其他的指令,这里再提一个:
v-on
v-on
指令可以绑定事件,比如说按钮的点击事件。像上面切换背景的例子中,可以通过一个按钮的点击事件来修改
isDark
的值,从而控制背景的改变。就不需要每次都手动来修改下isDark
的值了。感谢大家学习以上知识点内容和的支持。
您可能感兴趣的文章:
- vue.js数据绑定操作详解
- Vue入门之数据绑定(小结)
- Vue.js实现双向数据绑定方法(表单自动赋值、表单自动取值)
- vue中的数据绑定原理的实现
- vue.js数据绑定的方法(单向、双向和一次性绑定)
- 浅谈Vue.js之初始化el以及数据的绑定说明
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号