国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

《Webpack5 升級》- Vue2.x 組件庫 Webpack3 升 5

這篇具有很好參考價值的文章主要介紹了《Webpack5 升級》- Vue2.x 組件庫 Webpack3 升 5。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

前言

基于 Vue2.x 的項目和組件庫開發(fā)于 2019 年 ,那時對 Webpack 版本沒有概念,項目和組件庫的版本混亂…有的使用 v3,有的使用 v4
對于現(xiàn)今 2023 年(或 2024 年)的整個生態(tài)環(huán)境是不夠用的,無法使用較新和更優(yōu)秀的插件。所以升級勢在必行
注意 本篇是基于 Vue2.x 組件庫 的升級,如果想了解 基于 Vue2.x 項目 的升級。
請移步《Vue2.x 項目 Webpack 4 升級 5(半自動升級)》

實現(xiàn)

升級

  1. package.json 刪除冗余依賴
"extract-text-webpack-plugin": "^3.0.2",

"vue-loader": "^13.0.5",
"vue-template-compiler": "^2.4.4",
"webpack": "^3.6.0",
"webpack-dev-server": "^2.9.1",
"webpack-glob-entry": "^2.1.1"               
        
"babel-core": "^6.26.3",
"babel-loader": "^7.1.2",
"babel-preset-env": "^1.7.0",
"babel-preset-react": "^6.24.1",
"babel-preset-stage-0": "^6.24.1",
"babel-preset-stage-3": "^6.24.1",

"file-loader": "^1.1.6",
  1. 安裝相關(guān)插件
npm i vue@2.6.14

npm i vue-template-compiler@2.6.14 -D
npm i vue-loader@15.9.8 -D
npm i file-loader@6.2.0 -D
npm i babel-loader@8.3.0 -D


npm i @babel/core@7.2.2 -D
npm i @babel/plugin-transform-runtime@7.22.5 -D
npm i @babel/preset-env@7.3.1 -D
npm i @babel/preset-react@7 -D
npm i @vue/cli-plugin-babel@5.0.6 -D
npm i @vue/cli-service@5.0.6 -D
        
npm i axios@1.6.0

注意千萬不要安裝,這是給vue3和vue2的兼任版本使用

@vue/compiler-sfc
  1. 安裝 webpack5
npm install webpack@5.89.0 webpack-cli@5.1.4 -D
  1. 安裝
npm i mini-css-extract-plugin -D
npm i css-minimizer-webpack-plugin -D
npm i javascript-obfuscator webpack-obfuscator -D
npm i style-loader@2 -D
  1. 修改文件 .npmrc
init.author.name 改為 --init-author-name
init.author.email 改為 --init-author-email
  1. 修改文件 packages.json 的編譯命令
"scripts": {
	"build": "webpack --config ./webpack.config.js --progress"
},
  1. 修改文件 .babelrc
{ 
  "presets":[
    [
      "@babel/preset-env",
      { "targets": "> 1% in AU and not dead", "shippedProposals": true },
    ],
    ["@babel/preset-react", { "runtime": "automatic" }]
  ]
}

啟動時報錯

錯誤 1: VueLoaderPlugin is not a constructor

解決方案:vue-loader 必須在 15+,且在 webpack.config.js做如下配置:

const { VueLoaderPlugin } = require('vue-loader')

plugins: [
    // 引入VueLoader插件
    new VueLoaderPlugin(),
],

錯誤 2: The code generator has deoptimised the styling

解決方案: 在項目根目錄下查找文件 .babelrcbabel.config.js ,如果沒有就創(chuàng)建一個(兩者其一即可),配置如下:

// .babelrc:
{
  "compact": false
}

// babel.config.js:
module.exports = {
    compact: false,
}

錯誤 3: Missing class properties transform

