nth-check

WebJar for nth-check

License

License

BSD-2-Clause
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

nth-check
Last Version

Last Version

2.0.0
Release Date

Release Date

Type

Type

jar
Description

Description

nth-check
WebJar for nth-check
Project URL

Project URL

https://www.webjars.org
Source Code Management

Source Code Management

https://github.com/fb55/nth-check

Download nth-check

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/nth-check/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>nth-check</artifactId>
    <version>2.0.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/nth-check/
implementation 'org.webjars.npm:nth-check:2.0.0'
// https://jarcasting.com/artifacts/org.webjars.npm/nth-check/
implementation ("org.webjars.npm:nth-check:2.0.0")
'org.webjars.npm:nth-check:jar:2.0.0'
<dependency org="org.webjars.npm" name="nth-check" rev="2.0.0">
  <artifact name="nth-check" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='nth-check', version='2.0.0')
)
libraryDependencies += "org.webjars.npm" % "nth-check" % "2.0.0"
[org.webjars.npm/nth-check "2.0.0"]

Dependencies

compile (1)

Group / Artifact Type Version
org.webjars.npm : boolbase jar [1.0.0,2)

Project Modules

There are no modules declared in this project.

nth-check Build Status

Parses and compiles CSS nth-checks to highly optimized functions.

About

This module can be used to parse & compile nth-checks, as they are found in CSS 3's nth-child() and nth-last-of-type().

nth-check focusses on speed, providing optimized functions for different kinds of nth-child formulas, while still following the spec.

API

import nthCheck, { parse, compile } from "nth-check";
nthCheck(formula)

Parses and compiles a formula to a highly optimized function. Combination of parse and compile.

If the formula doesn't match any elements, it returns boolbase's falseFunc. Otherwise, a function accepting an index is returned, which returns whether or not the passed index matches the formula.

Note: The nth-rule starts counting at 1, the returned function at 0.

Example:

const check = nthCheck("2n+3");

check(0); // `false`
check(1); // `false`
check(2); // `true`
check(3); // `false`
check(4); // `true`
check(5); // `false`
check(6); // `true`
parse(formula)

Parses the expression, throws an Error if it fails. Otherwise, returns an array containing the integer step size and the integer offset of the nth rule.

Example:

parse("2n+3"); // [2, 3]
compile([a, b])

Takes an array with two elements (as returned by .parse) and returns a highly optimized function.

Example:

const check = compile([2, 3]);

check(0); // `false`
check(1); // `false`
check(2); // `true`
check(3); // `false`
check(4); // `true`
check(5); // `false`
check(6); // `true`

License: BSD-2-Clause

Security contact information

To report a security vulnerability, please use the Tidelift security contact. Tidelift will coordinate the fix and disclosure.

nth-check for enterprise

Available as part of the Tidelift Subscription

The maintainers of nth-check and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. Learn more.

Versions

Version
2.0.0
1.0.2
1.0.1