immutable.js初识

介绍

按照官网的定义, Immutable Data是指一旦被创造后,就不可以被改变的数据。

相等性判断

JavaScript提供三种不同的值比较操作:

  1. 严格相等 ("triple equals" 或 "identity"),使用 ===
  2. 宽松相等 ("double equals") ,使用 ==
  3. Object.is (ECMAScript 2015/ ES6 新特性)
aaa.png

那么,javascript是怎么对两个对象进行比较的呢?

var person1 = {
  age: 27, 
  gender: "male",
  education: {major:"math",school:"Harvard"}
};

var person2 = {
  age: 27, 
  gender: "male",
  education: {major:"math",school:"Harvard"}
};

console.log(person1 == person2); //false
console.log(person1 === person2); //false
console.log(Object.is(person1,person2)); //false

虽然,person1和person2的属性是完全一样的,但是person1和person2相等性判断为false。因为对象是通过指针指向的内存中的地址来比较的。

很多场景下,对于属性相同的对象,我们希望相等性判断为true。Underscore.jsLodash都有一个名为_.isEqual()方法,用来处理深度对象的比较。大致思路是递归查找对象的属性进行值比较(具体实现推荐这篇文章:https://github.com/hanzichi/underscore-analysis/issues/5)。当然了,对象层级越深,比较越耗时。

相比之下,immutable.js使用了 Structural Sharing(结构共享),特别擅长处理对象的比较,性能非常好。上面的代码,让我们换成immutable.js来表达:

const person1 = Immutable.Map( {
      age: 27, 
      gender: "male",
      education: Immutable.Map({
        major:"math",
        school:"Harvard"
      })
});

const person2 = Immutable.Map( {
      age: 27, 
      gender: "male",
      education: Immutable.Map({
        major:"math",
        school:"Harvard"
      })
});

const person3 = person1.setIn(["education","major"], "english"); //person3专业为english

console.log(Immutable.is(person1, person2));//true
console.log(Immutable.is(person1, person3));//false

恩,达到了我们想要的效果。

immutable.js之于react的好处

众所周知,react性能优化的核心在于处理shouldComponentUpdate方法来避免不必要的渲染。虽然react提供了PureComponent,但它实质只是浅比较,无法很好地处理对象的比较,所以还是不能解决重复渲染的问题。

这个时候,immutable.js应运而生,它可以完美地解决这个问题,极大地提高react应用的性能。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,209评论 25 709
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,906评论 18 399
  • 文章作者:Tyan博客:noahsnail.com | CSDN | 简书 CHAPTER3 Method...
    SnailTyan阅读 4,014评论 1 4
  • 今年的国庆节跟中秋节虽然不是同一天,但是也都是在小长假里面,也算是一起过的节日! 所以在整理一些国庆中秋祝福语送给...
    战福刚阅读 4,260评论 0 6
  • 102课的主题是“如何画出正确的思维导图”,老师从导图分类、工具认知和如何手绘三大块入手非常详细的讲解了手绘思维导...
    撸啦啦练写字阅读 728评论 0 0