我正在看一些关于 React Hooks 的教程,在教程中,作者创建了一个用于呈现可重用下拉列表的钩子。代码是这样的useDropdown
import React, { useState } from "react";
const useDropdown = (label, defaultState, options) => {
const [state, updateState] = useState(defaultState);
const id = `use-dropdown-${label.replace(" ", "").toLowerCase()}`;
const Dropdown = () => (
<label htmlFor={id}>
{label}
<select
id={id}
value={state}
onChange={e => updateState(e.target.value)}
onBlur={e => updateState(e.target.value)}
disabled={!options.length}
>
<option />
{options.map(item => (
<option key={item} value={item}>
{item}
</option>
))}
</select>
</label>
);
return [state, Dropdown, updateState];
};
export default useDropdown;
他在这样的组件中使用了这个
import React, { useState, useEffect } from "react";
import useDropdown from "./useDropdown";
const SomeComponent = () => {
const [animal, AnimalDropdown] = useDropdown("Animal", "dog", ANIMALS);
const [breed, BreedDropdown, updateBreed] = useDropdown("Breed", "", breeds);
return (
<div className="search-params">
<form>
<label htmlFor="location">
Location
<input
id="location"
value={location}
placeholder="Location"
onChange={e => updateLocation(e.target.value)}
/>
</label>
<AnimalDropdown />
<BreedDropdown />
<button>Submit</button>
</form>
</div>
);
};
export default SomeComponent;
他说,通过这种方式,我们可以创建可重用的下拉组件。我想知道这与定义一个普通的旧Drampdown组件并将道具传递到其中有何不同。在这种情况下,我能想到的唯一区别是,现在我们能够在父组件(即)中获取状态和setState,并直接从那里读取/设置子组件的状态(即组件输出)。然而,这是否被认为是一种反模式,因为我们正在破坏单向数据流?SomeComponentuseDropdown
慕莱坞森
潇湘沐
翻阅古今
相关分类