前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >全面复习vue 教程 api 查漏补缺

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

作者头像
拿我格子衫来
发布2022-01-24 17:58:47
2950
发布2022-01-24 17:58:47
举报
文章被收录于专栏:TopFETopFE

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

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

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

vue操作数组时需要注意

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

  1. 当你利用索引直接设置一个数组项时,例如:vm.items[indexOfItem] = newValue
  2. 当你修改数组的长度时,例如:vm.items.length = newLength
代码语言:javascript
复制
var vm = new Vue({
  data: {
    items: ['a', 'b', 'c']
  }
})
vm.items[1] = 'x' // 不是响应性的
vm.items.length = 2 // 不是响应性的

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

代码语言:javascript
复制
// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
代码语言:javascript
复制
// Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)

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

代码语言:javascript
复制
vm.$set(vm.items, indexOfItem, newValue)

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

代码语言:javascript
复制
vm.items.splice(newLength)

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

代码语言:javascript
复制
var vm = new Vue({
  data: {
    a: 1
  }
})
// `vm.a` 现在是响应式的

vm.b = 2
// `vm.b` 不是响应式的

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

代码语言:javascript
复制
Vue.set(vm.userProfile, 'age', 27)

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

代码语言:javascript
复制
vm.userProfile = Object.assign({}, vm.userProfile, {
  age: 27,
  favoriteColor: 'Vue Green'
})

v-for 里使用值范围

<template> 上使用 v-for

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 在 v-for 里使用值范围
  • 在 <template> 上使用 v-for
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档