1.0.10 • Published 4 years ago

@huynhducduy/is-palindrome v1.0.10

Weekly downloads
-
License
MIT
Repository
github
Last release
4 years ago

Palindrome Checker

npm (scoped) devDependencies Status npm bundle size (scoped) npm jsDelivr hits (npm scoped) Dependent repos (via libraries.io), scoped npm package

Zero dependencies, lightweight and fully functional palindrome checker

Install with npm

npm i @huynhducduy/is-palindrome --save

Install with yarn

yarn add @huynhducduy/is-palindrome

Table of Contents

Usage

CommonJS (Node)

var isPalindrome = require("@huynhducduy/is-palindrome");

ES Modules

import isPalindrome from "@huynhducduy/is-palindrome/dist/esm.js";

Browser (IIFE)

<script
  src="https://cdn.jsdelivr.net/npm/@huynhducduy/is-palindrome@1/dist/iife.js"
  crossorigin="anonymous"
></script>

Example

console.log(
  isPalindrome(
    "    Are we not pure? “No sir!” Panama’s moody Noriega brags. “It is garbage!” Irony dooms a man; a prisoner up to new era.    ",
    {
      remove: ["punctuation", "non-printable-ascii", "whitespace"],
      caseSensitive: false,
      trim: "both",
    }
  )
);
// true

Also support amd (RequireJS), umd, sys (SystemJS) as well.

API

default

Check if the given string is a valid palindrome

Params

  • str {Any}: String to check, it's not a valid string, the function will try to convert it, or will throws an exception
  • options {Object}: See options object
  • debug {Boolean}: Log debug or not

Return: {Boolean}: True if it is a valid palindrome that match out options, otherwise False

options

Options pass to is-palindrome. The processing flow is: Normalize -> Remove -> (Transform to lower case) -> Trim (whitespace and trailing)

nametype/valuesdefaultdescription
exceptionbooleanfalseInform the function to throw exceptions or not
normalizebooleanfalseInform the function to normalize string or not
normalizeForm"NFC", "NFD", "NFKC", "NFKD""NFC"The form being used to normalize string (if normalize === true), must be one of supported values, otherwise a exception will be thrown or the normalization will be omitted
removestring, [string][]remove some kind of char from string, accepted: "non-printable-ascii", "punctuation", "whitespace"
caseSensitivebooleantrueIndicate the case sensitivity of the function
trim"none", "start", "end", "both""none"Trim trailing whitespace mode
trimTrailingstring, [string]Trim trailing characters or strings
~\`!@#\$%^&\*(){}\[\];:"'<,.>?\/\\|\_+=-`

Other awesome projects

  • Update...

Running tests

Install dev dependencies:

yarn && yarn test

Compile & Minify:

yarn compile

Contributing

Pull requests and stars are always welcome. For bugs and feature requests, please create an issue

1.0.10

4 years ago

1.0.9

4 years ago

1.0.8

4 years ago

1.0.7

4 years ago

1.0.6

4 years ago

1.0.5

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.2

4 years ago

1.0.1

4 years ago