redux-immutable-state-invariant
全部标签 在每次表单更新后,从redux-form管理的表单中获取值的正确方法是什么?每次表单更改时,我都需要使用输入到表单中的值来分派(dispatch)一个操作。我当前的解决方案是取出旧值,而不是刚刚更新的值。onFormChange(e){const{fieldValue1,fieldValue2,fieldValue3}=this.props.fields;console.log(fieldValue1.value,fieldValue2.value,fieldValue3.value);}render(){return(//inputshere);}我的另一个解决方案是这个,但我不知道
我使用redux-saga并创建了一个生成器checkUsername来执行API调用。虽然constusername将等于来自API的响应,但我有undefined。function*checkUsername(action){try{constusername=yieldcall(Api.checkUsername,action.username);yieldput({type:actions.USERNAME_CHECK_SUCCEEDED,username});}catch(e){yieldput({type:actions.USERNAME_CHECK_FAILED,mess
我遵循了教程并得出了这个https://jsbin.com/foxoxejilu/1/edit?js,output使用react.js。我对Prop和状态感到困惑。在Note组件的save方法中,这一行做了什么this.props.onChange(this.refs.newText.value,this.props.id)而且我在代码的其他地方没有看到onChange和onRemove函数,这是React的预构建函数吗?React如何知道DOM已更改或删除? 最佳答案 我们可以这样总结正在发生的事情:一位家长(Board)将她的c
我正在使用React/Redux构建一个在某些方面类似于文本编辑器的应用程序。它不完全是一个文本编辑器,但它是相同的通用范例。有一个用于放置新项目的光标。可以添加、选择、删除项目等。我正在努力寻找一种符合redux精神的最佳方式来构建我的reducer。我有单独的状态切片来表示选择状态、文本本身、光标状态和其他设置。我认为“redux”方法是为每个状态切片设置缩减器,独立地改变状态以响应Action。然而,在文本编辑器中,这些状态片比乍看之下更加耦合。当你按下一个键时,有时会在光标所在的位置添加一个字母,并且光标会向前移动。但是,如果选择了文本,则将首先删除所选文本。如果您处于“插入”
我是redux-form的新手,在处理onSubmit时遇到了一个奇怪的问题。当我完全按照此处的redux-form示例设置我的项目时http://redux-form.com/6.7.0/examples/syncValidation/它按预期工作。我试图根据我的需要扩展这个示例,并确认它在加载表单时按预期工作,如下所示:路由组件>表单。当我尝试在通过路由(路由组件>容器组件>表单)加载的react组件中加载表单时,问题就出现了。当我点击提交时,字段值被添加到地址栏并且表单验证不运行。我已经尝试了我能想到的一切来解决这个问题。如果替换,下面提供的代码将正常工作与在index.js中。
我有以下类(class)classMatchBoxextendsReact.Component{constructor(props){super(props);this.countdownHandler=null;this.showBlocker=true;this.start=this.start.bind(this);}start(){...}render(){...return(...);}};functionmapStateToProps(state){...}functionmatchDispatchToProps(dispatch){...}exportdefaultwit
我使用reduxsaga创建应用程序,但我遇到了地理定位问题。实际上我找到了解决方案,但我不明白它是如何工作的。functionuserPositionPromised(){constposition={}if(navigator.geolocation){navigator.geolocation.getCurrentPosition(location=>position.on({location}),error=>position.on({error}),{enableHighAccuracy:true})}return{getLocation:()=>newPromise(loc
我正在尝试在带有reactjs和flux的项目中使用Immutable。假设我有一个包含代码的.js文件console.log(Immutable.Map({1:2}).toString())我将此脚本浏览器化并从浏览器(GoogleChrome)运行它,结果是:"Map{"1":2}"请注意,键1现在是字符串,而不是数字。如果我直接在站点的控制台中尝试相同的代码http://facebook.github.io/immutable-js/我得到了正确的结果:"Map{1:2}"为什么会发生这种情况,我该怎么做才能在我的脚本中获得正确的结果(键为数字)?我正在使用Nodev0.10.2
如果我已经完全替换了状态的一部分,我是否仍然需要使用Object.assign或扩展运算符来复制原始状态并将其替换为新状态,或者我可以直接返回我的reducer中的新状态?constfetching=(state={isFetching:false},action)=>{switch(action.type){case'REQUESTING':returnObject.assign({},state,{isFetching:true})case'RECEIVE_POKEMON_TYPE_INFO':returnObject.assign({},state,{isFetching:fal
我希望有一些函数可以获取当前状态来用它做一些逻辑,而不必通过参数将当前状态传递给函数。这是我的例子。在我的Action文件中,我有:exportconstaddToSearchHistory=(newSearch)=>({type:ADD_TO_SEARCH_HISTORY,newSearch})exportconstaddToCardHistory=(newCard)=>({type:ADD_TO_CARD_HISTORY,newCard})例如,我想要一个“getter”函数,告诉我“搜索历史”是否已经达到10个项目。所以我所做的是:exportconstsearchHasMaxH