npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

light-string-utils

v1.8.3

Published

A low-level utility library delivering consistency, customization, performance, and extra features for strings

Downloads

71

Readme

Light String Utils

npm npm npm

A light weight utility collection on string. Without any external dependencies.

The unit test cases are generated by our app UnitRunner.app

Happy coding!

Found any bugs/features?

Please feel free to open an issue. I shall be happy to help soon. Click here

Install

$ npm install light-string-utils --save

Usage

// CommonJS
const ltStringUtils = require("light-string-utils"); // OR:
const { length } = require("light-string-utils");

[//]: START GENERATED CODE

abbreviate

Abbreviates a string by returning the first character of each word.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The input string to be abbreviated. |

Returns

{string} - The abbreviated string.

Examples

abbreviate("Hello World"); // Returns "HW"
abbreviate(" "); // Returns ""
abbreviate("test"); // Returns "t"

capitalize

Capitalizes the first letter of a string and converts the rest to lowercase.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The input string to be capitalized. |

Returns

{string} - The capitalized string.

Examples

capitalize("hello world"); // returns "Hello world"
capitalize("hElLo wOrLD"); // returns "Hello world"
capitalize(" A "); // returns "A"
capitalize(""); // returns ""
capitalize(null); // throws Error "Invalid string served"
capitalize(123); // throws Error "Invalid string served"

center

Center aligns the given string within a new string of the specified length, padded with the specified character.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to center align. | | totalStringLength | {number} | none | The total length of the resulting string. | | paddingCharacter | {string} | " " | The character to use for padding. Defaults to a space. |

Returns

{string} - A new string of the specified length, with the original string centered and padded.

Examples

center("Hello World", 20); // Returns "    Hello World     "
center("Hello World", 20, "*"); // Returns "****Hello World*****"

deCapitalize

De-capitalizes the first letter of a string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to de |

Returns

{string} - A new string with the first letter de

Examples

deCapitalize("Hello World"); // Returns "hello World"
deCapitalize(" "); // Returns ""
deCapitalize("test"); // Returns "test"

endsWith

Checks if a string ends with the specified substring.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to center align. | | compareSubString | {string} | none | The substring to compare. |

Returns

{boolean} - A boolean indicating if the string ends with the specified substring.

Examples

endsWith("Hello World", "World"); // Returns true
endsWith("Hello World", "Worlds"); // Returns false
endsWith("Hello World", " "); // Returns false
endsWith("Hello World", "Hello World"); // Returns true

equalsIgnoreCase

Checks if two strings are equal ignoring the case.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str1 | {string} | none | The first string to compare. | | str2 | {string} | none | The second string to compare. |

Returns

{boolean} - A boolean indicating if the strings are equal ignoring the case.

Examples

equalsIgnoreCase("Hello World", "hello world"); // Returns true
equalsIgnoreCase("Hello World", "hello worlds"); // Returns false
equalsIgnoreCase("Hello World", " "); // Returns false
equalsIgnoreCase("Hello World", "Hello World"); // Returns true

escapeHTML

Escapes HTML characters.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to escape. |

Returns

{string} - The escaped string.

Examples

escapeHTML("<p>hello world</p>"); // returns "&lt;p&gt;hello world&lt;/p&gt;"
escapeHTML("hello world"); // returns "hello world"
escapeHTML("hello & world"); // returns "hello &amp; world"
escapeHTML("hello < world"); // returns "hello &lt; world"

first

Returns the first character of a string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to get the first character from. | | characterCount | {number} | 1 | The number of characters to return. |

Returns

{string} - The first character of the string.

Examples

first("Hello World"); // Returns "H"
first(" "); // Returns ""
first("test"); // Returns "t"
first("Hello World", 2); // Returns "He"

isAlNum

Checks if the string contains only alphanumeric characters.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to check. |

Returns

{boolean} - A boolean indicating if the string contains only alphanumeric characters.

Examples

isAlNum("Hello World"); // Returns false
isAlNum("HelloWorld"); // Returns true
isAlNum("HelloWorld123"); // Returns true
isAlNum("Hello World123"); // Returns false

isAlpha

Checks if the string contains only alphanumeric characters.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to check. |

Returns

{boolean} - A boolean indicating if the string contains only alphanumeric characters.

Examples

isAlpha("Hello World"); // Returns false
isAlpha("HelloWorld"); // Returns true
isAlpha("HelloWorld123"); // Returns false
isAlpha("Hello World123"); // Returns false

last

Returns the last character of a string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to get the last character from. | | characterCount | {number} | 1 | The number of characters to return. |

Returns

{string} - The last character of the string.

Examples

last("Hello World"); // Returns "d"
last(" "); // Returns ""
last("test"); // Returns "t"
last("Hello World", 2); // Returns "ld"

length

Returns the length of a string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to get the length of a string. |

Returns

{number} - The length of the string.

Examples

length("Hello World"); // Returns 11
length(" "); // Returns 1
length("test"); // Returns 4

limit

Limits the length of a string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to limit. | | strLimit | {number} | none | The limit of the string. | | padSide | {string} | "right" | The side to pad the string. | | padString | {string} | "..." | The string to pad the string with. |

Returns

{string} - The limited string.

Examples

limit("Hello World", 5); // Returns "Hello..."
limit("Hello World", 4, "left"); // Returns "...Hello "
limit("Hello World", 4, "left", "!!!"); // Returns "!!!Hello"

occurance

Returns the indices of the finding string in the input string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The input string (target string). | | findStr | {string} | none | The finding string. | | caseSensitive | {string} | false | Should it be case sensitive or in |

Returns

{number[]} - The starting indices of the occurances.

Examples

occurance("Hello World!!, Hello all", "Hellow"); // Returns []
occurance("You are great as usual", " "); // Returns [3, 7, 13, 16]
occurance("Contributing to the open source encourages mutual side benefits"); // Returns [3, 8, 13, 16, 45, 61]

pad

Pads a string with another string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to pad. | | side | {string} | none | The side to pad the string (left | right | both). | | padWith | {string} | none | The string to pad the string with. |

Returns

{string} - The padded string.

Examples

pad("Hello World", "left", "!!!"); // Returns "!!!Hello World"
pad("Hello World", "right", "!!!"); // Returns "Hello World!!!"
pad("Hello World", "both", "!!!"); // Returns "!!!Hello World!!!"
pad("Hello World", "both"); // Returns "Hello World"

repeat

repeats a string by defined times.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | item | {item} | none | The input string/number to be repeated. | | times | {number} | 1 | The number of times to repeat the string. | | delimiter | {string} | "" | The delimiter to be used between the repeated strings. |

Returns

{string} - The repeated string.

Examples

repeat("san"); // Returns "san"
repeat("san", 4); // Returns "sansansansan"
repeat("test ", 2); // Returns "test test"

replaceBy

Replaces all the occurrences of a string with another string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to replace. | | searchReplaceObj | {string} | none | The object containing the search and replace strings. |

Returns

{string} - The replaced string.

Examples

replaceBy("{{{Hello}}} {{{World}}}", { "Hello": "Hi", "World": "Earth" }); // Returns "Hi Earth"
replaceBy("{{{Hello}}} World", { "Hello": "Hi" }); // Returns "Hi World"
replaceBy("{{{Hello}}} {{{World}}}", { "Hello": "Hi", "World": "Earth", "Earth": "World" }); // Returns "Hi World"

sentenceCase

Converts a string to sentence case.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to convert. |

Returns

{string} - The converted string.

Examples

sentenceCase("hello world"); // Returns "Hello world"
sentenceCase("hello world."); // Returns "Hello world."

slugify

Converts a string to a slug.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to convert. |

Returns

{string} - The converted string.

Examples

slugify("Hello World"); // Returns "hello-world"
slugify("Hello World!"); // Returns "hello-world"
slugify("Hello World!@#$%^&*()"); // Returns "hello-world"

subString

Returns a substring of a string.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to get the substring from. | | start | {number} | 0 | The index to start the substring from. | | countFromStart | {number} | undefined | The number of characters to return. |

Returns

{string} - The substring of the string.

Examples

subString("Hello World"); // Returns "Hello World"
subString(" "); // Returns " "
subString("Hello World", 2); // Returns "llo World"
subString("Hello World", 2, 3); // Returns "llo"

titleCase

Converts a string to title case.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to convert. |

Returns

{string} - The converted string.

Examples

titleCase("hello world"); // Returns "Hello World"
titleCase("hello world!@#$%^&*()"); // Returns "Hello World!@#$%^&*()"

toArray

Converts a string to an array.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to convert. | | explodeBy | {string} | "" | The separator to use. |

Returns

{string[]} - The converted string.

Examples

toArray("Hello World", " "); // Returns ["Hello", "World"]
toArray("test"); // Returns ["t", "e", "s", "t"]

worldCount

Counts the number of words seperated by spaces or the given seperator.

Parameters

| Name | Type | Default | Description | | ---- | ---- | ------- | ----------- | | str | {string} | none | The string to convert. | | explodeBy | {string} | "" | The separator to use. |

Returns

{number} - The word count.

Examples

worldCount("Hello World", " "); // Returns 2
wc("test me!"); // Returns 2

[//]: END GENERATED CODE

Test

$ npm test

License

This software is released under the MIT License.