Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/niksy/array-string-at

Array/string `.at()` ponyfill.
https://github.com/niksy/array-string-at

Last synced: 2 months ago
JSON representation

Array/string `.at()` ponyfill.

Awesome Lists containing this project

README

        

# array-string-at

[![Build Status][ci-img]][ci]
[![Browser testing by BrowserStack][browserstack-img]][browserstack]

[Array/string `.at()`](https://github.com/tc39/proposal-relative-indexing-method)
[ponyfill](https://ponyfill.com).

> […] `at()`, that is on the prototype of the built-in indexable objects:
> `Array`, `String`, and `TypedArrays` objects. The method supports relative
> indexing from the end when passed a negative index.

## Install

```sh
npm install array-string-at --save
```

## Usage

```js
import at from 'array-string-at';

at('becky', 1); // e
at('becky', -2); // k
```

You can **use named export `preferNative` if you wish to use native
implementation if it’s available**. In all other cases, ponyfill will be used.
Beware of
[caveats](https://github.com/sindresorhus/ponyfill#user-content-ponyfill:~:text=Ponyfills%20should%20never%20use%20the%20native,between%20environments%2C%20which%20can%20cause%20bugs.)!

### Polyfill

```js
import at from 'array-string-at';

if (typeof String.prototype.at === 'undefined') {
Object.defineProperty(String.prototype, 'at', {
configurable: true,
writable: true,
value: function (index) {
return at(this, index);
}
});
}

if (typeof Array.prototype.at === 'undefined') {
Object.defineProperty(Array.prototype, 'at', {
configurable: true,
writable: true,
value: function (index) {
return at(this, index);
}
});
}
```

## API

### at(item, index)

Returns: `*`

Returns value at specified index. Supports relative indexing from the end when
passed a negative index.

#### item

Type: `string|Array|TypedArray`

Item to search.

#### index

Type: `number`

Relative index.

## Browser support

Tested in Chrome 72, Edge 15, Firefox 65 and should work in all modern browsers
([support based on Browserslist configuration](https://browserslist.dev/?q=bGFzdCAzIG1ham9yIHZlcnNpb25zLCBzaW5jZSAyMDE5LCBlZGdlID49IDE1LCBub3QgaWUgPiAw)).

## Test

Test suite is taken and modified from following packages:

- [es-shims, string](https://github.com/es-shims/String.prototype.at/blob/main/test/tests.js)
- [es-shims, array](https://github.com/es-shims/Array.prototype.at/blob/main/test/tests.js)

For automated tests, run `npm run test:automated` (append `:watch` for watcher
support).

## License

MIT © [Ivan Nikolić](http://ivannikolic.com)

[ci]: https://travis-ci.com/niksy/array-string-at
[ci-img]: https://travis-ci.com/niksy/array-string-at.svg?branch=master
[browserstack]: https://www.browserstack.com/
[browserstack-img]: https://img.shields.io/badge/browser%20testing-BrowserStack-informational?logo=