Я следовал руководству по настройке redux-thunk, чтобы я мог получить геолокацию пользователей, а затем отправить и обновить состояние. Однако каждый раз, когда я пытаюсь отправить действие с данными ответа, он просто устанавливает для этих данных значение null.
Когда я пытаюсь смоделировать вызов API с тайм-аутом и устанавливать некоторые случайные значения, он работает без проблем.
geoLocationActions.js
export function geoLocationActions() {
return dispatch => {
const geolocation = navigator.geolocation;
geolocation.getCurrentPosition((position) => {
console.info(position.coords);
dispatch({
type: 'FETCH_USER_LOCATION_SUCCESS',
payload: position
});
});
}
};
MapContainer.js
import React from "react";
import { geoLocationActions } from '../../../actions/geoLocationActions';
import { connect } from 'react-redux';
class MapContainer extends React.Component {
componentWillMount() {
this.props.geoLocationActions();
}
render() {
return (
<div>
<p>Fetching location...</p>
</div>
);
}
}
// update current geolocation state
const mapDispatchToProps = (dispatch) => {
return {
geoLocationActions: () => dispatch(geoLocationActions())
};
}
const mapStateToProps = (state) => {
return {
state: state
};
};
export default connect(mapStateToProps, mapDispatchToProps)(MapContainer);
redurs.js
case 'FETCH_USER_LOCATION_SUCCESS':
return {
...state,
userLocation: action.payload
}
store.js
import { createStore, combineReducers, applyMiddleware, compose } from
'redux';
import reducer from '../reducers/reducers';
import reduxThunk from "redux-thunk";
const rootReducer = combineReducers({
state: reducer
});
export const store = createStore(
rootReducer,
compose(
applyMiddleware(reduxThunk),
window.devToolsExtension ? window.devToolsExtension() : f => f
)
);
да! Верно, поэтому мне это кажется очень странным.
Вставьте console.info() в редуктор. Это называется? Затем добавьте console.info(this.props) в вашу функцию рендеринга, это вызывается?





Получается объект HTML5 Geoposition. Вам нужно преобразовать его в обычный объект, который можно сериализовать с помощью JSON.stringify. Вы можете использовать этот метод:
const geopositionToObject = geoposition => ({
timestamp: geoposition.timestamp,
coords: {
accuracy: geoposition.coords.accuracy,
latitude: geoposition.coords.latitude,
longitude: geoposition.coords.longitude
}
})
Обновите файл geoLocationActions.js следующим образом:
export function geoLocationActions() {
return dispatch => {
const geolocation = navigator.geolocation;
geolocation.getCurrentPosition((position) => {
const positionObj = geopositionToObject(position)
console.info(positionObj);
dispatch({
type: 'FETCH_USER_LOCATION_SUCCESS',
payload: positionObj
});
});
}
};
Вы можете взглянуть на мое репо, чтобы увидеть тот же код.
Вы видите
console.info(position.coords);в своей консоли?