У меня есть проект ASP.NET Core с React и Redux, я также использую интерфейс Kendo React. Я пытаюсь вернуть данные одному из моих виджетов Kendo, но у меня появляется ошибка, когда я пытаюсь это сделать, и мне нужна помощь, чтобы определить, что я сделал неправильно.
Когда я запускаю свое приложение, я получаю сообщение об ошибке:
1 из 2 ошибок на странице TypeError: data.findIndex не является функцией
DropDownList / _this.renderDropDownWrapper
C: /Users/Allan/node_modules/@progress/kendo-react-dropdowns/dist/es/DropDownList/DropDownList.js: 83
80 | var focus = _this.state.focused; 81 | var открыл =
_this.props.opened! == undefined? _this.props.opened: _this.state.opened; 82 | значение переменной = _this.value;
83 | var selectedIndex = data.findIndex (function (i) {return areSame (i, value, dataItemKey);}); 84 | var text =
getItemValue (value, textField); 85 | var valueDefaultRendering =
(React.createElement ("span", {className: "k-input"}, текст)); 86 |
var valueElement = valueRender! == undefined?
В консоли эта ошибка отображается как:
Предупреждение: сбойный тип опоры: недопустимая опора data
типа string
поставлено на DropDownList
, ожидается array
.
Ошибка имеет смысл, но возвращаемые данные должны быть массивом. Это не так, поскольку, кажется, ничего не возвращает. Так что я сделал что-то не так.
Вот мой код, пожалуйста, обратите внимание, что мои данные поступают из общего хранилища.
компоненты / суда / WidgetData.js
import React, { Component } from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import { actionCreators } from '../../store/Types';
import { DropDownList } from '@progress/kendo-react-dropdowns';
class WidgetData extends Component {
state = {
vesseltypes: ""
};
componentWillMount() {
this.props.requestTypes();
}
render() {
return (
<div>
<DropDownList data={this.state.vesseltypes} />
</div>
);
}
}
export default connect(
state => state.vesseltypes,
dispatch => bindActionCreators(actionCreators, dispatch)
)(WidgetData);
компоненты / магазин / Types.js
const requestVesselTypes = 'REQUEST_TYPES';
const receiveVesselTypes = 'RECEIVE_TYPES';
const initialState = {
vesseltypes: [],
isLoading: false
};
export const actionCreators = {
requestTypes: () => async (dispatch) => {
dispatch({ type: requestVesselTypes });
const url = 'api/KendoData/GetVesselTypes';
const response = await fetch(url);
const alltypes = await response.json();
dispatch({ type: receiveVesselTypes, alltypes });
}
}
export const reducer = (state, action) => {
state = state || initialState;
if (action.type === requestVesselTypes) {
return {
...state,
isLoading: true
};
}
if (action.type === receiveVesselTypes) {
alltypes = action.alltypes;
return {
...state,
vesseltypes: action.alltypes,
isLoading: false
}
}
return state;
};
И, наконец, в магазине определен редуктор
компоненты / магазин / configureStore.js
const reducers = {
vesseltypes: Types.reducer
};
Я протестировал API, чтобы убедиться, что данные есть, и он работает, я записал эти данные на консоль из Types.js
в хранилище и вижу, что они возвращены. Я очень новичок в реакции с редуксом, поэтому я пытаюсь найти свой путь здесь, и любая помощь приветствуется.