从一个令人疑惑的bug出发,debug更香哦
一、bug介绍
问题截图:data:image/s3,"s3://crabby-images/fcc65/fcc6568de2e05f9278397d0991413c0b287ab39e" alt=""
问题描述:看不出任何出错提示;第一次login跳转 /merchant/management会出错;刷新后正常;推断是management页面ssr有问题
出错行:vue-server-renderer
data:image/s3,"s3://crabby-images/d06dd/d06ddca4f9d5b626269eb1b4190d55544cdc80bc" alt=""
二、经过一番缠斗,总结的node_modules调试方法:
tips:
只用vscode run;停掉其他(iterm等) // vscode的debug就相当于其他终端的npm run start
设置正确的.vscode/launch.json: 除了环境变量其他一般是自动生成的 env=dev..
npm run build:env=dev..
截图示例:
data:image/s3,"s3://crabby-images/efb63/efb63dc78a0d0185e53f007507729bd2b32f23ca" alt=""
data:image/s3,"s3://crabby-images/c50f4/c50f4bdb640490c9429c84f3004c0199b46bcd2a" alt=""
data:image/s3,"s3://crabby-images/70351/70351c21447f5cc0e1c8fd546cec8d175d573d91" alt=""
data:image/s3,"s3://crabby-images/414be/414be936462eb69bbafe52e102a25dc687798b34" alt=""
三、Debug过程
根据调用链推测出错的代码
由于是children是array类型,推测是list页面。排除法确定出错位置在:
return h('span', [undefined]) // Table组件的columns
[undefined] 作为span的children 来render,导致出错
所以client渲染(即刷新后)不会出错,server会出错。
结论:Table组件和SSR有一方或两方不够完善
// fix: 改自己的代码 T ^ T // 给vue提了一个PR,反正也不会被看到
refer: https://code.visualstudio.com/docs/nodejs/nodejs-debugging
// 没用到的refer: https://medium.com/nodesimplified/node-js-set-breakpoints-and-debug-node-application-with-chrome-devtools-14ad021deccc
网友评论