Реагировать | Items.map не является функцией
Я использую Downshift, чтобы создать раскрывающийся список, который отображает некоторые пункты меню. Я создал повторно используемый компонент React с понижением, но теперь я получаю эту ошибку:
Uncaught TypeError: items.map is not a function
at IconDropdown.react__WEBPACK_IMPORTED_MODULE_2___default.a.createElement.react__WEBPACK_IMPORTED_MODULE_2___default.a.createElement (index.jsx:29)
Вот код, к которому относится эта ошибка:
{isOpen ? (
<div className="dropdown-menu">
{items.map(item => ( // Specifically this map
<button
type="button"
{...getItemProps({ item })}
key={item}
className="dropdown-item"
>
<Icon icon={item.icon} /> {item.name}
</button>
))}
</div>
) : null}
И я использую его в моем основном компоненте экрана, как это:
items = {
editUser: {
name: 'Edit Info',
icon: 'pencil-square-o'
},
changePassword: {
name: 'Change Password',
icon: 'lock'
},
deleteUsed: {
name: 'Delete user',
icon: 'trash-o'
}
};
render() {
return (
<IconDropdown items={this.items} />
)}
Ожидаемое поведение: визуализировать список пунктов меню с соответствующими значками.
Текущее поведение: я получаю вышеуказанную ошибку. Я не уверен, что не так с этим кодом. На моих глазах это правильно.
Я могу опубликовать весь компонент, если хотите, просто дайте мне знать.
ОБНОВЛЕНИЕ, весь раскрывающийся компонент:
import React, { Fragment } from 'react';
import PropTypes from 'prop-types';
import Downshift from 'downshift';
import Icon from 'lenses/common/components/Icon';
import './styles.scss';
const IconDropdown = ({ items, ...otherProps }) => (
<Fragment>
<Downshift {...otherProps}>
{({ getItemProps, isOpen, toggleMenu }) => (
<div>
<div className="btn-group">
<button
id="my-select"
type="button"
className="btn btn-primary dropdown-toggle dropdown-toggle-split"
onClick={toggleMenu}
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded={isOpen}
>
<span className="sr-only">Toggle Dropdown</span>
</button>
{isOpen ? (
<div className="dropdown-menu">
{items.map(item => (
<button
type="button"
{...getItemProps({ item })}
key={item}
className="dropdown-item"
>
<Icon icon={item.icon} /> {item.name}
</button>
))}
</div>
) : null}
</div>
</div>
)}
</Downshift>
</Fragment>
);
IconDropdown.propTypes = {
items: PropTypes.shape({
name: PropTypes.string.isRequired,
icon: PropTypes.string
})
};
export default IconDropdown;
4 ответа
.map
не существует из объекта {}
, он существует только из массива []
, Вы можете:
- Измените ваш объект на массив
- использование
Object.keys(items).map(...)
- использование
lodash.map
Попробуй поставить Object.keys(objectname)
прежде чем вы массив карты.
Для работы функции карты необходим массив с Object.keys(objectname)
, вы превратите объект {}
в действительный массив []
для карты.
Object.keys(items).map(item => ...
Вы повторяете object
это должно быть array
Просто поменяй
items = {
editUser: {
name: 'Edit Info',
icon: 'pencil-square-o'
},
changePassword: {
name: 'Change Password',
icon: 'lock'
},
deleteUsed: {
name: 'Delete user',
icon: 'trash-o'
}
};
К
items = [{
name: 'Edit Info',
icon: 'pencil-square-o'
},{
name: 'Change Password',
icon: 'lock'
},{
name: 'Delete user',
icon: 'trash-o'
}
];
Или вы можете использовать items.enteries.map
перебирать объект
items
это не массив. Проверьте пост о том, как отобразить объект здесь
Другим решением было бы объявить элементы в виде массива:
items = [
{
name: 'Edit Info',
icon: 'pencil-square-o'
},
{
name: 'Change Password',
icon: 'lock'
},
{
name: 'Delete user',
icon: 'trash-o'
}
];