美文网首页
Object.assign() 函数与...state函数

Object.assign() 函数与...state函数

作者: 云深不知处a | 来源:发表于2018-12-17 15:48 被阅读39次

1、Object.assign()函数
Object.assign(target, source)
target为目标对象
source为源对象
该函数的作用是以目标对象为基础,将源对象中的内容更新到目标对象中,有则替换,无则新增

 var result01 = {type: '01', name: 'ming', age: 23};
 let result02 = {type: '02', marry: false};
 let result03 = {type: '03', age: 55}
 const result = Object.assign({}, result01, result02, result03);
 DLog(result,result.name,result.type,result01);

结果


image.png
var result01 = {type: '01', name: 'ming', age: 23};
let result02 = {type: '02', marry: false};
let result03 = {type: '03', age: 55}
const result = Object.assign(result01, result02, result03);
DLog(result,result.name,result.type,result01);

结果


image.png

由此可以看出,如果不需要改变目标函数,第一个参数就置为空对象

2、...state函数
测试01:

      let result01 = {type: '01', name: 'ming', age: 23};
        console.log(result01);
        console.log({...result01});
        console.log({result01});
        console.log([{...result01}]);

打印结果


image.png

说明 ...state 是把对象的元素拿出来作为一个新的集合

测试02:

      let result01 = {type: '01', name: 'ming', age: 23};
        let result02 = {type: '02', marry: false};
        let result03 = {type: '03', age: 55,address:'beijing'}
        const result = Object.assign({},result01, result02, result03);
        console.log({...result02,...result03});

打印结果


image.png

测试03:

      var arr0 = [0,1,2];
        var arr1 = [3,4];
        var arr3 = [arr0];
        var arr4 = [...arr0];
        console.log(arr3);
        console.log(arr4);

打印结果


image.png
      var arr0 = [0,1,2];
        var arr1 = [3,4];
        var arr3 = [arr0];
        var arr4 = [...arr0,{...arr1}];
        console.log(arr4);  

打印结果


image.png
       var arr0 = [0,1,2];
       var arr1 = [3,4,0];
       var arr3 = [arr0];
       var arr4 = [...arr0,...arr1];
       console.log(arr4);

打印结果


image.png

说明这是一个数据深拷贝的过程
把源对象的元素加入到目标函数中
对象合并

这样看...state与Object.assign()之间既有相似之处,也有各种特点
对比代码与结果,不难理解

相关文章

  • Object.assign() 函数与...state函数

    1、Object.assign()函数Object.assign(target, source)target为目标...

  • React学习笔记2

    1.render函数对于props和state必须是纯函数 render函数不能改变props和state的属性,...

  • react 数据操作

    state 与 props 的相同之处 改变都会触发render函数(UI改变) state 与props 的不同...

  • React Hooks

    State Hook State Hook是一个在函数组件中使用的函数(useState), 用于在函数组件中使用...

  • Vuex的使用

    State 访问方式: 通过属性访问和辅助函数 通过属性访问: this.$store.state 辅助函数: ....

  • 3.启发函数(heuristic)的设计

    启发函数的介绍 是一种函数用来估算当前state和 目标state之间的距离,用于路径决策。也就是说,该函数的IQ...

  • React学习(6)-React中组件的数据-state

    前言 组件中的state具体是什么?怎么更改state的数据? setState函数分别接收对象以及函数有什么区别...

  • react中使用redux

    明确概念: Reducer 是一个纯函数,接收旧的state和action,返回新的state 与被传入Array...

  • 正确使用setState

    1、参数 用于产生与当前state合并的子集 state更新后立即执行的回调函数 2、setState更新(异步更...

  • 2019-01-24

    js函数 函数定义 functionfunctionname([arg0,arg1,arg2]){ state...

网友评论

      本文标题:Object.assign() 函数与...state函数

      本文链接:https://www.haomeiwen.com/subject/efhckqtx.html