本地开发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等方法调试定位。

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

阅读 722
评论
    1 个回答
    • 2.1k

    报错已经很明显的告诉你了。
    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

      撰写回答

      登录后参与交流、获取后续更新提醒