리액트 훅으로, 상태로 Set을 관리해요. 효율적인 상태 관리를 제공하고 안정적인 액션 함수를 제공해요.
function useSet<T>(
initialState?: SetOrValues<T>
): [Omit<Set<T>, 'add' | 'clear' | 'delete'>, SetActions<T>];<Interface name="" type="[Set, SetActions]" description="Set 상태와 이를 조작하는 액션을 포함한 튜플이에요." :nested="[ { name: '[0]', type: 'Omit<Set, "add" | "clear" | "delete">', required: false, description: '변경 메서드가 숨겨진 현재 Set 상태예요.', }, { name: '[1].add', type: '(value: T) => void', required: false, description: 'Set에 값을 추가해요.', }, { name: '[1].remove', type: '(value: T) => void', required: false, description: 'Set에서 값을 제거해요.', }, { name: '[1].toggle', type: '(value: T) => void', required: false, description: '값이 없으면 추가하고, 있으면 제거해요.', }, { name: '[1].setAll', type: '(values: Set | T[]) => void', required: false, description: 'Set의 모든 값을 교체해요.', }, { name: '[1].reset', type: '() => void', required: false, description: 'Set을 초기 상태로 리셋해요.', }, ]" />
function TagSelector() {
const [selectedTags, { add, remove, toggle }] = useSet<string>(['react']);
return (
<div>
{['react', 'vue', 'svelte'].map(tag => (
<button key={tag} onClick={() => toggle(tag)}>
{selectedTags.has(tag) ? '✓' : ''} {tag}
</button>
))}
</div>
);
}