2017812

情景描述

  • 使用如下的react+redux代码
render(){
  <form>
    <input type='text' onKeyPress={()=>{
        if(e.which === 13){
            this.props.dispatchData(..)
        }  //这里就是dispatch一个action
    }}>
   </form>
}
  • 然后发现整个store被重置

解答

  • Q1:我正常的reducer接受步骤是不会导致store被重置,到底是什么造成的?
  • A1:本来想通过console的方式发现哪里出了问题,却发现一旦回车之后就页面被刷新了,所有的console也都消失了。

  • Q2:既然console不行,也并不能瞎猜,到底该如何判断原因所在呢?
  • A2:那么当然采用webstorm的断点功能,查看我们dispatch操作是否正常执行,页面是否正常render,使用这种方式正好可以解决console的东西在刷新之后全部消失

至于webstorm如何进行浏览器断点调试,参见简书-webstorm前端断点调试

  • Q3:进过断点调试发现整个dispatch和store的更新操作都没有问题,却在这之后执行了某个事件刷新了页面,很显然这已经是我们代码之外的动作了,那么到底是谁造成的?

  • A3:必然是默认事件,这也是我们经常忽略那么这时候补充默认事件的知识

    默认事件,指的是浏览器默认事件。当我们点击某一个链接的时候,浏览器会直接跳转,在表单中按回车,表单会自动提交,这些都是浏览器的默认行为。

    因此我们可以确定发生了浏览器onKeyPress的默认提交行为


  • Q4:那么到底是什么行为?
  • A4:我尝试去除if发现,其他的所有字母输入都不会触发页面刷新,只有回车会触发.可以初步断定是浏览器的enter事件造成的,根据以上知识,猜想出发了表单提交。那么我们现在要是确定表单提交的默认事件能够造成页面跳转(刷新)即可确定。根据研究在表单最后一个input元素中敲回车,会触发表单提交,在action没有重置的时候,会将表当提交到当前的url

  • 解决:因此我们可以通过去除enter的默认事件解决
if(e.which === 13){
    e.preventDefault();
}

反思

  • 发现自己遇到坑自己竟然再踩还能陷下去。针对默认事件这件事,我已经入坑了无数次了,但是每次都忘记。这个事情该怎么呀?
  • 我发现着断点调试是很好用,但是发现使用的时候除了看些数据的值没有什么其他的用处,可能还是自己不太能发掘所有功能,求教
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,015评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,107评论 19 139
  • 22年12月更新:个人网站关停,如果仍旧对旧教程有兴趣参考 Github 的markdown内容[https://...
    tangyefei阅读 35,268评论 22 257
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,268评论 4 61
  • 1 我的狗丢了,它的名字叫罗娜。它原来只是一条很小很小的狗,小到只有巴掌那么大。像个老鼠一样。去年夏天,罗娜把它捧...
    雨童先生阅读 523评论 0 6