vue异步组件与组件懒加载问题(import不能导入变量字符串路径)
vue异步组件与组件懒加载
在写项目的时候,需要动态配置路由菜单,所有的菜单都是通过配置生成的,这就意味着菜单的路径(在vue开发项目里面就是一个字符串的路径)需要异步加载进去,但是由于对webpack的import不是很熟悉,所以就有一下的坑需要填了
错误的原因分析
_import.js module.exports = file => () => import(file)
但是这种方法错误的原因是:
webpack 编译es6 动态引入 import() 时不能传入变量,例如dir =’path/to/my/file.js’ ; import(dir) , 而要传入字符串 import(‘path/to/my/file.js’),这是因为webpack的现在的实现方式不能实现完全动态。
解决方案一
可以通过字符串模板来提供部分信息给webpack;例如import(./path/${myFile}), 这样编译时会编译所有./path下的模块,但运行时确定myFile的值才会加载,从而实现懒加载。
解决方案二
function lazyLoadView(AsyncView) { const AsyncHandler = () => ({ component: AsyncView, // A component to use while the component is loading. loading: require('@/view/system/Loading.vue').default, // A fallback component in case the timeout is exceeded // when loading the component. error: require('@/view/system/Timeout.vue').default, // Delay before showing the loading component. // Default: 200 (milliseconds). delay: 200, // Time before giving up trying to load the component. // Default: Infinity (milliseconds). timeout: 10000 }); return Promise.resolve({ functional: true, render(h, { data, children }) { // Transparently pass any props or children // to the view component. return h(AsyncHandler, data, children); } }); } const My = () => lazyLoadView(import('@/view/My.vue')); const router = new VueRouter({ routes: [ { path: '/my', component: My } ] })
通过上述两种方法都能够解决 动态组件的懒加载效果
vue懒加载组件 路径不对
最近在使用VueRouter的懒加载组件的时候.
const routes = [ { path: '/', component: App }, { path: '/category', component: resolve => {require(['./components/Category.vue'], resolve)} } ]
但是在加载/category的时候,我发现会报错。
原来webpack会把这个懒加载单独加载一个js,默认按照
0.app.js 1.app.js ……的顺序加载的
通过简单的debug发现是0.app.js的路径不对
通过webpack的设置即可解决(我使用的laravel,配置根据情况自行修改)
Elixir.webpack.mergeConfig({ module: { loaders: [ { test: /\.css/, loader: "style!css" } ] }, output: { publicPath: "js/" } })
配置下output下的publicPath即可。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
- Vite使用unplugin-auto-import实现vue3中的自动导入
- vue3项目如何配置按需自动导入API组件unplugin-auto-import
- vue中import导入三种方式详解
- Vue export import 导入导出的多种方式与区别介绍
- 解决vue3 defineProps 引入定义的接口报错
- 一文详细聊聊vue3的defineProps、defineEmits和defineExpose
- Vue3中defineEmits、defineProps 不用引入便直接用
- vue3的defineExpose宏函数是如何暴露方法给父组件使用
- defineProps宏函数不需要从vue中import导入的原因解析
相关文章
uniapp组件uni-file-picker中设置使用照相机和相册权限的操作方法
这篇文章主要介绍了uniapp组件uni-file-picker中设置使用照相机和相册的权限,在uniapp中,我们通常会使用uni-file-picker这个组件,但是这个组件中,有点缺陷,就是没有对这个功能的传值设置,这里就要给组件进行修改了,需要的朋友可以参考下2022-11-11
最新评论