- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我使用 redux 的 native react 应用程序中,reducers 似乎工作正常,但 UI 不会根据状态修改进行更新。
这是我的 reducer :
const initialState = {
userId: 1,
userName: "nobody",
showIntroOnNextStart: true
}
export default function reducer(state = initialState, action) {
switch(action.type) {
case 'INCREMENT':
let newState = {
...state,
userId: state.userId + 1
};
console.log(newState);
return newState;
}
return state;
}
它将通过以下方式导出和导入:
import userProfile from './userProfile'
export { userProfile }
这是我的连接方法:
export default connect(state => ({
state: state.userProfile
}),
(dispatch) => ({
actions: bindActionCreators(actions, dispatch)
})
)(ApplicationContainer);
所以最终状态是这样的:
在我的应用程序组件的渲染方法中,我将状态传递给子组件:
render() {
const { state, actions } = this.props;
return ....lots of scenes...
<Scene key="home" component={HomeScreen} title="Home" state={state} {...actions} />
在特定的场景组件中,我使用这样的状态:
render(){
const { state, decrement, increment } = this.props;
return (
<View {...this.props} style={styles.container}>
<Text>{state.userId}</Text>
<Button onPress={increment}>Increment</Button>
</View>
);
}
增量操作按预期正常工作,每个 console.log-Output 都显示一个具有正确增量值的新状态对象。
但是 View 不会更新。在 reducer 函数中,状态按预期工作并在每次调用时递增 userId。但在渲染函数中,状态对象值从一开始就保持不变。
这里可能出了什么问题?
当我从 react-native-router-flux 中删除这个 Router-Stuff 时,一切正常。状态将是相同的实例并将被更新。但是一旦将组件封装到路由器的场景中,就不会发生状态更新
最佳答案
从我使用 Redux 的有限时间来看,不渲染的问题通常是对象的引用没有改变。如果你有一个深对象,你需要做深拷贝。我个人喜欢对 React 中的任何状态使用 immutable.js。
您可以尝试缩小问题范围的另一件事是在按增量后调用组件上的 this.forceUpdate()。如果它更新了 View ,那将使您更接近于找出问题所在。
关于javascript - react /归零 : modified state is not updated in view,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37241194/
我有一个表,其中包含带有订单字段的项目,我用这些字段将它们画在树上。 CREATE TABLE items ( menuId INTEGER, itemId INTEGER,
我正在关注这个 YouTube他们使用的教程Modifier.preferredSize()在一个盒子上和 Modifier.preferredHeight()在 Spacer Composable
当删除包含 UserSession.insert 的 if 语句时,一切正常。但是当它被包含时,我们会收到有关无效修饰符的错误。 出了什么问题?谢谢! 服务器/helpers/b.s Meteor.s
我已经为我的 Android 项目构建了一个注释处理器,它使用 JavaPoet 构建了一个源文件。但是,每次我需要对任何 JavaPoet 对象调用 addModifiers 时,Android S
我应该在哪里设置像 CreatedDate、CreatedBy、ModifiedDate、ModifiedBy 这样的字段?我应该将当前用户上下文传递到存储库并将其设置在那里,还是更好的方法是在应用程
我可以以某种方式重构以下代码片段以摆脱 双修饰符声明 ? .block { &__element { rule: value; } &--modifier { rule:
我正在编写一个函数,它接受一个谓词 p 和一个列表。它返回 ([value],[state]),其中第一个列表包含通过 p 的元素,第二个列表包含未通过的元素。但是,当我运行 runState (my
在我的项目中,我使用了 Typescript@4.0.3它运行良好,但现在我将其版本更新为最新 Typescript@4.1.3它给了我很多错误。我无法在文档中找到任何内容,也没有任何想法如何解决此问
我正在开发一个通过表单发送数据的 Rails 应用程序。我想在表单发送之后,但在它被处理之前修改表单的一些“参数”。 我现在拥有的 {"commit"=>"Create", "authentici
我的问题是关于接口(interface)。我创建了一个接口(interface)并定义了四个方法:第一个方法是 private 方法;第二个是 default 方法;第三个是static方法;第四个是
好的,所以我当前正在尝试选择目录中的最新文件(本例中为/FSTP/LOGS),但我想忽略包含字符串“DEBUG - null”但不是字符串的任何文件“DEBUG - MA”或“INFO - MA”。这
正是标题所说的。 Modifier.heightIn(...) 和有什么区别和 Modifier.prefferedHeigh() .在我的试验中,它们似乎以相同的方式工作。有谁知道何时使用什么以及在
我在项目中使用 Android Volley Networking 库。 当我自己将带有 etag 的“if-None-Match”添加到 header 时,我没有得到 304,因为 Volley 还
我一直在阅读一些关于在从服务器发送响应时为 Last-Modified 设置 header 的文章。我了解它的用途,以及如何设置它等。 我也理解传入的 If-Modified-Since header
我一直在浏览 Ivy 文档,但我对默认 ivysettings.xml 有疑问在 ivy.jar 中找到。 我要做的就是将公共(public)存储库更改为我们拥有的本地 Maven 存储库。就是这样。
我是 Ruby 新手。这是一个使用任何语言的编程面试问题。我正在尝试用 Ruby 来做。 编写一个程序来输入给定的句子。用单词的第一个字母/#ofcharactersbetween1st&laSTLe
我收到以下代码A的警告信息,为什么? 可选的 Modifier 参数应具有默认值 Modifier 代码A @Composable fun DisplayIcon( modifier: Mod
假设我想创建一个 Column与最宽的 child 一样宽Text在里面。为此,该列可以使用 .wrapContentWidth() 修饰符或 .width(IntrinsicSize.Max) ,但
我正在尝试用 Javascript 编写实现图形(数据结构)。为此,我有一个名为 Graph 的函数将该矩阵存储在名为 this.adjMatrix 的属性中的二维数组中。它还有很多方法。 我还想创建
即使在 Google PageSpeed(97) 和 Yahoo! YSlow(92) PHP 生成的缩略图似乎并不是被动地从旧缓存中获取的:它们似乎每次都生成......又一次......新鲜出炉,
我是一名优秀的程序员,十分优秀!