使用 Maybe 自行組合 safeNth()

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

内容简介:Ramda 有些 Function 會回傳VS Code 1.33.1Quokka 1.0.209

Ramda 有些 Function 會回傳 undefined ,這些 Function 常常會忘記處理 undefined 而產生 Bug,比較好的方式是改回傳 Maybe ,可避免忘記處理 undefined

Version

VS Code 1.33.1

Quokka 1.0.209

Ramda 0.26.1

nth()

import { nth } from 'ramda';

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

console.log(nth(1)(data).title);
console.log(nth(3)(data).title);

使用 Ramda 的 nth() ,取出資料後為 object,取其 title property 顯示。

nth()

Number -> [a] -> a | Undefined

回傳 array 的 nth element

Numbern th element

[a] :data 為 array

a | Undefined :若找得到則傳回 element,找不到則傳回 undefined

使用 Maybe 自行組合 safeNth()

但別忘了 nth() 可能回傳 undefined ,因此很容易產生 Cannot read property of undefined 的 run-time 錯誤。

當然可以搭配 Ramda 的 propOr() 避免,但只要你稍微不小心,還是會忘了使用 propOr()

safeNth()

import { nth } from 'ramda';
import { isObject, safe } from 'crocks';

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

// safeNth :: Number -> [a] -> Maybe a
let safeNth = ofst => arr => safe(isObject)(nth(ofst, arr));

console.log(safeNth(1)(data).option({ title: 'No title' }).title);
console.log(safeNth(3)(data).option({ title: 'No title' }).title);

第 2 行

import { isObject, safe } from 'crocks';

使用 Crocks 的 isObject()safe()

第 10 行

// safeNth :: Number -> [a] -> Maybe a
let safeNth = ofst => arr => safe(isObject)(nth(ofst, arr));

自行建立 saveNth() ,signature 與 Ramda 的 nth() 完全相同,差異只在於回傳 Maybe ,而不是 a | Undefiend

safeNth()

Number -> [a] -> Maybe a

回傳 array 的 nth element

Numbern th element

[a] :data 為 array

Maybe a :無論找不找得到都回傳 Maybe

safe(isObject)

由 Crocks 的 safe()isObject() 組合出 function,若 nth() 結果為 object,則以 Just 包進 Maybe ,否則以 Nothing 包進 Maybe ,最後 safeNth() 回傳 Maybe

13 行

console.log(safeNth(1)(data).option({ title: 'No title' }).title);

因為 safeNth() 回傳為 Maybe ,所以取出資料時一定要透過 option() 才能取回 object,因此必須提供 default value 處理 Nothing

Maybe 強迫你要使用 option() 才能取回 object,因此你不可能忘記處理 Nothing ;不像 undefined 並沒有強迫處理,這就是常見的 bug 來源

使用 Maybe 自行組合 safeNth()


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

深入理解Nginx

深入理解Nginx

陶辉 / 机械工业出版社 / 2013-4-15 / 89.00元

本书是阿里巴巴资深Nginx技术专家呕心沥血之作,是作者多年的经验结晶,也是目前市场上唯一一本通过还原Nginx设计思想,剖析Nginx架构来帮助读者快速高效开发HTTP模块的图书。 本书首先通过介绍官方Nginx的基本用法和配置规则,帮助读者了解一般Nginx模块的用法,然后重点介绍如何开发HTTP模块(含HTTP过滤模块)来得到定制的Nginx,其中包括开发一个功能复杂的模块所需要了解的......一起来看看 《深入理解Nginx》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具