handyutility
v1.0.1
Published
a set of Javascript supplements utilities and functions
Downloads
31
Maintainers
Readme
Installation
You can install Handy Utility using npm:
npm install handyutility
Alternatively, you can use the CDN script to include the hu.min.js
in your HTML file
<script src="https://unpkg.com/browse/handyutility@latest/dist/hu.min.cjs"></script>
Alternatively, you can use the CDN script to include the hu.min.js
in your HTML file
<!-- VIA: jsdelivr CDN -->
<script src="https://cdn.jsdelivr.net/npm/handyutility@latest/dist/hu.min.js"></script>
<!-- VIA: unpkg CDN -->
<script src="https://unpkg.com/handyutility@latest/dist/hu.min.js"></script>
Otherwise, you can download the hu.min.js
file from the dist directory and include it in your HTML file, or click here to download it directly
<script src="path/to/hu.min.js"></script>
Usage
Once you have installed or included the hu.min.js file, you can start using the functions in your code.
// Import the handyutility
import Utils from "handyutility";
// explicitly use the handy, operators and promises ...
import { Handy, Operators, Promises } from "handyutility"
Utils.handy.IPify().then((ip) => {
console.log(ip);
});
Handy.IPify().then((ip) => {
console.log(ip);
});
Utilities
Handy
Utils.handy.IPify()
Retrieve the IP address of the current machine.
const url = new URL("https://www.google.com/search?q=handyscript");
Utils.handy.searchParamsSerializer(url: URL) // {q: "handyscript"}
Extract the search params from a URL
There is more to discover ✨
Operators
Utils.operators.is(1, 1) // true
Utils.operators.is("hello", "hi") // false
// Objects are compared by their keys recursively
const obj1 = {name: "john", age: 20};
const obj2 = {name: "john", age: 20};
Utils.operators.is(obj1, obj2) // true
// Functions and Regular expressions are compared by their source code
const fn1 = () => console.log("hello");
const fn2 = () => console.log("hi");
Utils.operators.is(fn1, fn2) // false
const reg1 = /hello/;
const reg2 = /hi/;
Utils.operators.is(reg1, reg2) // false
// Dates are compared by their millisecond representation
const date1 = new Date();
const date2 = new Date(date1.getTime());
Utils.operators.is(date1, date2) // true
The is
function is used to compare values if they are truly equal
There is more to discover ✨
Promises
async function simulateAsyncOperation(attempt: number): Promise<number> {
const randomSuccess = Math.random() < 0.5; // Simulate a success or failure randomly
if (randomSuccess) {
return attempt;
} else {
throw new Error(`Attempt ${attempt} failed`);
}
}
async function main() {
const maxAttempts = 5;
const delayMs = 1000;
try {
const result = await Utils.promises.retry(async () => {
const attempt = await simulateAsyncOperation(1); // Start with the first attempt
if (attempt < maxAttempts) {
throw new Error('Retry');
}
return attempt;
}, maxAttempts, delayMs);
console.log(`Operation succeeded on attempt ${result}`);
} catch (error) {
console.error(`Operation failed: ${error.message}`);
}
}
main();
The retry
function facilitates robust handling of transient failures in asynchronous operations, employing exponential backoff with a specified maximum retry limit
There is more to discover ✨
Contributing
Contributions are welcome, feel free to submit a pull request or an issue.