Methods:

  • add
  • clear
  • removeIndex
  • removeById
💡 Implementation
Pretty
Copy
const useArray = initial => {
const [value, setValue] = useState(initial);
return {
value,
setValue,
add: useCallback(a => setValue(v => [...v, a]), []),
clear: useCallback(() => setValue(() => []), []),
removeById: useCallback(
id => setValue(arr => arr.filter(v => v && v.id !== id)),
[]
),
removeIndex: useCallback(
index =>
setValue(v => {
v.splice(index, 1);
return v;
}),
[]
)
};
};
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
🚀 Usage
Pretty
Copy
function Demo() {
const todos = useArray(["Item 1"]);
return todos.value.map(todo => <div>{todo}</div>);
}
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
âš¡Preview
Item 1
🚨 console
Contributors