低代码平台-远程组件打包(ESModule)

前言

最近的工作基本上在第三方低代码平台展开,使用过之后才发现低代码其实并不低代码,反而有种束手束脚的别扭感,很多时候业务设计的思路平台无法实现或者实现的体验感不佳。想写低代码文章的目的有两个,一个是熟悉低代码的逻辑和业务,二是想思考什么样的低代码平台才更被人想用。

技术栈

  • vue3 组件的开发语言,同时通过vue3的异步组件defineAsyncComponent来加载远程组件
  • vite 脚手架,用于调试组件
  • webpack 把组件编译打包成esm格式

使用vite初始化工程

yarn create vite 按照提示操作即可。

这一步就不赘述了,可查阅vite官网

webpack配置

安装webpack

依赖之间可能有版本要求,所以一开始最好跟我的版本一致。
yarn add webpack@5.89.0 webpack-cli@5.1.4 -D

vue-loader

使webpack能够编译vue文件
yarn add vue-loader@17.3.1 -D

样式

使webpack能够编译css/less文件
yarn add style-loader@3.3.3 css-loader@6.8.1 less@4.2.0 less-loader@11.1.3 -D

js处理

将es5以上依法转义
yarn add babel-loader@9.1.3 @babel/core@7.23.6 @babel/preset-env@7.23.6 -D

图片处理

yarn add file-loader@6.2.0 -D

完整配置

js 复制代码
import { dirname} from "node:path"
import { fileURLToPath } from "node:url"
import { VueLoaderPlugin } from "vue-loader"
import path from 'path'
// 按需打包element-plus
import AutoImport from 'unplugin-auto-import/webpack'
import Components from 'unplugin-vue-components/webpack'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
// 需要打包的组件名
const cardName = process.env.npm_config_card
const getCurrentDir = () => {
  const __filename = fileURLToPath(import.meta.url)
  const __dirname = dirname(__filename)
  return __dirname
}
const __dirname = getCurrentDir()

export default {
  mode: "production",
  entry: {
    // 组件代码
    index: path.resolve(__dirname, `../src/cards/${cardName}/index.js`),
    // 组件配置面板代码
    panel: path.resolve(__dirname, `../src/cards/${cardName}/panel/index.js`)
  },
  output: {
    filename: "[name].js",
    path:  path.resolve(__dirname, `./${cardName}`),
    // esm打包模式
    library: { type: 'module' }
  },
  experiments: { outputModule: true },
  plugins: [
    new VueLoaderPlugin(),
    AutoImport({
      resolvers: [ElementPlusResolver()],
    }),
    Components({
      resolvers: [ElementPlusResolver()],
    }),
  ],
  externals: {
     // 排除vue
    'vue': 'https://cdn.jsdelivr.net/npm/vue@3.2.37/dist/vue.esm-browser.js'
  },
  optimization: {
    // 压缩代码
    minimize: true,
  },
  module: {
    rules: [
      // vue
      {
        test: /\.vue/,
        use: ["vue-loader"],
      },
      // JS
      {
        test: /\.m?js$/,
        exclude: /(node_modules|bower_components)/,
        use: {
          loader: "babel-loader",
          options: {
            presets: [
              // 开始
              [
                "@babel/preset-env",
                {
                  useBuiltIns: "usage",
                  corejs: {
                    version: 3,
                  }
                },
              ],
              // 结束
            ],
          },
        },
      },
      // CSS
      {
        test: /\.css$/,
        use: ["style-loader", "css-loader"],
      },
      {
        test: /\.less$/,
        use: ["style-loader", "css-loader", "less-loader"],
      },
      // Images
      {
        test: /\.(jpg|png|gif|svg)$/,
        use: [
          {
            loader: "file-loader",
            options: {
              outputPath: "assets/images/",
            },
          },
        ],
      },

      // Fonts
      {
        test: /\.(ttf|eot|woff|woff2)$/,
        use: [
          {
            loader: "file-loader",
            options: {
              outputPath: "assets/fonts/",
            },
          },
        ]
      }
    ]
  }
}

打包命令

npm run build --card=组件名

具体文件目录可访问gitee地址

参考文章

疑问

  • 打包组件的时候需要在externals中定义vue的远程地址,能否定义一个相对地址
  • 如何排除elementplus不打包到组件
相关推荐
小龙报2 小时前
【Coze-AI智能体平台】低代码省时高效:Coze 应用开发全流程指南
java·人工智能·python·深度学习·低代码·chatgpt·交互
2501_9272835816 小时前
荣联汇智助力天津艺虹打造“软硬一体”智慧工厂,全流程自动化引领印刷包装行业数智变革
大数据·运维·数据仓库·人工智能·低代码·自动化
梦梦代码精1 天前
LikeShop 是怎么解决数据库瓶颈的?
java·数据库·低代码·php
盟接之桥1 天前
盟接之桥说制造:深耕长尾市场,跨越价值“临界点”
大数据·网络·安全·低代码·汽车·制造
启效云2 天前
启效云战略升级:本体论落地 AI 原生应用智能体,打造中国版 Palantir 数字基座
人工智能·低代码·软件开发·低代码开发·零码化编辑器
决斗小饼干2 天前
让“办公室政治”见鬼去吧
低代码
LT10157974442 天前
2026年低代码自动化测试平台选型指南:降低测试落地门槛
测试工具·低代码·自动化
咬人喵喵2 天前
五一劳动节 SVG 交互图文案例大全
低代码·微信·编辑器·交互·svg
梦想很大很大3 天前
让 AI 成为“报表配置员”:BI 低代码平台的 Schema 实践路径
前端·人工智能·低代码
几何心凉3 天前
低代码快速接入:魔珐星云具身智能 3D 数字人开发实战指南
低代码