首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >react钩子道具再次未定义

react钩子道具再次未定义
EN

Stack Overflow用户
提问于 2021-07-19 16:07:48
回答 2查看 45关注 0票数 0

我正在尝试从我的App.js发送一个硬编码的数组到一个叫做'Select‘的组件。它看起来和我正在学习的教程一模一样。也许其他人可以看到我做错了什么。

状态变量'categories‘在App.js中定义,在select.js中未定义

代码语言:javascript
复制
import {useState} from "react";
import Header from "./components/header";
import Select from "./components/select.js";


function App(){
    const [categories, setCategories] = useState([
            {
                id: 1,
                name:'Restaurant',
                pros:['Great Menu, good food, Great Beer list, live music'],
                cons:['Bad acoustics, bad service, rude staff, over priced']
            },
            {
                id: 2,
                name:'Music Venue',
                pros:['Good seating, Music Variety, Good Dance Floor, Good Bar, Good Food'],
                cons:['Bad acoustics, bad crowd, small space, over priced']
            },
            {
                id: 3,
                name:'Hiking Trail',
                pros:['Spectacular Scenery, Great Destination, Swimming, Drinking Water'],
                cons:['Crowded, Horses/Bicycles, Burn Zone, Biting Bugs']
            }
        ]);    
    
    return(
        <div className="container">
            
            <Header />
             
            {categories.length > 0 ?
              <Select options={categories}
              />:' No Options'}
            
        </div>
    )
}
export default App;
代码语言:javascript
复制
import Option from "./option.js"

const Select = ({categories}) => {
    
   
  {console.log(categories)}
    return (
        <>
        
            <select name="selectCat" id="selectCat">

            <option value="" defaultValue>Choose a Category</option>
            
            {categories && categories.map((option) => (
            
            <Option key={option.id} text={option.name}/>))}
            </select>
            </>
        
    )
}

export default Select

提前感谢

EN

回答 2

Stack Overflow用户

发布于 2021-07-19 16:11:41

您正在传递错误的属性名称。将options更改为categories

代码语言:javascript
复制
<Select 
   categories={categories} <- here
 />:' No Options'}
票数 0
EN

Stack Overflow用户

发布于 2021-07-19 16:11:45

代码语言:javascript
复制
import Option from "./option.js"

const Select = ({categories}) => {
    
   
  {console.log(categories)}
    return (
        <>
        
            <select name="selectCat" id="selectCat">

            <option value="" defaultValue>Choose a Category</option>
            
            {categories && categories.map((option) => (
            
            <Option key={option.id} text={option.name}/>))}
            </select>
            </>
        
    )
}

export default Select

您传递的是选项,但却在破坏类别。因此,请尝试解构选项。

代码语言:javascript
复制
const Select = ({options}) => {
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68437110

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档