- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我创建了一个自定义 fromJS 函数,以便当我将对象转换为不可变对象(immutable对象)时,结果将仅包含 OrderedSet 和 Map(而不是列表和 Map)。
除了在下面的情况下,对象中的键称为“长度”之外,这一切都工作得很好。有什么想法可以解决当前的问题吗?
var imm = require("immutable")
function fromJS(js) {
return typeof js !== 'object' || js === null ? js :
Array.isArray(js) ?
imm.Seq(js).map(fromJS).toOrderedSet() :
imm.Seq(js).map(fromJS).toMap();
}
var output = fromJS({
measurements: {
length: 10,
weight: 30
}
}).toJS();
// output is :
{
measurements: {
0: undefined,
1: undefined
....
32: undefined
}
}
最佳答案
通过将属性 length
更改为 mLength
来完成工作。
这是JSBin
ImmutableJS 查找 length
属性来检查给定值是否为 array-like反对与否。
由于您的 measurements
对象具有属性 length
,因此它认为该对象是一个 类数组
对象并继续 基于
构造,问题就开始了。类数组
类型的Seq
为了确认这一点,here是输出 Map
的 jsbin,其时间数在 measurements
对象的 length 属性中给出。
关于javascript - 自定义 fromJS immutablejs 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41222781/
我正在探索这两个库,对我来说 ImmutableJS具有(主要)不可变的数据结构,而 Ramda有瑞士军刀套装FP实用程序。 当我谷歌时,我看到类似 Ramda 的文章对比 ImmutableJS推荐
在原始 JS 对象上使用 Immutable.fromJS() 可以按预期工作并返回一个 Map,但尝试使用相同的 Immutable.fromJS()从构造函数获取的自定义对象不起作用。 含义: {
我导入了一条不可变记录,并希望在将其用作应用程序的默认状态之前向其中添加一个新属性。但是,尽管尝试了 merge、mergeDeep、mergeWith 和 mergeDeepWith,但我根本无法添
我正在设置这样的 map : import { Map } from 'immutable'; const initialState = { a: "test", b: { ins
我有这个不可变映射,我需要获取属性名称: 如果我这样做 retrospective.get('users') 我可以进入用户内部,但是如果我这样做 retrospective.getIn(['user
我正在研究 Immutable.js 代码,发现了一些奇怪的东西。Immutable.js 会跳过保存到不会使用的变量的代码吗? const Immutable = require('immutabl
是否可以使用 immutablejs像这样: 模态 class PeriodModel { constructor( id, title, ) {
我的 reducer 中最初有以下不可变状态: const firstState = Map({ "1": {title: "Hello 1", content: "Content 1"}, "2"
我有以下代码: Immutable.Set(['valor1', 'valor2', 'valor2', 'valor3', ['valor4', 'valor5']]).flatten().toJS
我有这个矩阵: const initialState = Immutable.fromJS({ board: [ ['','',''], ['','',''
const List = Immutable.List; const items = [ { id: 1, subList: [] }, { id: 2, subList: [] }, {
我有这个 immutableJs map : event: { days: [ { date: 1, sessions: [
我有一个这样的 map (在 ImmutableJS 中): {arrayOfValues: [ {one: {inside: 'first in array'}}, {one: {insid
我正在学习使用 ImmutableJS,但我有点困惑。我查看了文档,发现有对象的映射和数组的列表。 所以我构建了一个像这样的对象: sampleTodo = Immutable.Map({text:
如果我有一个像这样的对象: var fruitList = Immutable.map ({ fruits: [apples, oranges, mangoes]}); 如何在保持不变性的同时删除数组
我正在使用 ImmutableJS与 Redux和 redux-immutable .假设我有一个初始状态,它是一个空的项目数组: const initialState = fromJS({ it
我有以下格式的数据:action.places。 我只想将其与传入的新数据结合起来,并返回更新地点的新 map 。如果我得到一个地点对象,并且其中一个地点与前一个地点具有相同的纬度/经度,我不想附加该
我很难理解 immutablejs 的文档。我想更新名为 Sanskar 的列表。为此,我首先尝试使用 findIndex 来查找其索引并使用 update() 更新它。但我收到 item.get()
我在不可变的js中有一个像这样的结构的 map : myMap = { a: { b: { c: [ { d: "som
如果我使用 Immutable.js,react-redux 仍然可以使用 shouldComponentUpdate 吗? connect()方法在shouldComponentUpdate()中使
我是一名优秀的程序员,十分优秀!