使用 Maybe 自行組合 safeNth()

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

内容简介: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()


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

查看所有标签

猜你喜欢:

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

Adobe Dreamweaver CS5中文版经典教程

Adobe Dreamweaver CS5中文版经典教程

Adobe公司 / 陈宗斌 / 人民邮电 / 2011-1 / 45.00元

《Adobe Dreamweaver CS5中文版经典教程》由Adobe公司的专家编写,是AdobeDreamweavelCS5软件的官方指定培训教材。全书共分为17课,每一课先介绍重要的知识点,然后借助具体的示例进行讲解,步骤详细、重点明确,手把手教你如何进行实际操作。全书是一个有机的整体,它涵盖了Dreamweavercs5的基础知识、HTML基础、CSS基础、创建页面布局、使用层叠样式表、使......一起来看看 《Adobe Dreamweaver CS5中文版经典教程》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换