Here comes the official

preface:

There are a lot of tool function libraries, all kinds of libraries also need not say more, the project requirements of the tool function can basically find from the edge of the function library, as for why I want to write the tool function, after careful consideration summed up the following two reasons:

1, to find the sense of existence + realize the value, I always let the things I write there is my own code! “Funny”

2. There are so many tools in the tool library that I can’t tell which one I need the most (in short, I can’t use it)

Object array deduplicating:

Array deleveraging is one of the most common methods of array deleveraging. There are very few simple array deleveraging methods

/** * @descriptiong: @param {array} arr * @param {string} key * @returns {arrary} */ function unique(arr,key){ const map = new Map(); return arr.filter(item => { return ! map.has(item[key]) && map.set(item[key],'anything'); }); }Copy the code

Normal array deduplication

Use indexof? Yes, but it doesn’t look good enough

/** * @description: es6Unique(arr) {return array. from(new Set(arr)); }Copy the code

Why? www.runoob.com/jsref/jsref… Go and see for yourself

Mainly from(), which doesn’t allow the same elements to be gay

Let obj = new Set(['a','b','c','c']) let ovjArr = array. from(obj) let obj = new Set(['a','b','c','c'])Copy the code

Input box filter

Front-end retrieval is commonly used, for various reasons, sometimes the back-end will not provide you with a variety of interfaces, for the large amount of data in the table content or need to search function, here side is used in the local fuzzy query

1. Query the specified key name (i.e., the specified column: for example, I only query the username column) : indexOf

/** * @description fuzzy filter object array * @param {string} filterValue Fuzzy query content * @returns {array} */ function filter(filterValue,arr){ const res = arr.filter(item => return item[key].toUpperCase().indexOf(value.toUpperCase()) ! == -1 return res }Copy the code

How to query the contents of multiple columns? Em ~ I want to

2. Match all the fuzzy queries, and this feels nice

/** * @description fuzzy filter object array * @param {string} value Fuzzy query content * @returns {array} */ function filter(value,arr){const res = arr.filter(item =>{ return Object.keys(item).some(key => { return String(item[key]).toLowerCase().indexOf(value) > -1 } }) return res }Copy the code

Fixation of trailer

Object arrays are sorted by specified property values, complex array sorts, parsing parameters in urls, and user authentication

* @param {string} * @returns {array} */Copy the code

To sum up:

This share is about two common methods of reloading and filtering in common environment. I hope we can share some good methods to learn from each other. (In fact, I just want to go whoring, do you let me?)

Wrong character? Don’t blame me, my input method,