В моем решении, являющемся проектом ASP.NET Core с компонентами React, Redux и Kendo React, мне нужно возвращать свои реквизиты в виде массива.Я использую виджет Kendo Dropdown, как показано ниже.
<DropDownList data={this.props.vesseltypes} />
Однако я получаю сообщение об ошибке:
Ошибка типа проп: недопустимая поддержка data
типа object
передано DropDownList
, ожидаемое array
.
Итак, я проверил свои возвращенные данные из props.vesseltypes
, который является массивом, а не плоским массивом.
Вот мой код для возврата этих данных:
компоненты / сосуды / 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 {
componentWillMount() {
this.props.requestTypes();
}
render() {
console.log(this.props.vesseltypes)
return (
<div>
<DropDownList data={this.props.vesseltypes} />
</div>
);
}
}
export default connect(
vesseltypes => vesseltypes,
dispatch => bindActionCreators(actionCreators, dispatch)
)(WidgetData);
components / store / 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;
};
И, наконец, в хранилище определен редуктор
components / store / configureStore.js
const reducers = {
vesseltypes: Types.reducer
};
Controllers / KendoDataController.cs
[HttpGet]
public JsonResult GetVesselTypes()
{
var types = _vesselTypeService.GetVesselTypes();
return Json(types);
}
Итак, виджет выпадающий ожидает массив, который я возвращаю через магазинмассив объектов.Таким образом, это не может быть использовано раскрывающимся списком, потому что это не то, что он ожидает.У меня вопрос, как я могу вернуть это как один массив или плоский массив?