控制台报错
data:image/s3,"s3://crabby-images/31ef9/31ef9d09e2193aede754cd13f682c1911ed4e916" alt=""
router.js
data:image/s3,"s3://crabby-images/575ce/575ceb5b2f7763db2622fad9d3afa37c765ffdab" alt=""
引用位置
data:image/s3,"s3://crabby-images/2fbc1/2fbc16111d0b1d41f9297594c5605065cc0dd8ff" alt=""
components 更正前
data:image/s3,"s3://crabby-images/d405e/d405e844287e040f235c51e2ab5bb803a9e4c0ff" alt=""
components 更正后 default
data:image/s3,"s3://crabby-images/15736/15736d0be9a70e44fd390290756667f7bc9fb489" alt=""
require和import混合使用时会出现这种情况
1.针对本文情况
require 是 CommonJS 的模块导入方式,而组件定义时写的 export default 是 ES6 方式,因此require 导入的结果其实是一个含 default 属性的对象,所以 vue 中 component 用这个会报错,
- 针对router中使用require引入组件 使用components代替component成功解决报错分析如下:
因为 vue 的命名视图组件注册恰好用的是 components ,而官方也说了“如果 router-view 没有设置名字,那么默认为 default”,所以这两个default 正好对应起来,于是加了s就不会报错了。
参考:https://www.jianshu.com/p/4d61f71de95a
总结
-
合理的用法应该是 require('xxx.vue').default 或是用 import。
网友评论