vue.js实现数据动态响应 Vue.set的简单应用


Posted in Javascript onJune 15, 2017

在vue里面,我们操作最多的就是各种数据,在jquery里面,我们习惯通过下标定向找到数据,然后重新赋值

比如var a[0]=111;(希望上家公司原谅菜鸟的我写了不少这样的代码)

下面上代码

<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <script src="./js/vue.min.js"></script>
</head>
<body>
 <div id="app">
  <ul>
  <li v-for="item in listData">{{item}}</li>
 </ul>
 <a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" v-text="he" @click="changeData()"></a>
 </div>
</body>
<script>
 new Vue({
 el:"#app",
 data:{
  he:"点我",
  listData:["a","b","c"]
  },
 methods:{
  changeData () {
   this.listData[0]="d";
  }
  }
 })
</script>
</html>

当我点击按钮时候,发现没有任何变化,页面上还是a,b,c

vue.js实现数据动态响应 Vue.set的简单应用

vue当然不会这么菜呢

下面是伟大的vue内置的方法来了

 Vue.set()

官方解释

设置对象的属性。如果对象是响应式的,确保属性被创建后也是响应式的,同时触发视图更新。这个方法主要用于避开 Vue 不能检测属性被添加的限制。

 我的理解就是触发视图重新更新一遍,数据动态起来

Vue.set(a,b,c)

a是要更改的数据

b是数据的第几项

c是更改后的数据

解决上面数据不能更改后的代码

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <script src="./js/vue.min.js"></script>
</head>
<body>
 <div id="app">
   <ul>
    <li v-for="item in listData">{{item}}</li>
  </ul>
  <a href="javascript:void(0)" v-text="he" @click="changeData()"></a>
 </div>
</body>
<script>
 new Vue({
  el:"#app",
  data:{
   he:"点我",
   listData:["a","b","c"]
   },
  methods:{
    changeData () {
     Vue.set(this.listData,0,'X')
    }
   }
 })
</script>
</html>

vue.js实现数据动态响应 Vue.set的简单应用

我们可以看到,this.listData数组的第一项已经被更改了

X

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Jquery 获取表单text,areatext,radio,checkbox,select值的代码
Nov 12 Javascript
JavaScript 学习笔记(十六) js事件
Feb 01 Javascript
使用GruntJS构建Web程序之安装篇
Jun 04 Javascript
浅析$(function) ready和onload 的区别
Sep 03 Javascript
EasyUI修改DateBox和DateTimeBox的默认日期格式示例
Jan 18 Javascript
node.js平台下利用cookie实现记住密码登陆(Express+Ejs+Mysql)
Apr 26 Javascript
jQuery EasyUI结合zTree树形结构制作web页面
Sep 01 jQuery
js中document.write和document.writeln的区别
Mar 11 Javascript
深入理解Vue Computed计算属性原理
May 29 Javascript
详解如何探测小程序返回到webview页面
May 14 Javascript
详解ECMAScript2019/ES10新属性
Dec 06 Javascript
JavaScript 绘制饼图的示例
Feb 19 Javascript
vue实现全选、反选功能
Nov 17 #Javascript
vue中将网页打印成pdf实例代码
Jun 15 #Javascript
Bootstrap Tree View简单而优雅的树结构组件实例解析
Jun 15 #Javascript
Angularjs为ng-click事件传递参数
Jun 15 #Javascript
详解原生js实现offset方法
Jun 15 #Javascript
微信小程序 监听手势滑动切换页面实例详解
Jun 15 #Javascript
微信小程序canvas写字板效果及实例
Jun 15 #Javascript
You might like
木翼下载系统中说明的PHP安全配置方法
2007/06/16 PHP
ThinkPHP3.0略缩图不能保存到子目录的解决方法
2012/09/30 PHP
php实现遍历文件夹的方法汇总
2017/03/02 PHP
php 开发中加密的几种方法总结
2017/03/22 PHP
(推荐一个超好的JS函数库)S.Sams Lifexperience ScriptClassLib
2007/04/29 Javascript
设置下载不需要倒计时cookie(倒计时代码)
2008/11/19 Javascript
使用JavaScript动态设置样式实现代码及演示动画
2013/01/25 Javascript
使用Node.js实现一个简单的FastCGI服务器实例
2014/06/09 Javascript
3种Jquery限制文本框只能输入数字字母的方法
2014/12/03 Javascript
创建你的第一个AngularJS应用的方法
2015/06/16 Javascript
浅谈javascript的闭包
2017/01/23 Javascript
JavaScript队列的应用实例详解【经典数据结构】
2017/04/12 Javascript
微信小程序后台解密用户数据实例详解
2017/06/28 Javascript
解决百度Echarts图表坐标轴越界的方法
2018/10/17 Javascript
JavaScript生成一个不重复的ID的方法示例
2019/09/16 Javascript
[37:35]DOTA2上海特级锦标赛A组资格赛#1 Secret VS MVP.Phx第二局
2016/02/25 DOTA
Python批量重命名同一文件夹下文件的方法
2015/05/25 Python
20个常用Python运维库和模块
2018/02/12 Python
django DRF图片路径问题的解决方法
2018/09/10 Python
python实现输入任意一个大写字母生成金字塔的示例
2019/10/27 Python
python+Django实现防止SQL注入的办法
2019/10/31 Python
python字典和json.dumps()的遇到的坑分析
2020/03/11 Python
keras的ImageDataGenerator和flow()的用法说明
2020/07/03 Python
python接入支付宝的实例操作
2020/07/20 Python
深入了解Python装饰器的高级用法
2020/08/13 Python
5 分钟读懂Python 中的 Hook 钩子函数
2020/12/09 Python
python爬虫利用代理池更换IP的方法步骤
2021/02/21 Python
CSS3 mask 遮罩的具体使用方法
2017/11/03 HTML / CSS
Otticanet英国:最顶尖的世界名牌眼镜, 能得到打折季的价格
2019/02/10 全球购物
error和exception有什么区别
2012/10/02 面试题
什么是表空间(tablespace)和系统表空间(System tablespace)
2013/02/25 面试题
个人自我鉴定怎么写
2013/10/28 职场文书
机电专业毕业生推荐信
2013/11/10 职场文书
班主任工作年限证明
2014/01/12 职场文书
详解thinkphp的Auth类认证
2021/05/28 PHP
如何使用Tkinter进行窗口的管理与设置
2021/06/30 Python