Ramda 之 includes()

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

内容简介:實務上我們常需判斷某一個值是否存在於 Array 內,若存在則傳回VS Code 1.31.1Quokka 1.0.212

實務上我們常需判斷某一個值是否存在於 Array 內,若存在則傳回 true ,若不存在則傳回 false ,對於簡單的需求,我們會希望不要傳入 Callback,直接傳入 Data 即可。

Version

VS Code 1.31.1

Quokka 1.0.212

Ramda 0.26.1

Imperative

let data = [1, 2, 3];

let includes = arg => arr => {
  for(let elem of arr) {
    if (elem === arg) return true;
  }
  return false;
}

console.log(includes(1)(data));

建立 includes() ,imperative 會使用 for loop 搭配 if 判斷,若找到就直接回傳 true 結束,若都找不到則回傳 false

Ramda 之 includes()

Array.prototype.includes()

let data = [1, 2, 3];

console.log(data.includes(1));

Array.prototype 有內建 includes() ,直接傳入 data 即可。

就功能而言兩者都一樣,但 Array.prototype.includes() 屬 OOP 風格,為 data 的 method,而 includes() 為 FP 風格,data 以 argument 傳入 function,且為最後一個 argument,方便 point-free

Ramda 之 includes()

Functional

import { any } from 'ramda';

let data = [1, 2, 3];

let includes = arg => any(x => x === arg);

console.log(includes(1)(data));

其實我們大可不必自己寫 for loop,可藉助 Ramda 的 any() 實現出 includes()

any()

(a -> Boolean) -> [a] -> Boolean

判斷符合條件的 data 是否存在於 array

Ramda 之 includes()

includes()

Primitive

import { includes } from 'ramda';

let data = [1, 2, 3];

console.log(includes(1)(data));

事實上 Ramda 已經提供 includes() ,可直接使用。

includes()

a → [a] → Boolean

判斷 data 是否存在於 array

a : 欲判斷的 data

[a] :data 為 array

Boolean :回傳比較結果

Ramda 之 includes()

Object

import { includes } from 'ramda';

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

console.log(includes({ title: 'FP in JavaScript', price: 100 })(data));

includes() 也可判斷 object 是否存在於 array,值得注意的是 includes() 使用 equals() 判斷,而非 === ,比較的是 object property,而非 object reference。

Ramda 之 includes()

import { includes } from 'ramda';

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

console.log(data.includes({ title: 'FP in JavaScript', price: 100 }));

若使用 Array.prototype.includes() ,比較的是 object reference,明顯與 includes() 不同。

對於 primitive, includes()Array.prototype.includes() 完全相同;但對於 object,則兩者不同

Ramda 之 includes()

String

import { includes } from 'ramda';

let data = 'FP in JavaScript';

console.log(includes('JavaScript', data));

includes() 除了用在 array,也可以用在 string

Ramda 之 includes()

let data = 'FP in JavaScript';

console.log(data.includes('JavaScript'));

若用在 string ,則與 String.prototype.includes() 完全相同。

Ramda 之 includes()


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

查看所有标签

猜你喜欢:

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

Python语言程序设计

Python语言程序设计

[美]梁勇(Lang Y. D.) / 李娜 / 机械工业出版社 / 2015-4 / 79.00元

本书采用“问题驱动”、“基础先行”和“实例和实践相结合”的方式,讲述如何使用Python语言进行程序设计。本书首先介绍Python程序设计的基本概念,接着介绍面向对象程序设计方法,最后介绍算法与数据结构方面的内容。为了帮助学生更好地掌握相关知识,本书每章都包括以下模块:学习目标,引言,关键点,检查点,问题,本章总结,测试题,编程题,注意、提示和警告。 本书可以作为高等院校计算机及相关专业Py......一起来看看 《Python语言程序设计》 这本书的介绍吧!

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

在线压缩/解压 JS 代码

MD5 加密
MD5 加密

MD5 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器