Security News
tea.xyz Spam Plagues npm and RubyGems Package Registries
Tea.xyz, a crypto project aimed at rewarding open source contributions, is once again facing backlash due to an influx of spam packages flooding public package registries.
array-includes
Advanced tools
Package description
The array-includes npm package provides a simple utility function for checking if an array includes a certain element, with optional support for the fromIndex parameter. It is a polyfill for the Array.prototype.includes method, which is part of the ECMAScript 2016 (ES7) standard but may not be available in all environments.
Check if an array includes a specific element
This feature allows you to check if an array contains a specific element. It returns true if the element is found, otherwise false.
var arrayIncludes = require('array-includes');
var myArray = [1, 2, 3];
var includesTwo = arrayIncludes(myArray, 2); // true
Check if an array includes a specific element starting from a given index
This feature allows you to check if an array contains a specific element, starting the search from a given index. It is useful when you want to ignore certain elements at the beginning of the array.
var arrayIncludes = require('array-includes');
var myArray = [1, 2, 3, 2];
var includesTwoFromIndex2 = arrayIncludes(myArray, 2, 2); // true
Lodash is a popular utility library that includes a method called _.includes. This method is similar to array-includes but offers additional features such as deep path string checks for objects and is part of a larger utility library.
Underscore is another utility library that provides a method called _.contains (also aliased as _.includes). It is similar to array-includes but is part of a larger set of utility functions for working with arrays, objects, and functions.
Changelog
v3.1.6 - 2022-11-07
auto-changelog
c5fbe72
npmignore
to autogenerate an npmignore file dbd6dc8
es-abstract
, get-intrinsic
b819e3b
6e241d5
aud
, tape
9b2a931
0a0c758
define-properties
, es-abstract
eslint
, @ljharb/eslint-config
, @es-shims/api
, aud
, functions-have-names
, safe-publish-latest
, tape
Math.max
calles-abstract
, is-string
prepublishOnly
script for npm 7+node/install
instead of node/run
; use codecov
actioneslint
, @ljharb/eslint-config
, @es-shims/api
, aud
, tape
call-bind
, es-abstract
, get-intrinsic
eslint
, @ljharb/eslint-config
, aud
, functions-have-names
, has-strict-mode
, tape
.apply
es-abstract
; use call-bind
and get-intrinsic
where applicableeslint
, @ljharb/eslint-config
, functions-have-names
, tape
; add aud
, safe-publish-latest
pull_request_target
eventnyc
on all testsimplementation
test; run es-shim-api
in postlint; use tape
runneres-abstract
eslint
, @ljharb/eslint-config
, tape
auto
entry pointes-abstract
(68% bundle size decrease)es-abstract
, define-properties
eslint
, @ljharb/eslint-config
, evalmd
, covert
, functions-have-names
, replace
, semver
, tape
, @es-shims/api
, function-bind
funding
field, FUNDING.ymlfromIndex
testsnpx aud
instead of nsp
or npm audit
with hoopsjscs
functions-have-names
npm audit
instead of nsp
jscs
shim.js
actually shims when the polyfill differs from nativenode
v7.9
, v6.10
, v4.8
; comment out OS X builds; improve test matrixnsp
, eslint
, @ljharb/eslint-config
, tape
, jscs
, semver
, function-bind
, @es-shims/api
es-abstract
es-abstract
jscs
, nsp
, eslint
, @ljharb/eslint-config
, semver
node
v5.5
node
v0.8
evalmd
as part of the full test suite, since it's more like a linterdefine-properties
, es-abstract
eslint
, semver
, nsp
, semver
, jscs
eslint
configio.js
v3.0
io.js
v2.0
es-abstract
, tape
, eslint
, semver
, jscs
, semver
es-abstract
, editorconfig-tools
, nsp
, eslint
, semver
node
/iojs
versions now ship with an npm
that understands ^
.travis-ci
tests on iojs
and node
v0.12; allow 0.8 failures.tape
, jscs
, es-abstract
, remove is
.tape
, jscs
, nsp
, eslint
, es-abstract
es-abstract
for ECMAScript spec internal abstract operationsnpm
Readme
An ES7/ES2016 spec-compliant Array.prototype.includes
shim/polyfill/replacement that works as far down as ES3.
This package implements the es-shim API interface. It works in an ES3-supported environment and complies with the proposed spec.
Because Array.prototype.includes
depends on a receiver (the this
value), the main export takes the array to operate on as the first argument.
Engines that need this package include:
npm install --save array-includes
Basic usage: includes(array, value[, fromIndex=0])
var includes = require('array-includes');
var assert = require('assert');
var arr = [ 'one', 'two' ];
includes(arr, 'one'); // true
includes(arr, 'three'); // false
includes(arr, 'one', 1); // false
var arr = [
1,
'foo',
NaN,
-0
];
assert.equal(arr.indexOf(0) > -1, true);
assert.equal(arr.indexOf(-0) > -1, true);
assert.equal(includes(arr, 0), true);
assert.equal(includes(arr, -0), true);
assert.equal(arr.indexOf(NaN) > -1, false);
assert.equal(includes(arr, NaN), true);
assert.equal(includes(arr, 'foo', 0), true);
assert.equal(includes(arr, 'foo', 1), true);
assert.equal(includes(arr, 'foo', 2), false);
/* when Array#includes is not present */
delete Array.prototype.includes;
var shimmedIncludes = includes.shim();
assert.equal(shimmedIncludes, includes.getPolyfill());
assert.equal(arr.includes('foo', 1), includes(arr, 'foo', 1));
/* when Array#includes is present */
var shimmedIncludes = includes.shim();
assert.equal(shimmedIncludes, Array.prototype.includes);
assert.equal(arr.includes(1, 'foo'), includes(arr, 1, 'foo'));
Simply clone the repo, npm install
, and run npm test
FAQs
An ES7/ES2016 spec-compliant `Array.prototype.includes` shim/polyfill/replacement that works as far down as ES3.
The npm package array-includes receives a total of 20,787,779 weekly downloads. As such, array-includes popularity was classified as popular.
We found that array-includes demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Tea.xyz, a crypto project aimed at rewarding open source contributions, is once again facing backlash due to an influx of spam packages flooding public package registries.
Security News
As cyber threats become more autonomous, AI-powered defenses are crucial for businesses to stay ahead of attackers who can exploit software vulnerabilities at scale.
Security News
UnitedHealth Group disclosed that the ransomware attack on Change Healthcare compromised protected health information for millions in the U.S., with estimated costs to the company expected to reach $1 billion.