- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
目前,我正在尝试在组件内部使用模式来更新组件状态。我能够打开模式,并且能够填写输入值。点击添加按钮后,我希望更新状态并关闭模式。这应该会导致在主 Exercise
组件中显示新数据。
但是,当我尝试添加新行时,进程在 addWorkoutRow
方法中挂起并且没有出现任何错误。按钮变回 Add Workout
但模式不会关闭且状态不会更新。
我曾尝试使用 setState 回调,但没有成功。我很确定我在设置 const newRow
和调用 setModalVisible
函数之间的错误我只是无法退后一步看到它。
import React, {Component} from 'react';
import {Modal, View, StyleSheet, TextInput, Text, TouchableOpacity} from 'react-native';
const ExerciseItem = (name, sets, reps, weight) => (
<View style={styles.exerciseItem}>
<Text style={styles.itemInput}>{name}</Text>
<Text style={styles.itemInput}>{sets}</Text>
<Text style={styles.itemInput}>{reps}</Text>
<Text style={styles.itemInput}>{weight}</Text>
</View>
);
class Exercise extends Component {
constructor() {
super();
this.state = {
showCustomForm: false,
showWeightsForm: !this.showCustomForm,
modalVisible: false,
rows: [],
counter: 0,
}
this.addWorkoutRow = this.addWorkoutRow.bind(this);
}
setModalVisible(visible) {
this.setState({modalVisible: visible})
}
addWorkoutRow() {
const name = this.name._lastNativeText;
const sets = this.sets._lastNativeText;
const reps = this.reps._lastNativeText;
const weight = this.weight._lastNativeText;
const newRow = { name, sets, reps, weight };
const rows = this.state.rows;
rows.push(newRow);
this.setState({ rows });
this.setModalVisible(!this.state.modalVisible);
}
render() {
const rows = []
for (let i = 0; i < this.state.rows.length; i += i) {
rows.push(<ExerciseItem
key={i}
name={this.state.rows[i].name}
sets={this.state.rows[i].sets}
reps={this.state.rows[i].reps}
weight={this.state.rows[i].weight}
/>);
}
return (
<View style={styles.container}>
<Text style={{fontSize: 20, color: '#fff', fontWeight: 'bold' }}>Workout</Text>
<Modal
style={styles.modalContainer}
animationType="fade"
transparent
visible={this.state.modalVisible}
onRequestClose={() => console.log('closed')}
presentationStyle="overFullScreen"
>
<TextInput
ref={(input) => { this.name = input; }}
style={styles.modalInputs}
placeholderTextColor={'#fff'}
placeholder={'Exercise Name'} />
<TextInput
ref={(input) => { this.sets = input; }}
style={styles.modalInputs}
placeholderTextColor={'#fff'}
placeholder={'Sets'} />
<TextInput
ref={(input) => { this.reps = input; }}
style={styles.modalInputs}
placeholderTextColor={'#fff'}
placeholder={'Reps'} />
<TextInput
ref={(input) => { this.weight = input; }}
style={styles.modalInputs}
placeholderTextColor={'#fff'}
placeholder={'Weight'} />
<TouchableOpacity
onPress={() => this.addWorkoutRow()}
style={styles.modalBtn}>
<Text style={styles.drkContent}>+</Text>
</TouchableOpacity>
</Modal>
{rows}
<View style={styles.btnContainer}>
<TouchableOpacity
onPress={() => this.setModalVisible(!this.state.modalVisible)}
style={styles.btns}>
<Text style={styles.drkContent}>Add Workout</Text>
</TouchableOpacity>
</View>
</View>
)
}
}
export default Exercise
这是我的 package.json
{
"name": "PresentApp",
"version": "0.0.1",
"private": true,
"scripts": {
"start": "node node_modules/react-native/local-cli/cli.js start",
"test": "jest",
"lint": "eslint ./components"
},
"dependencies": {
"babel-eslint": "^8.2.1",
"eslint": "^4.17.0",
"eslint-config-airbnb": "^15.1.0",
"eslint-config-prettier": "^2.9.0",
"eslint-plugin-import": "^2.8.0",
"eslint-plugin-jsx-a11y": "^5.1.1",
"eslint-plugin-react": "^7.6.1",
"prettier": "^1.10.2",
"prop-types": "^15.6.0",
"react": "16.0.0",
"react-native": "0.50.4",
"react-native-router-flux": "^4.0.0-beta.24",
"react-native-sound": "^0.10.4"
},
"devDependencies": {
"babel-jest": "21.2.0",
"babel-preset-react-native": "4.0.0",
"eslint-plugin-prettier": "^2.6.0",
"firebase": "^5.0.4",
"jest": "21.2.1",
"react-test-renderer": "16.0.0"
},
"jest": {
"preset": "react-native"
}
}
最佳答案
在你的 for 循环中,你像这样递增 i += i
。这会导致无限循环。这就是您的组件卡在渲染中的原因。将 for 循环增量更改为 i += 1
。
关于javascript - 如何使用 React refs、回调模式来更新状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52682626/
我想读取帖子的数据并获取用户 key ,然后通过它进行搜索并同时获取用户数据,我尝试过,但它后退了一步,直到它才显示用户名我执行任何其他操作 这是帖子和经过身份验证的用户的 Firebase 实时数据
您知道是否有办法将 js ref 和 css ref 作为单个 ref 包含在 html 中?通常这些 ref 单独包含在 html head 中,但我的经理想知道下游消费者是否有一种简化的方法将这些
我正在使用 Swing+Clojure 开发一个 GUI 应用程序,它需要各种可变数据(例如滚动位置、用户数据、文件名、选定的工具选项等)。 我至少可以看到三种不同的处理这组数据的方式: 创建对所有数
我正在尝试通过 React 使用 ref 属性。我的浏览器出现奇怪的错误,但我无法弄清楚问题出在哪里。谁能向我解释一下为什么我会收到此错误: Error: Invariant Violation: a
在我的程序中,我有模板类,这些模板类主要是用于特殊目的 std::function 的包装器。最小的例子是: template class Foo { public: exp
如果被引用为参数的对象在函数中被修改,是否使用 ref 有关系吗?下面两个函数有区别吗? void DisposeObject(ClassThing c) { c.Dispose(); } vo
尝试将大型但线性的 svn 存储库迁移到 git。 svn 存储库没有标准布局(主干、分支、标签)...只有主干的一个目录。 Ubuntu 12.4 LTS,git 1.7.9.5。 $ git sv
您现在如何设置动态引用? 我收到一个错误 cannot set property of 'test' undefined ,如果我使用 this.someRef['test'] = ref;}/>
试图理解 gerrit 中的 refs/for/refs/* 功能。这个问题与 refs/for/master 无关。 我们什么时候可以使用这个 refs/for/refs/* 功能。 有人可以为此解
我以不同的方式调用 4 种方法时得到不同的结果: static void Main(string[] args) { var emp = new Employee { Name = "ABC"
假设我有以下内容: var t = typeof(Foo).MakeByRefType(); 有没有办法将结果转换回typeof(Foo)? 老实说,我发现的唯一方法是: var t = typeof
我以下列方式使用 ref。那么当在第 5 种方法中创建一个新对象时,是否会一直访问 main 方法中的原始 emp 并在那里创建一个新对象? 如果是,有没有一种方法可以实现相同的功能而无需多次迭代,即
我在文档的 html 标签内有一些文本。文字看起来像这样 I need this text <ref> Some unwanted text </ref> I need thi
一些背景: 前几天我遇到了一些事情,这让我开始思考嵌套函数调用中的重载解析。考虑以下代码: #include void printer(const int &a) { std::cout <<
如果直接从 this.refs 获取元素对象,那么为什么要使用 ReactDOM.findDOMNode? var HelloMessage = React.createClass({ click:f
我在这里做错了什么,或者从 C# 7.2 开始,不支持通过 ref 返回并允许设置的索引器? 作品: public ref byte this[int index] { get { r
看来我现在几乎每天都在这里问问题。我不确定这是好事还是坏事... 今天的“WTF flavor ”涉及我在使用来自 NI Measurement Studio 对象的函数时完全和完全无能为力。与我之前
这个问题在这里已经有了答案: Does foreach() iterate by reference? (10 个答案) Alternative to using ref in foreach? (
给定一个函数声明 dynamic DoSomething(dynamic inputObject) 我可以用枚举调用它作为inputObject: MyEnum myEnum; myEnum = Do
如果我将数组传递给函数并在函数内对数组进行更改,则函数外部存在的数组会反射(reflect)这些效果。例如: var myArr = [1, 2, 3]; function popAll(arr) {
我是一名优秀的程序员,十分优秀!