日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 Vue 正文

Vite,Vue3項目引入dataV報錯的解決方法

作者:新時代的弩力 更新時間: 2024-04-01 Vue

背景:開發(fā)一個大屏項目中,需要是要DataV的那邊邊框,裝飾等,只是DataV是基于vue2的,vue3版的作者還在開發(fā)中,于是翻了DataV的源碼,發(fā)現使用esm方式時是直接引入源碼而不經過打包,其源碼中使用的vue語法vue3也支持,所以可以直接在vue3中引入使用.

vite,vue3項目直接引入DataV

安裝

npm install @jiaminghi/data-view

使用

import dataV from "@jiaminghi/data-view";

app.use(dataV)

引入后報錯

  1. template v-for 綁定key
    解決方式: 使用patch-package給源碼打補丁
    在這里插入圖片描述
  2. 報錯Uncaught SyntaxError: The requested module '/node_modules/@jiaminghi/c-render/lib/index.js?v=c576b840' does not provide an export named 'default'
    在這里插入圖片描述
    在這里插入圖片描述

這是因為vite開發(fā)時會對依賴進行預構建,由于dataV源碼中引入了其他commonjs包,而vite沒有將這些依賴預構建轉成esm,所以需要在vite.config.js中配置告知vite哪些依賴需要轉成esm格式,配置在optimizeDeps.include,就可以愉快使用了.
配置如下:

export default defineConfig({
  // ... 省略其他配置
  optimizeDeps: {
    // 開發(fā)時 解決這些commonjs包轉成esm包
    include: [
      "@jiaminghi/c-render",
      "@jiaminghi/c-render/lib/plugin/util",
      "@jiaminghi/charts/lib/util/index",
      "@jiaminghi/charts/lib/util",
      "@jiaminghi/charts/lib/extend/index",
      "@jiaminghi/charts",
      "@jiaminghi/color",
    ],
  },
  build: {
    // 打包時需要另外處理的commonjs規(guī)范的包
    commonjsOptions: {
      include: [
        /node_modules/, // 必須包含
      ],
    },
  },
});

fork一份dataV源碼添加多vue3打包方式,發(fā)布npm包

  • @iamzzg/data-view
  • 倉庫地址

改造過程

  1. 增加打包入口文件
    源碼構建源碼
    在這里插入圖片描述
    增加入口文件:
    在這里插入圖片描述
  2. 打包過程中發(fā)現缺少rollupless,需要安裝,為了同時打包vue2vue3的格式,需要編譯vue文件,vue2需要vue-template-compiler,vue3需要@vue/compiler-sfc,對應的rollup-plugin-vue版本是@6和@5.1.6
    在這里插入圖片描述
  3. 修改了rollup.config.js配置的插件順序,否則打包不了
import resolve from "rollup-plugin-node-resolve";
import vue from "rollup-plugin-vue";
import commonjs from "rollup-plugin-commonjs";
import babel from "rollup-plugin-babel";
import postcss from "rollup-plugin-postcss";
import vue2 from "rollup-plugin-vue2";

const bundleFormats = ["umd", "esm", "cjs", "iife"];
const vueVersions = ["vue2", "vue3"];

const isVue3 = (v) => v == "vue3";
const isUmd = (v) => v == "umd";
const isCjs = (v) => v == "cjs";
const isIife = (v) => v == "iife";

const getRollupConfig = (bundleFormat, vueVersion = "vue2") => {
  const vuePlugin = isVue3(vueVersion) ? vue : vue2;
  return {
    input: `build/${isVue3(vueVersion) ? "vue3-entry/" : ""}entry.${bundleFormat}.js`,
    output: {
      format: bundleFormat,
      file: `dist/${isVue3(vueVersion) ? "vue3/" : ""}datav.map.vue.${isUmd(bundleFormat) ? "" : bundleFormat + "."}js`,
      name: "datav",
      ...(isUmd(bundleFormat) || isIife(bundleFormat)
        ? {
            globals: {
              // 模塊名: 變量名
              vue: "Vue",
            },
          }
        : {}),
      ...(isCjs(bundleFormat) ? { exports: "named" } : {}),
      ...(isUmd(bundleFormat) && isVue3(vueVersion) ? { exports: "default" } : {}),
    },
    plugins: [
      // rollup-plugin-vue 6.0.0版本 插件必須放在第一,需要postcss插件處理,sfc使用less,需安裝less
      vuePlugin({
        preprocessStyles: true,// 預處理css
      }),
      resolve(),
      babel({
        exclude: "node_modules/**",
      }),
      commonjs(),
      postcss(),
    ],
    // 外部包
    external: ["vue"],
  };
};

const configs = [];
bundleFormats.forEach((format) => {
  vueVersions.forEach((vueVersion) => {
    const config = getRollupConfig(format, vueVersion);
    configs.push(config);
  });
});

export default configs;
  1. 發(fā)布npm包
    修改包名為@iamzzg/data-view
npm login
npm publish --access=public

打包后Vue3使用方式

datav 打包成 vue3 的版本在 dist/vue3 文件夾下

  1. umd 使用方式
    未托管到 cdn,可以直接復制dist/vue3/datav.map.vue.js
<script src="dist/vue3/datav.map.vue.js"></script>
<script>
  // app是createApp()的返回值
  app.use(datav);
</script>
  1. esm 使用方式
    安裝
npm i @iamzzg/data-view

全局注冊

import datav from "@iamzzg/data-view/dist/vue3/datav.map.vue.esm";

app.use(datav);

按需導入,和 vue2 方式一致

import { borderBox1 } from "@iamzzg/data-view/dist/vue3/datav.map.vue.esm";
app.use(borderBox1);

原文鏈接:https://blog.csdn.net/qq_42372534/article/details/132740161

  • 上一篇:沒有了
  • 下一篇:沒有了
欄目分類
最近更新