Vue中使用watch监听对象/数组导致的新旧值相同

2019-12-02 admin

<nav id=“sf-header” class=“navbar navbar-expand-lg navbar-light bg-white shadow-sm”></nav>

<input id=“articleId” value=“1190000021172055” class=“hidden”>

<div class=“position-relative”>

<div class=“container my-4”>

<div class=“row”>

<div class=“col-12 col-xl w-0”>

<div class=“card border-0 mb-4”>

<div class=“card-body p-lg-30”>

vue官网的说明 ZI1C2Q3C1)U6HN%HQQNYA1A.png

data(){
    return {
        processSteps: {
            type: 'form',
            data: [
                {
                    name: 'xiaoming',
                    age: 18
                },{
                    name: 'xiaohong',
                    age: 18
                }
            ]
        },
        list: []
    }
}
//计算属性实现的监听也不是深度监听
computed: {
    //processSteps为实例中实际用到的一个对象, 此处借助另一个变量newProcessSteps来完成监听后的处理操作
    newProcessSetps(){
        return JSON.parse(JSON.stringify(this.processSteps)))
    },
    //数组(只要有返回新数组就可以)
    newList(){
        return [...this.list]    //...展开运算符返回一个新数组
    }
},
watch: {
    newProcessSteps:{
        handler(newVal, oldVal){
            console.log(newVal, oldVal)
            //比较newVal和olcVal
            ...
            ...
        },
        deep: true
    }
}

<div class=“article-author d-flex flex-column flex-sm-row align-items-center pt-4 border-top”>

<div class=“d-flex align-items-center flex-grow-1 author-left”> </div>

<button type=“button” class=“btn btn-primary follow-user sf_do” data-dotype=“post” data-content="{“type”:“state”,“state”:false,“true”:"\u5173\u6ce8\u4f5c\u8005",“false”:"\u6b63\u5728\u5173\u6ce8"}" data-api="/iteration/api/user/1030000017125528/follow">关注作者</button>

</div>

</div>

</div>

推荐阅读

</div>

<div class=“col-12 col-xl-auto”>

<div class=“w-xl-300”>

<div class=“card border-0 mt-4”>

<div class=“card-body”>

<div class=“text-center mb-3”>

<div class=“mb25 hidden-md hidden-sm hidden-xs”>Planets <map name=“gridsMap” id=“gridsMap”></map> </div>

</div>

</div>

</div>

</div>

</div>

</div>

</div>

</div>

[转载]原文链接:https://segmentfault.com/a/1190000021172055

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处。

转载请注明:文章转载自 JavaScript中文网 [https://www.javascriptcn.com]

本文地址:https://www.javascriptcn.com/read-80284.html

文章标题:Vue中使用watch监听对象/数组导致的新旧值相同

相关文章
bootstrap PrintThis打印插件使用详解
bootstrap PrintThis打印效果图: 如图,这个是调用了谷歌的打印,使用很方便,可以自己調样式,需要的可以研究一下,这边贴出使用方法。 附上GitHub:https://github.com/jasonday/printTh...
2017-03-16
vue 数组遍历方法forEach和map的原理解析和实际应用
一、前言 forEach和map是数组的两个方法,作用都是遍历数组。在vue项目的处理数据中经常会用到,这里介绍一下两者的区别和具体用法示例。 二、代码 1. 相同点 都是数组的方法 都用来遍历数组 两个函数都有4个参数:匿名函数中可传3...
2018-11-15
一些前端学习中好的书籍,整理
一、Javascript方面的书籍: 1 JavaScript权威指南(第6版):号称javascript圣经,前端必备;前端程序员学习核心JavaScript语言和由Web浏览器定义的JavaScript API的指南和综合参考手册; 2...
2015-11-12
js性能优化 如何更快速加载你的JavaScript页面
确保代码尽量简洁 不要什么都依赖JavaScript。不要编写重复性的脚本。要把JavaScript当作糖果工具,只是起到美化作用。别给你的网站添加大量的JavaScript代码。只有必要的时候用一下。只有确实能改善用户体验的时候用一下。 ...
2015-11-12
10个强大的纯CSS3动画案例分享
我们的网页外观主要由CSS控制,编写CSS代码可以任意改变我们的网页布局以及网页内容的样式。CSS3的出现,更是可以让网页增添了不少动画元素,让我们的网页变得更加生动有趣,并且更易于交互。本文分享了10个非常炫酷的CSS3动画案例,希望大家...
2015-11-16
请前往任务中心完善资料即可激活会员
登录后,点击右上角的用户名,在下拉菜单中可以进去“我的任务” 注册自动激活,本站没有VIP!没有充值!没有推广任务等等 回复即可下载 ...
2015-11-18
Android中Okhttp3实现上传多张图片同时传递参数
之前上传图片都是直接将图片转化为io流传给服务器,没有用框架传图片。 最近做项目,打算换个方法上传图片。 Android发展到现在,Okhttp显得越来越重要,所以,这次我选择用Okhttp上传图片。 Okhttp目前已经更新到Okhttp...
2017-03-17
v-charts | 饿了么团队开源的基于 Vue 和 ECharts 的图表工具
在使用echarts生成图表时,经常需要做繁琐的数据类型转化、修改复杂的配置项,v-charts的出现正是为了解决这个 痛点。基于Vue2.0和echarts封装的v-charts图表组件,只需要统一提供一种对前后端都友好的数据格式 设置简...
2018-05-24
Angular2-primeNG文件上传模块FileUpload使用详解
近期在学习使用Angular2做小项目,期间用到很多primeNG的模块。 本系列将结合实战总结angular2-primeNG各个模块的使用经验。 文件上传模块FileUploadModule 首先要在使用该组件的模块内导入文件上传模块 ...
2017-03-09
jsdom 中文文档(纯翻译)
jsdom是一个纯粹由 javascript 实现的一系列 web标准,特别是 WHATWG 组织制定的DOM和 HTML 标准,用于在 nodejs 中使用。大体上来说,该项目的目标是模拟足够的Web浏览器子集,以便用于测试和挖掘真实世界...
2018-05-14
回到顶部