当前位置: 首页 > news >正文

东莞市做阀门的网站嘉兴市南湖区建设街道网站

东莞市做阀门的网站,嘉兴市南湖区建设街道网站,百中搜,小男生和大人做的网站背景:开发一个大屏项目中,需要是要DataV的那边边框,装饰等,只是DataV是基于vue2的,vue3版的作者还在开发中,于是翻了DataV的源码,发现使用esm方式时是直接引入源码而不经过打包,其源码中使用的vue语法vue3也支持,所以可以直接在vue3中引入使用. vite,vue3项目直接引入DataV 安…

背景:开发一个大屏项目中,需要是要DataV的那边边框,装饰等,只是DataV是基于vue2的,vue3版的作者还在开发中,于是翻了DataV的源码,发现使用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开发时会对依赖进行预构建,由于dataV源码中引入了其他commonjs包,而vite没有将这些依赖预构建转成esm,所以需要在vite.config.js中配置告知vite哪些依赖需要转成esm格式,配置在optimizeDeps.include,就可以愉快使用了.
配置如下:

export default defineConfig({// ... 省略其他配置optimizeDeps: {// 开发时 解决这些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规范的包commonjsOptions: {include: [/node_modules/, // 必须包含],},},
});

fork一份dataV源码添加多vue3打包方式,发布npm包

  • @iamzzg/data-view
  • 仓库地址

改造过程

  1. 增加打包入口文件
    源码构建源码
    在这里插入图片描述
    增加入口文件:
    在这里插入图片描述
  2. 打包过程中发现缺少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,需安装lessvuePlugin({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. 发布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);
http://www.yayakq.cn/news/567889/

相关文章:

  • 毕业设计做视频网站好做么网站建设硬件配置
  • 灯饰 技术支持 东莞网站建设营销培训主题
  • 玛伊网站做兼职加入要多少钱公司设计网页
  • 网站公司建设网站价格wordpress域名授权
  • 网站程序更换自己开公司需要什么条件
  • 马云做网站最早成品视频软件推荐哪个好一点
  • 网站建设 海豚弯惠州搜索引擎优化
  • 北京哪家做网站网站模板购买 优帮云
  • 怎么减少wordpress网站cpu占用企业简介的网站怎么做
  • 域名空间网站怎么做制作网站语言
  • 主办单位性质与网站名称不符辽宁建设工程信息网官方网站
  • 国内做的比较好的网站是什么电子商务的发展现状与趋势
  • 山西大同专业网站建设价格电子商务发展现状与趋势
  • 建设购物网站论文国内网站建设哪家好
  • 购买域名之后怎么做网站一个外国设计网站网址
  • 专注服务于站长和网站的信息平台.凡客诚品售后服务官方
  • 网站上切换语言是怎么做的十大猎头公司
  • wordpress分类关键字北京官网seo
  • 网站托管西安工商核名官网首页登录入口
  • 有服务器怎么做网站教程网站群建设 中标
  • 模板网站建设教程视频网站开发项目源码
  • 网站建设明细报价表 服务器php 网站后台
  • wordpress 大型网站吗仓库改造类网站怎么做
  • 泉州做网站联系方式如何分析企业网站
  • 专业电子商务网站建设实木餐桌椅移动网站建设
  • 上上上海网站设计怎么挂代理访问网站
  • 旅游网站建设那家好在线制作表情包生成器软件
  • 东莞最新通报最新优化网站关键词排名软件
  • 网站设计遵从的原则网站qq临时会话
  • 自己做网站广告法西安优化多钱