全面复习vue 教程 api 查漏补缺

举报
拿我格子衫来 发表于 2022/03/17 22:56:48 2022/03/17
【摘要】    没有需求做的我感觉自己像个废物   由于要准备面试,这几天准备好好学习,学习不仅仅为了是应付面试,更是为了查漏补缺 看了几遍vue的官网,虽然看了很多遍,但每一遍都很有收获 v-for 可以直接遍历对象, 虽然在实际中大多用是数组,很少去遍历对象 vue操作数组时需要注意 由于 Ja...

   没有需求做的我感觉自己像个废物

 

由于要准备面试,这几天准备好好学习,学习不仅仅为了是应付面试,更是为了查漏补缺 看了几遍vue的官网,虽然看了很多遍,但每一遍都很有收获

v-for 可以直接遍历对象, 虽然在实际中大多用是数组,很少去遍历对象

vue操作数组时需要注意

由于 JavaScript 的限制,Vue 不能检测以下数组的变动:

  1. 当你利用索引直接设置一个数组项时,例如:vm.items[indexOfItem] = newValue
  2. 当你修改数组的长度时,例如:vm.items.length = newLength

  
  1. var vm = new Vue({
  2. data: {
  3. items: ['a', 'b', 'c']
  4. }
  5. })
  6. vm.items[1] = 'x' // 不是响应性的
  7. vm.items.length = 2 // 不是响应性的

 

为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将在响应式系统内触发状态更新:


  
  1. // Vue.set
  2. Vue.set(vm.items, indexOfItem, newValue)

  
  1. // Array.prototype.splice
  2. vm.items.splice(indexOfItem, 1, newValue)

你也可以使用 vm.$set 实例方法,该方法是全局方法 Vue.set 的一个别名:

vm.$set(vm.items, indexOfItem, newValue)
 

为了解决第二类问题,你可以使用 splice

vm.items.splice(newLength)
 

 

还是由于 JavaScript 的限制,Vue 不能检测对象属性的添加或删除


  
  1. var vm = new Vue({
  2. data: {
  3. a: 1
  4. }
  5. })
  6. // `vm.a` 现在是响应式的
  7. vm.b = 2
  8. // `vm.b` 不是响应式的

对于已经创建的实例,Vue 不允许动态添加根级别的响应式属性。但是,可以使用 Vue.set(object, propertyName, value) 方法向嵌套对象添加响应式属性

 

Vue.set(vm.userProfile, 'age', 27)
 

 为已有对象赋值多个新属性


  
  1. vm.userProfile = Object.assign({}, vm.userProfile, {
  2. age: 27,
  3. favoriteColor: 'Vue Green'
  4. })

在 v-for 里使用值范围

在 <template> 上使用 v-for

 

事件处理可以将 当前事件对象  $event 作为参数传入函数

 

 

 

 

文章来源: fizzz.blog.csdn.net,作者:拿我格子衫来,版权归原作者所有,如需转载,请联系作者。

原文链接:fizzz.blog.csdn.net/article/details/103616205

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。