解決方案: 在文件 .babelrcbabel.config.js` 下配置

{ 
  "presets":[
    [
      "@babel/preset-env",
      { "targets": "> 1% in AU and not dead", "shippedProposals": true },
    ],
    ["@babel/preset-react", { "runtime": "automatic" }]
  ]
}

錯誤 4: Uncaught ReferenceError: Cannot access 'l' before initialization

解決方案: 在文件 .babelrcbabel.config.js ,webpack.config.js 下配置

// .babel 或 babel.config.js
"plugins": [
    "@babel/plugin-transform-runtime"
]
  
// webpack.config.js
module.exports = {
  target: ['web', 'es5'],
}

錯誤 5: 插件 xlsx 報錯

解決方案: 如下方式引入

import * as XLSX from "xlsx";

錯誤 6: Can't resolve '[object Module]

解決方案: 字體庫報錯,屬于資源配置錯誤。 文件 webpack.config.js 中配置

{
    test: /\.(eot|svg|ttf|woff|woff2)(\?\S*)?$/,
    type: "asset/resource", // 正確
    // loader: "file-loader"http:// 錯誤
},

編譯時報錯

錯誤 1: Uncaught ReferenceError: exports is not defined

解決方案:第三方參考,也可研究 babel-loader。沒真正解決,因為僅在開發(fā)聯(lián)調(diào)環(huán)境下報此錯誤。

組件庫文件 index.js 導(dǎo)出組件,要判斷當(dāng)前環(huán)境是否為 production

// 合并導(dǎo)出
if (process.env.NODE_ENV === 'production') {
    Object.assign(exports, { MyTestComponents });
}

export {
    MyTestComponents 
}

錯誤 2: 使用相對路徑引用的圖片解析后的地址不正確

解決方案: 未解決,把小圖片改為 base64 配置(待研究);

項目版本是 Webpack4,但使用 Webpack5 組件庫的解決方案

vue.config.js 加上如下代碼第 2 行:

module.exports = {    
    productionSourceMap: false,
    // 你的組件庫名稱
    transpileDependencies: ['my-components-test'],
}

最后

想要了解更多,請查看官網(wǎng) 《從 v4 升級到 v5》文章來源地址http://www.zghlxwxcb.cn/news/detail-775847.html

到了這里,關(guān)于《Webpack5 升級》- Vue2.x 組件庫 Webpack3 升 5的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 基于 Vue3 + Webpack5 + Element Plus Table 二次構(gòu)建表格組件

    基于 Vue3 + Webpack5 + Element Plus Table 二次構(gòu)建表格組件

    基于 Vue3 + Webpack5 + Element Plus Table 二次構(gòu)建表格組件,開箱即用 A Vue 3.x Table Component built on Webpack 5 該組件庫可供學(xué)習(xí)、參考和用于二次開發(fā)。 1.基于 Webpack 5 構(gòu)建 2.全面支持 Vue 3 3.支持 JSON 序列化表格快速配置 4.已內(nèi)置 Pagination 分頁 5.支持自定義 prop 列名 6.支持單元格內(nèi)容自

    2024年04月13日
    瀏覽(30)
  • 使用Vue3和Vite升級你的Vue2+Webpack項目

    使用Vue3和Vite升級你的Vue2+Webpack項目

    ???? 博主貓頭虎(????)帶您 Go to New World??? ?? 博客首頁 ——????貓頭虎的博客?? ?? 《面試題大全專欄》 ?? 文章圖文并茂??生動形象??簡單易學(xué)!歡迎大家來踩踩~?? ?? 《IDEA開發(fā)秘籍專欄》 ?? 學(xué)會IDEA常用操作,工作效率翻倍~?? ?? 《100天精通Golang(基礎(chǔ)

    2024年02月09日
    瀏覽(28)
  • 《基于 Vue 組件庫 的 Webpack5 配置》7.路徑別名 resolve.alias 和 性能 performance

    路徑別名 resolve.alias 性能 performance

    2024年02月11日
    瀏覽(26)
  • 《基于 Vue 組件庫 的 Webpack5 配置》9.module.exports 可為數(shù)組類型且注意編譯順序

    module.exports 常見是對象類型,其實也可用數(shù)組類型; 注意編譯順序, 從后往前 編: 也就是說先編 another.js ,再編 index.js ; 所以 代碼第 9 行 不能設(shè)置為 true ,僅在第一次,也就是 代碼第19行 設(shè)置 一次 即可清空整個 output 文件夾; 如果 代碼第 9 行 設(shè)置為 true ,則在編 i

    2024年02月08日
    瀏覽(24)
  • vue2+webpack升級vue3+vite,在vue3組合式編程中使用vuex

    同學(xué)們可以私信我加入學(xué)習(xí)群! 我的項目是從vue2+webpack升級為vue3+vite,這種升級工作,其實最重要的不是如何快速準(zhǔn)確地把原有vue2項目全部重構(gòu)為vue3項目,因為這是不現(xiàn)實的。 升級工作一定是一個長久的持續(xù)過程,所以如何保證舊的vue2項目與新的vue3模塊之間互相兼容,才

    2024年01月18日
    瀏覽(31)
  • 《基于 Vue 組件庫 的 Webpack5 配置》6.將字體庫和圖片等靜態(tài)資料,編譯后打包至指定文件夾

    參考 Rule.generator.filename package.json 的配置如下

    2024年02月11日
    瀏覽(29)
  • vue2+webpack升級vue3+vite,報錯Cannot read properties of null (reading ‘isCE‘)

    vue2+webpack升級vue3+vite,報錯Cannot read properties of null (reading ‘isCE‘)

    同學(xué)們可以私信我加入學(xué)習(xí)群! 系列文章:vue2+webpack升級vue3+vite,修改插件兼容性bug 前面的文章主要是介紹,在升級初始階段遇到的一些顯而易見的兼容性問題和bug。隨著項目迭代的不斷深入,一些不容易暴露的問題也漸漸呈現(xiàn)。 本文主要記錄一些開發(fā)重構(gòu)過程中的bug vu

    2024年01月18日
    瀏覽(33)
  • Webpack5 搭建Vue項目(進階版)

    提示:中間隔了好長時間,我胡漢三又回來繼續(xù)更新了?。?!?????? 提示:文章涉及的一些內(nèi)容僅供參考: 大多數(shù)情況下,大家在項目開發(fā)的過程中,基本很少去說讓開發(fā)人員去自助的搭建一個Vue項目。 基本都是使用現(xiàn)成的一些模版項目,直接在上面進行一個二次的開發(fā)

    2024年02月09日
    瀏覽(20)
  • Webpack5 vue-loader和VueLoaderPlugin

    .vue 文件是用戶用 HTML-like 的語法編寫的 Vue 組件。每個vue 文件都包括三部分 , VueLoaderPlugin 是一個解析 Vue.js 的插件,用于在 webpack 構(gòu)建過程中解析和轉(zhuǎn)換 .vue 單文件組件。它的作用是將 .vue 文件中的模板、樣式和腳本進行編譯,并將其轉(zhuǎn)換為 JavaScript 模塊,以供Webpack打包使

    2024年02月15日
    瀏覽(23)
  • Webpack5入門到原理20:Vue 腳手架搭建

    package.json .eslintrc.js babel.config.js

    2024年01月24日
    瀏覽(48)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包