本地开发react项目,运行外部引入的组件某个事件时报错,如何准确定位到错误原因。

在本地运行一个react+antd项目,点击pagination组件的页数li后触发组件的改变页数事件,在这个过程中组件报了错。

antd里介绍的关于onChange事件的使用:
code1.png

我在代码里实际的应用,(将绑定的函数从当前组件的方法改为props属性的方法后执行onChange事件报错,但是onShowSizeChange事件没问题):
code2.png

出错情况:
error.png
提示是因为‘apply’undefined.
下面是antd经webpack编译生成后的table.jsx文件

antd里的源码:
code3.png

可以看到,编译后的jsx文件是
pagination.onChange(pagination.current, ...otherArguments);
这一句报的错。
对应的源码是549行的那一句。
看着antd源码逻辑是没什么问题的,可是又不能通过debugger等方法调试定位。

找不到错误原因,想问下各位大佬,这种问题该怎么解决。

阅读 4k
1 个回答

报错已经很明显的告诉你了。
Cannot read property 'apply' of undefined
说明你的pagination.onChangeundefined呀。


当你报错的时候,控制台抛出错误,如下图:
image.png
会帮你定位到是哪里错了。
这个时候你只需点击错误就会帮你跳转到错误的地方。
此处跳转到,如下图:
image.png
定位出错的位置,你就可以打断点,然后继续重复你刚刚的操作,断点进来,如下图:
image.png
可以看到这个时候就是调用你定义的方法的时候,看代码,此处调用了pagination.onChange.apply,根据报错原因Cannot read property 'apply' of undefined,猜测出pagination.onChangeundefined
试着在控制台输出pagination,如图:
image.png
发现pagination.onChange确实是undefined

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题