使用 mapObjIndexed() 改變 Object 的 Value

栏目: JavaScript · 发布时间: 5年前

内容简介:在 Array,我們有VS Code 1.35.1Quokka 1.0.227

在 Array,我們有 map() 能在 Length 不變前提下,改變其 Element;若要在 Object 的 Key 不變前提下,根據其 Key 改變 Value,Ramda 提供了 mapObjIndexed()

Version

VS Code 1.35.1

Quokka 1.0.227

Ramda 0.26.1

Change Value by Key

import { mapObjIndexed } from 'ramda';

let data = {
  'FP in JavaScript': 100,
  'RxJS in Action': 200,
  'Speaking JavaScript': 300
};

// fn :: {a} -> {a}
let fn = mapObjIndexed((val, key) => `Price of ${key} is ${val}`);

console.dir(fn(data));

data 為 object,我們希望在 key 不變前提下,將 value 改成類似 Price of FP in JavaScript is 100 格式,其中 value 改變還牽涉到 key,此時就很適合使用 mapObjIndexed()

mapObjIndexed()

((*, String, Object) → *) → Object → Object

Object 版的 map() ,提供 value 與 key 給 callback 使用

(*, String, Object) -> * :callback,其中 * 為 value, String 為 key, Object 原本的 object。

Object :data 為 object

Object :回傳 map 後的 object

使用 mapObjIndexed() 改變 Object 的 Value

Only Change by Value

import { mapObjIndexed } from 'ramda';

let data = {
  'FP in JavaScript': 100,
  'RxJS in Action': 200,
  'Speaking JavaScript': 300
};

// fn :: {a} -> {a}
let fn = mapObjIndexed(val => `Price is ${val}`);

console.dir(fn(data));

若 value 改變不牽涉到 key,只與 value 有關,則 callback 可以不用傳入 key,只傳入 value 即可。

使用 mapObjIndexed() 改變 Object 的 Value

import { map } from 'ramda';

let data = {
  'FP in JavaScript': 100,
  'RxJS in Action': 200,
  'Speaking JavaScript': 300
};

// fn :: {a} -> {a}
let fn = map(val => `Price is ${val}`);

console.dir(fn(data));

事實上若 value 改變不牽涉到 key,只與 value 有關,其實使用 map() 亦可。

使用 mapObjIndexed() 改變 Object 的 Value

Change Value by Index

import { map, addIndex } from 'ramda';

let data = {
  'FP in JavaScript': 100,
  'RxJS in Action': 200,
  'Speaking JavaScript': 300
};

// fn :: {a} -> {a}
let fn = addIndex(map)((val, idx) => `Price ${idx} is ${val}`);

console.dir(fn(data));

若 value 改變不牽涉到 key,而是與 index 有關,則要用 addIndex()map() 組合的新 function,其 callback 的第二個參數為 index。

使用 mapObjIndexed() 改變 Object 的 Value


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C++设计新思维

C++设计新思维

(美)Andrei Alexandrescu / 侯捷、於春景 / 华中科技大学出版社 / 2003-03 / 59.8

本书从根本上展示了generic patterns(泛型模式)或pattern templates(模式模板),并将它们视之为“在C++中创造可扩充设计”的一种功能强大的新方法。这种方法结合了template和patterns,你可能未曾想过,但的确存在。为C++打开了全新视野,而且不仅仅在编程方面,还在于软件设计本身;对软件分析和软件体系结构来说,它也具有丰富的内涵。一起来看看 《C++设计新思维》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具