- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我在 redux 中的初始状态
Cereal :[{grainId: "", amount: "0.0"}],
我试图让我的表单序列化为类似的东西,但我找不到一种方法让 Cereal 成为外部对象。我想知道它是否可能,或者我是否必须手动重新创建该对象。或者只是从商店获取状态。
我的表单如下所示:
<select
name='grainId'
value={this.props.value}
>
...options
</select>
<input
type="text"
name='amount'
value={this.props.value}
/>
然后有一个添加颗粒按钮,它将在该状态下将另一个对象添加到数组中,然后在页面上呈现表单的另一部分。无论如何,是否可以将每个“Grain”部分包装在表单元素中,以便很好地序列化?
如果不是,我可以在表单提交上发布商店的状态吗?这是不好的做法吗?
最佳答案
由于您已经从 redux 状态加载初始表单数据,因此我认为让表单在 Redux 状态发生变化时更新它是有意义的。使用这种方法,每个输入chnage都会触发Redux状态的更新,然后该状态将被传递到组件(通过mapStateToProps),并导致重新渲染显示新值。这样,您就可以确保在您的 reducer 中,状态始终具有您喜欢的形状( {grains: [{grainId: "", amount: "0.0"}, etc... ]
)。
就像你暗示的那样,这意味着当你最终提交时,你基本上是在提交 Redux 表单状态(或者至少是从它传递下来的 props)。
看起来像这样(可运行JSFiddle demo here):
class App extends React.Component {
renderGrains() {
const {grains, changeGrain} = this.props;
return grains.map((grain, index) => (
<div key={ index }>
<input
type="text"
value={grain.grainId}
onChange={({target:{value}}) => changeGrain(index, 'grainId', value)}
/>
<input key={ grain.grainId + 'amount' }
type="number"
value={grain.amount}
onChange={({target:{value}}) => changeGrain(index, 'amount', value)}
/>
<br />
</div>
));
}
render() {
const {addEmptyGrain, grains} = this.props;
const onSubmit = (e) => {
e.preventDefault();
alert('submitting: \n' + JSON.stringify({grains}, null, 2));
};
return (
<form>
{ this.renderGrains() }
<button onClick={ (e) => { e.preventDefault(); addEmptyGrain();} }>Add grain</button><br />
<button onClick={onSubmit}>Submit</button>
</form>
);
}
}
reducer 看起来像这样:
const r1_initialState = { grains: [{grainId: "", amount: 0.0}] };
const reducer1 = (state = r1_initialState, action) => {
switch(action.type) {
case CHANGE_GRAIN:
const {index, key, newValue} = action;
const grainsCopy = [...state.grains];
grainsCopy[index][key] = newValue;
return {...state, grains: grainsCopy};
case ADD_EMPTY_GRAIN: {
return {...state, grains: [...state.grains, {grainId: '', amount: 0.0}]}
}
default:
return state;
}
};
如果这看起来工作量太大,但您仍然希望将表单数据保持在 Redux 状态,可以使用像 redux-form
这样的库。 ,它处理表单的 onChange 等重复处理。
另一种选择是从 Redux 加载初始状态,但仅使用它来设置组件的内部状态。然后将所有表单更改作为组件状态的更改进行处理。与上例中的逻辑相同的逻辑可用于渲染数组中的字段。
关于javascript - 将动态形式序列化为对象数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46333025/
出于好奇,我尝试了一些原型(prototype)制作,但似乎只允许在第一个位置使用子例程的原型(prototype) &。 当我写作时 sub test (&$$) { do_somethin
我需要开发一个类似于 Android Play 商店应用程序或类似 this app 的应用程序.我阅读了很多教程,发现几乎每个教程都有与 this one 类似的例子。 . 我已经开始使用我的应用程
考虑一个表示“事件之间的时间”的列: (5, 40, 3, 6, 0, 9, 0, 4, 5, 18, 2, 4, 3, 2) 我想将这些分组到 30 个桶中,但桶会重置。期望的结果: (0, 1,
我是一名优秀的程序员,十分优秀!