- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个reducer
import { FETCH_WEATHER } from "../actions/index";
export default function(state = [], action) {
switch (action.type) {
case FETCH_WEATHER:
console.log(state)
return [action.payload.data,...state];
default:
return state
}
}
但每当我控制台记录 state
结果总是 undefined
这是我的action
import axios from 'axios';
const API_KEY = '...';
const ROOT_URL = `...`
export const FETCH_WEATHER = 'FETCH_WEATHER';
export function fetchWeather(city){
const url = `${ROOT_URL}&q=${city},us`;
const request = axios.get(url)
return {
type : FETCH_WEATHER,
payload: request,
}
}
我正在考虑创建一个常量来保存整体数据并将其传递给 reducer,但我认为这不是正确的方法。
问题:我如何访问 reducer 中的先前状态,以便每当我 console.log
时都有一个值。
这是代码 codesandbox
最佳答案
先前的状态存储在您的 state
变量中,如您的 reducer 中所定义。因此,可以通过 state
变量在您的 reducer 中访问以前的状态。
看起来您有可能导致问题的 block 语法错误(请参阅下面的更正)。
此外,如果您想在 reducer 运行时将之前的状态记录到控制台,请考虑在 reducer 的开头调用 console.log
:
import { FETCH_WEATHER } from "../actions/index";
export default function(state = [], action) {
// console.log(state) // Add this to log previous state for every call to reducer
switch (action.type) {
case FETCH_WEATHER: { // Added { here
console.log(state)
return [action.payload.data,...state];
} // Added } here
default:
return state
}
}
关于javascript - 如何在 React Redux 中获取状态的先前值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51852651/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!