什么是immutable?
简而言之,Immutable数据就是一旦创建,就不能更改的数据。每当对Immutable对象进行修改的时候,就会返回一个新的Immutable对象,以此来保证数据的不可变。对于Immutable的好处及介绍,大家可以参考Immutable 详解及 React 中实践,这篇文章介绍的很清楚。
因为Immutable的官方文档有点晦涩难懂,本文只是用来整理Immutable常用的API的使用,便于使用与查询,想了解更详细的内容,请戳这里~
Immutable 的几种数据类型
List: 有序索引集,类似JavaScript中的Array。
Map: 无序索引集,类似JavaScript中的Object。
OrderedMap: 有序的Map,根据数据的set()进行排序。
Set: 没有重复值的集合。
OrderedSet: 有序的Set,根据数据的add进行排序。
Stack: 有序集合,支持使用unshift()和shift()添加和删除。
Range(): 返回一个Seq.Indexed类型的集合,这个方法有三个参数,start表示开始值,默认值为0,end表示结束值,默认为无穷大,step代表每次增大的数值,默认为1.如果start = end,则返回空集合。
Repeat(): 返回一个vSeq.Indexe类型的集合,这个方法有两个参数,value代表需要重复的值,times代表要重复的次数,默认为无穷大。
Record: 一个用于生成Record实例的类。类似于JavaScript的Object,但是只接收特定字符串为key,具有默认值。
Seq: 序列,但是可能不能由具体的数据结构支持。
Collection: 是构建所有数据结构的基类,不可以直接构建。
用的最多就是List和Map,所以在这里主要介绍这两种数据类型的API。
fromJS()
作用:将一个js数据转换为Immutable类型的数据。
用法:fromJS(value, converter)
简介:value是要转变的数据,converter是要做的操作。第二个参数可不填,默认情况会将数组准换为List类型,将对象转换为Map类型,其余不做操作。
toJS()
作用:将一个Immutable数据转换为JS类型的数据。
用法:value.toJS()
is()
作用:对两个对象进行比较。
用法:is(map1,map2)
简介:和js中对象的比较不同,在js中比较两个对象比较的是地址,但是在Immutable中比较的是这个对象hashCode和valueOf,只要两个对象的hashCode相等,值就是相同的,避免了深度遍历,提高了性能。
import { Map, is } from 'immutable' const map1 = Map({ a: 1, b: 1, c: 1 }) const map2 = Map({ a: 1, b: 1, c: 1 }) map1 === map2 //falseObject.is(map1, map2) // falseis(map1, map2) // true
数据读取
get() getIn()
作用:获取数据结构中的数据
has() hasIn()
作用:判断是否存在某一个key
Immutable.fromJS([1,2,3,{a:4,b:5}]).has('0'); //true Immutable.fromJS([1,2,3,{a:4,b:5}]).has('0'); //true Immutable.fromJS([1,2,3,{a:4,b:5}]).hasIn([3,'b']) //true
数据修改
注:这里对于数据的修改,是对原数据进行操作后的值赋值给一个新的数据,并不会对原数据进行修改,因为Immutable是不可变的数据类型。
set()
作用:设置第一层key、index的值
delete()
作用:用来删除第一层结构中的属性
deleteIn()
用来删除深层数据,用法参考setIn
更新数据
update()
作用:对对象中的某个属性进行更新,可对原数据进行相关操作
参考文章:https://segmentfault.com/a/1190000010676878?utm_source=tag-newest
redux简单应用
import { INPUT_FOCUS } from '../actionTypes' import { fromJS } from 'immutable'; const defaultState = fromJS({ focused: false }) export default (state = defaultState, action) => { if (action.type === INPUT_FOCUS) { return state.set('focused', !state.get('focused')) } else { return state } }
组件取值
const mapStateToProps = (state) => { console.log(state) return { focused: state.header.get('focused') } } const mapDispatchToProps = { change_focus } export default connect(mapStateToProps, mapDispatchToProps)(Header);
发表评论
侧栏公告
寄语
譬如朝露博客是一个分享前端知识的网站,联系方式11523518。
热评文章
标签列表
热门文章
友情链接