坚果大叔 坚果大叔
  • 首页
  • 闲言碎语
  • 技术
  • 生活
  • 记录
  • 朋友
  • 热点新闻
  • 常用代码
  • 工具箱
  • 关于
首页 › 技术 › Vue改变数组值,页面视图为何不刷新?

Vue改变数组值,页面视图为何不刷新?

坚果大叔
2020-02-10 17:35:22技术阅读 2,151

1、iview table 自定义序号

Vue改变数组值,页面视图为何不刷新?-坚果大叔

将其对应的type设为 index 即可

{
    title: "序号",
    width: 70,
    align: "left",
    type: "index"
}

2、父子组件传值,父组件调用子组件方法

场景:iview 中 封装一个modal 组件公共引用

父组件:

// 引入组件
import orderModal from './orderModal.vue'
// 使用
<order-modal 
  :showPop="showPop"    // 控制组件的显示关闭
  :orderData="orderData"      // 数据
  :orderH1="orderH1"
  :btnText="btnText"
  @on-close="hidePop">    // 将子组件的方法传递给父组件使用
</order-modal>

// 父组件方法
hidePop(e,type){
    if(type !== undefined){
      // 方法
    }
    this.showPop = e  // 关闭弹窗 e 为子组件传递过来的值
},

子组件

<Modal 
    v-model="currentValue"  // 子组件中接受父组件的 isShowAdd
    @on-cancel="cancel">    // Modal 的关闭事件
    <Form   
        ref="orderData" 
        :model="orderData">  // 接受传递的数据
    </Form>
</Modal>

// 子组件 props接受传递参数
props: ['showPop','orderData','orderH1','btnText'],

这里原本 ==v-model== 使用的使传递过来的 ==showPop== 作为参数,一开始没有问题,但是如果我想将子组件的关闭方法提到父组件去触发 那么 直接在 父组件 ==this.showPop = false==。那么就会提示报错,因为 Vue使单向数据流不能直接改版传递子组件的值。改成如下:

// 在子组件中用watch来监听 isShowAdd 是否变化,
然后赋值给 currentValue
watch: {
  isShowAdd(value,val) {
    this.currentValue = value
  }
}
// 子组件的关闭操作提升到父组件 $emit
cancel(type){
    this.$emit('on-close', false, type)
}

3、网上的资料如下图:

Vue改变数组值,页面视图为何不刷新?-坚果大叔

总结:

这个问题还折腾了快半个小时,归根到底还是不经常使用的后果,好多代码之前都用过,像封装组件这种还要折腾,简直是不知道说什么好呀,只能以后多使用了。

4、Vue改变数据视图不更新

4.1 异步更新队列

Vue 异步执行 DOM 更新。只要观察到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据改变。

如果同一个 watcher 被多次触发,只会被推入到队列中一次。

这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作上非常重要。

然后,在下一个的事件循环“tick”中,

Vue 刷新队列并执行实际 (已去重的) 工作。

Vue 在内部尝试对异步队列使用原生的 Promise.then 和 MessageChannel,如果执行环境不支持,会采用 setTimeout(fn, 0) 代替。

解决方法

this.$nextTick()

4.2 数组改变视图不更新

通过以下数组方法可以让vue监测数组改动

push()

pop()

shift()

unshift()

splice()

sort()

reverse()

4.3 vue不能检测到对象属性的添加或删除

由于 Vue 会在初始化实例时对属性执行 getter/setter 转化过程,所以属性必须在 data 对象上存在才能让 Vue 转换它,这样才能让它是响应的

解决方法

1、Vue.set(object, key, value)

2、Object.assign() 或 _.extend() 方法来添加属性。

但是第二种方法,添加到对象上的新属性不会触发更新。在这种情况下可以创建一个新的对象,让它包含原对象的属性和新的属性:

// 代替 `Object.assign(this.someObject, { a: 1, b: 2 })`

this.someObject = Object.assign({}, this.someObject, { a: 1, b: 2 })  // 深拷贝
对象
赞赏 赞(0)
本文系作者 @坚果大叔 原创发布在 坚果大叔。未经许可,禁止转载。
永远的曼巴
上一篇
常见的CSS文字居中显示
下一篇
在小程序中查看
搜你想看的
聚合文章
2021又快过去了。
map,filter,forEach的区别和用法
八种让人眼前一亮的CSS HOVER效果~
JavaScript要点
闲言碎语
Memos
npm install 出现 Error:EISDIR:illegal operation on a directory 的错误提示!
2025-03-31 19:02:11
553 0 0
iphone 利用 Scriptable 添加网上国网电费小组件
2025-01-06 20:40:20
4,950 6 2
在博客中加上memos记录展示。
2024-12-25 23:41:27
2,299 5 2
网页点击平滑滚动效果~
2024-10-17 16:43:08
2,013 4
  • 0
博主

一位佛系的前端开发者,略通摄影,乐于尝试新事物,热衷于美食。

友链
故事胶片
公众号
坚果大叔 执行上下文 卖坚果的怪叔叔 Dacking
Copyright © 2017-2025 坚果大叔

开往-友链接力

萌ICP备20230818号

苏ICP备18048410号-3
  • 首页
  • 闲言碎语
  • 技术
  • 生活
  • 记录
  • 朋友
  • 热点新闻
  • 常用代码
  • 工具箱
  • 关于
# CSS # # JavaScript # # vue # # 微信 # # 生活 #
坚果大叔
317
文章
125
评论
365
喜欢