雅荷心语博客
雅荷心语
心之所向便是光
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 关注本站
    • 微信
    • 微博
    • 腾讯微博
    • Twitter
    • Facebook
    • RSS订阅
Hi, 请登录     我要注册     找回密码

vue工程项目动态加载umd.js实践

2024-09-27 分类:前端之旅 阅读(1116) 评论(0)

首先,如何打包出 umd.js

新建一个 xx.vue 组件, 写入代码后进行打包编译,

1
2
3
4
5
6
7
8
9
{
  "name": "my-vue-component",
  "version": "1.0.0",
  "main": "dist/my-vue-component.umd.js",
  "scripts": {
    "serve": "vue serve xx.vue",
    "build": "vue build --target lib --name my-vue-component ./xx.vue"
  }
}

这里需要注意 打包的 –name ,指定为组件名称, 后续会使用到!

我们需要打包出干净的 umd.js 文件, 需要把 css 打包到 js 里, 在 xx.vue 同层目录里新建 vue.config.js

1
2
3
4
5
module.exports  = {
  css: {
    extract: false
  }
}

配置就绪后正常打包 执行 npm run build

1
2
3
4
5
6
7
-rw-r--r--  1  staff   289B Sep 27 18:03 demo.html
-rw-r--r--  1  staff    76K Sep 27 18:03 my-vue-component.common.js
-rw-r--r--  1  staff    98K Sep 27 18:03 my-vue-component.common.js.map
-rw-r--r--  1  staff    77K Sep 27 18:03 my-vue-component.umd.js
-rw-r--r--  1  staff    98K Sep 27 18:03 my-vue-component.umd.js.map
-rw-r--r--@ 1  staff    26K Sep 27 18:03 my-vue-component.umd.min.js
-rw-r--r--  1  staff   115K Sep 27 18:03 my-vue-component.umd.min.js.map

打包完成后将 umd.min.js 上传到 cdn 里, 后续使用!

打开自己的 Vue 工程项目, 准备使用这个 umd.js 文件

新增一个动态加载 js 的方法,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
function loadComponent(url, componentName) {
  return new Promise((resolve, reject) => {
    const script = document.createElement('script');
    script.src = url;
    script.async = true;
    script.onload = () => {
      resolve(window[componentName]);
    };
    script.onerror = () => {
      reject(new Error(`Failed to load script: ${url}`));
    };
    document.head.appendChild(script);
  });
}

 

然后在项目里新建一个 Div, #novel-reader-container , 开始引入 umd.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<template>
  <div class="cloak">
    <div id="novel-reader-container"></div>
  </div>
</template>
export default {
  name: 'IndexPage',
  components: {},
  data() {
    return {}
  },
  methods: {},
  mounted() {
    const componentUrl = 'https://storage.xxx.com/xxx/js/test/my-vue-component.umd.min.js';
    const componentName = 'my-vue-component';
    loadComponent(componentUrl, componentName)
      .then((component) => {
        console.log(component)
        // 注册全局组件
        this.$options.components[componentName] = component;
        // 使用 Vue.extend 将其转换为构造函数
        const ComponentConstructor = this.$options._base.extend(component);
        // 动态创建并挂载组件实例
        new ComponentConstructor().$mount('#novel-reader-container');
      })
      .catch((error) => {
        console.error('Error loading component:', error);
      });
 
  },
}

搞定, 页面正常渲染出组件内容!

此方法适用于所有 vue 项目, 可实现动态加载组件及项目的插件扩展!

 

分享到:更多 ()

相关推荐

  • AI 编辑器 cursor 如何禁止自动更新
  • AI 编辑器 cursor 工具栏改成和 vscode 一样的左侧 竖向展示
  • nodejs 脚本打包为可执行文件
  • 初学 python 笔记
  • nodejs 同时运行多个脚本
  • 让你的照片动起来
  • 使用 shell 检测目标服务器是否异常
  • 使用leaflet加载及转发瓦片地图
关于我

小天明 北京·朝阳 前端搬砖工程师

碎碎念):(来自公众号)

热门文章

  • 踩坑记录——iphone上safari开启隐身模式时localStorage变为只读-雅荷心语博客踩坑记录——iphone上safari开启隐身模式时localStorage变为只读2017-02-21评论(4)
  • 程序员是怎样一群人-雅荷心语博客程序员是怎样一群人2015-12-08评论(3)
  • 百度你个大毒瘤 - 吐糟博客这几天打不开事情-雅荷心语博客百度你个大毒瘤 – 吐糟博客这几天打不开事情2015-12-28评论(2)
  • PHP 非对称加密 openssl 加密及解密方法-雅荷心语博客PHP 非对称加密 openssl 加密及解密方法2016-05-17评论(2)
  • PHPStorm10 下载安装破解汉化-雅荷心语博客PHPStorm10 下载安装破解汉化2015-12-15评论(2)
2025年7月
一 二 三 四 五 六 日
« 六    
 123456
78910111213
14151617181920
21222324252627
28293031  

最新评论

  • 前端小武 8年前 (2017-04-06)说:
    我看到了layer
  • 丁艳平 8年前 (2017-03-03)说:
  • Dawn 9年前 (2016-09-16)说:
    call_user_func_array最后的例子是错哦,你用bc方法去调用类里 另外一个方法就知道问题所在了。情况1.调用非静态方法 第一个参数应该传[类的实例,调用方法] (既然有类实例了直接-&
  • Dawn 9年前 (2016-06-21)说:
    tp框架设置了全局捕获异常的,这也没什么。坑的是 他捕获了异常。然后全部返回404。。。不知道的 还以为自己网站被删除了
  • Dawn 9年前 (2016-05-17)说:
    构造函数里的判断 用异常机制可能更好一些

其他类型

  • 芊云全景
  • 配音兔AI配音神器

博客类型

  • 芊云全景
  • 配音兔AI配音神器

左邻右舍

  • 易水寒
  • 楼教主
  • 芊云全景
  • 贤心
  • 配音兔AI配音神器

雅荷心语博客 -心之所向便是光

联系我们关于我们

© 2025 雅荷心语博客   网站地图