Redusance - A Renaissance in Array Reduction
Welcome to Redusance, where the art of array manipulation undergoes its own Renaissance! Inspired by the transformative era of innovation and creativity, Redusance is a modern JavaScript library designed to extend and enhance the capabilities of the traditional reduce
function. Our aim is to provide developers with an array of ingenious, efficient, and easy-to-use reduce helpers, bringing a new level of artistry to your coding toolkit.
- Enhanced Reduce Operations: Discover a range of extended reduce functions like
toAvg
,toGroups
,toMax
, and more, each crafted to provide more power and flexibility than standard reduce methods. - Elegant Syntax: Designed with the modern developer in mind, Redusance utilizes a concise and intuitive syntax, making your code more readable and maintainable.
- High Performance: Optimized for efficiency, our library ensures high performance even with large datasets.
- Easy Integration: Seamlessly integrates with your existing JavaScript projects, enhancing your development without the need for a steep learning curve.
To get started with Redusance, simply install the package in your JavaScript project:
npm install redusance
Then, import and use our reduce helpers in your project:
import { toAvg, toGroups, toMax } from 'redusance';
// Example usage
const numbers = [1, 2, 3, 4, 5];
const average = numbers.reduce(...toAvg());
const groups = numbers.reduce(...toGroups((item: number) => item % 2 === 0 ? "even" : "odd"));
const max = numbers.reduce(...toMax());
toGroups
groups elements of an array into categories based on a provided grouping function.toDistinct
filters non-unique elements of an array based on the value or a provided unique key function.For an array containing elements other than string/numeric/symbol you have to provide the unique key function.
toSum
calculates the sum of all elements in an array of numbers.toAvg
calculates the average (mean) of elements in an array of numbers.toMedian
calculates the median of in an array of numbers.toMax
finds the maximum value in an array of numbers.toMin
finds the minimum value in an array of numbers.
While libraries like Lodash offer their own powerful and flexible method chaining capabilities, Redusance focuses on enhancing the native JavaScript experience. Lodash provides a comprehensive suite of utilities that extend beyond what native JavaScript offers, but it requires adherence to its own syntax and methods.
Benefits of Redusance
- Native JavaScript Integration: Redusance complements the existing JavaScript array methods, making it intuitive for those familiar with JavaScript.
- Specialized Reduce Helpers: Offers a range of tailor-made reduce helper functions that provide additional functionalities not natively present in JavaScript.
- Minimal Dependency: Ideal for projects aiming to reduce external dependencies while still enhancing array manipulation capabilities. Redusance has no other runtime dependencies.
- Performance: Optimized to work efficiently with JavaScript's native methods, potentially offering performance benefits in certain scenarios.
In Redusance, each helper function is designed to return two separate elements: a reducer function and an initial value. This design necessitates the use of the spread syntax (...
) for proper integration with the reduce
method of arrays in JavaScript.
Our helper functions, such as toAvg
, are structured to return a tuple containing two elements:
- Callback Function: The main logic to apply on the array.
- Initial Value: The starting point for the reduce operation.
For example:
function toAvg() {
// Returns a reducer function and an initial value
return [callbackFunction, initialValue];
}
We welcome contributions to Redusance! If you're interested in helping improve this project, here's how you can get involved:
Submitting Issues: If you find a bug or have a feature request, please use the GitHub Issues page to submit them. Be as detailed as possible for bug reports, including steps to reproduce the issue.
Submitting Pull Requests: We're open to pull requests. If you've fixed a bug or implemented a new feature, feel free to submit a PR. Please ensure your code adheres to the existing style of the project to increase the chances of your PR being merged.
Code Reviews: Even if you're not contributing code, you can help by reviewing pull requests. Any feedback or suggestions are valuable and help maintain the quality of the code.
Documentation: Improvements or additions to documentation are always appreciated. Whether it's correcting typos, clarifying existing content, or adding new sections, your contributions make the project more accessible to everyone.
Thank you for considering contributing to Redusance. We're excited to see what you bring to the project!
Redusance is open-source software licensed under the MIT License.