摘要:組件庫開發(fā)總結(jié)由于工作需要,最近在學習怎么開發(fā)一個組件庫。按需打包的使用要使用按需打包,不僅組件庫的打包需要做處理,項目中也需要做處理。
Vue組件庫開發(fā)總結(jié)
由于工作需要,最近在學習怎么開發(fā)一個Vue組件庫。主要需要實現(xiàn)以下點:
1.組件使用npm包引入
2.實現(xiàn)按需引入及按需打包
項目中許多實現(xiàn)是參考的element-ui,特別是webpack打包部分
項目生成是直接用的vue-cli,在根目錄下增加了一個index.js,用于組件打包的入口文件,兩個webpack打包文件,以及一個組件的json文件,用于之后的按需引入的打包。組件放置在src/cmps中,目錄結(jié)構(gòu)如下圖:
由于我的組件把樣式都寫在了vue里面,所以沒有多帶帶的樣式文件,就是一個Vue文件和一個js入口文件
vue組件的編寫需要按照官方的vue插件開發(fā)規(guī)范來。為了實現(xiàn)后續(xù)的按需打包,在每一組件的入口文件中,都需要定義install方法,并隨組件一同暴露出來
import Button from "./index.vue" Button.intall = function (vue) { vue.component(Button.name, Button) } export default Button所有組件輸出編寫
所有組件的輸出就是將所有組件暴露出去,并加上一個對所有組件的install方法。其中if(window && window.Vue) install(window.Vue)是用來實現(xiàn)script標簽引入的方式的。
import Input from "src/cmps/input/index.js" import Toast from "src/cmps/toast/index.js" import Button from "src/cmps/button/index.js" const cmps = [ Input, Toast, Button ] const install = vue => { cmps.map(cmp => { vue.component(cmp.name, cmp) }) } if(window && window.Vue) install(window.Vue) export default { install, Input, Toast, Button }組件打包 全量加載的打包
全量加載的打包首先是把vue-cli生成的webpack文件改一下打包的出入口文件和路徑就行了。為了方便之后的按需加載的打包,出口文件我的路徑放在了lib目錄下。
為了實現(xiàn)npm包、script標簽等引入形式,libraryTarget選擇了umd模式。library是npm包引入時的名稱。entry的寫法是我為了用dev在本地測試組件是否可用而寫的。externals是為了去除在組件庫和實際項目中會重復的庫,比如vue
entry: ENV == "dev"? path.resolve(__dirname, "./src/main.js"): path.resolve(__dirname, "./index.js"), output: { path: path.resolve(__dirname, "./lib"), publicPath: "/dist/", filename: "input-ui.js", library: "input-ui", libraryExport: "default", libraryTarget: "umd" }, externals: { vue: "vue" }
package.json中需要加入對主入口的說明
"main": "lib/input-ui.js"按需加載的打包
按需加載的打包主要是參考了element-ui的代碼。需要對每個組件多帶帶打包,以及對所有組件全量打包。其實我沒有明白這里的全量打包和上面說的量加載的全量打包有什么區(qū)別。好像是libraryTarget不一樣,element-ui中,全量打包的主入口文件的libraryTarget是commonjs2,而按需打包中的主入口文件的libraryTarget是umd。我這里的libraryTarget是隨便寫的,因為我其實并不需要用到采用script標簽的引入方式。
按需加載的打包是將所有組件多帶帶打包,和全量打包的差別也只是出入口的差別。
const entry = require("./comps.json") module.exports = { entry , output: { path: path.resolve(__dirname, "./lib"), publicPath: "/dist/", filename: "[name].js", chunkFilename: "[id].js", libraryTarget: "commonjs2" },
comps.json
{ "input": "./src/cmps/input", "toast": "./src/cmps/toast", "button": "./src/cmps/button" }按需打包的使用
要使用按需打包,不僅組件庫的打包需要做處理,項目中也需要做處理。通過上面的方式打包的組件庫,在項目中可以使用babel-plugin-component來實現(xiàn)按需打包。
在.babelrc中加入這個組件。libraryName是需要按需打包的庫名。由于我的簡陋的組件中,沒有引用多帶帶的樣式,所以style設成了false,不然在引用組件時,還需要獲取一個樣式文件。之前提到為了方便按需打包,所以打包后的目錄是lib,這是由于babel-plugin-component默認的庫的目錄就是lib,如果需要修改目錄只需要加入"libDir": "lib"具體的babel-plugin-component的使用可以官方的readme。
"plugins": [["component", { "libraryName": "input-ui", "style": false }]]
然后就可以在項目中使用按需引入的方式來使用組件了
import {Input, Button} from "input-ui" Vue.component(Input.name, Input) Vue.component(Button.name, Button)npm包本地測試
在發(fā)布npm包之前,我們需要先在本地測試這個包是否到達我們預想的效果。這時,我們可以使用npm link把我們需要測試的包link到npm本地的全局。再在本地測試項目中通過npm link 本地測試的包名把我們要測試的本地包引入測試項目中,便可以對我們只做的組件庫npm包進行本地測試了。
npm包發(fā)布首先需要在npm官網(wǎng)注冊賬號。npmjs.com
然后添加用戶npm adduser填入賬號密碼及郵箱。
通過npm publish發(fā)布包就行了。如果遇到報錯說沒有權(quán)限發(fā)布該包,基本上是因為這個包名已被使用。換個其他的名字就行了。而且每次發(fā)布包都需要修改版本號,不同發(fā)布兩個相同的版本號。
這是本人第一次寫文章,而且本人水平有限,對webpack的打包,其實并不是很了解,所以寫的有些亂,甚至可能有些錯誤,請大家及時指出,感謝。gitHub
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/104936.html
摘要:文件夾結(jié)構(gòu)文件夾里的文件夾設置是靈活的,可以根據(jù)自己的習慣進行,不必雷同。對文件夾配置的總結(jié)先到此為止,下一篇文章會是對文件夾里具體文件的配置和例子總結(jié),有需要的可以去看看。 之前一段時間都在使用 vue 開發(fā)后臺管理系統(tǒng),在摸索的過程中對 vue 本身和模塊化、規(guī)范化開發(fā)有了更深的認知,現(xiàn)在記錄下來,希望對其他需要開發(fā)項目的人有幫助。 項目配置 首先,在確定好使用的框架和組件庫后,先...
摘要:文件夾結(jié)構(gòu)文件夾里的文件夾設置是靈活的,可以根據(jù)自己的習慣進行,不必雷同。對文件夾配置的總結(jié)先到此為止,下一篇文章會是對文件夾里具體文件的配置和例子總結(jié),有需要的可以去看看。 之前一段時間都在使用 vue 開發(fā)后臺管理系統(tǒng),在摸索的過程中對 vue 本身和模塊化、規(guī)范化開發(fā)有了更深的認知,現(xiàn)在記錄下來,希望對其他需要開發(fā)項目的人有幫助。 項目配置 首先,在確定好使用的框架和組件庫后,先...
摘要:項目問題總結(jié)這個項目,很簡單,前端使用,后端使用進行開發(fā)。方便移動端開發(fā)。當動畫結(jié)束后,有一個鉤子函數(shù)可以使用其他一些功能組件,都是自己嘗試去編寫的,像日歷組件組件組件等。版本的,是沒有任何的鉤子函數(shù),我就感覺懵逼了。。。 todo-list 項目問題總結(jié) 這個 todo-list 項目,很簡單,前端使用 react,后端 nodejs 使用 koa2 進行開發(fā)。數(shù)據(jù)庫使用 Mysql...
閱讀 2575·2021-11-22 09:34
閱讀 3552·2021-11-15 11:37
閱讀 2355·2021-09-13 10:37
閱讀 2116·2021-09-04 16:40
閱讀 1596·2021-09-02 15:40
閱讀 2467·2019-08-30 13:14
閱讀 3337·2019-08-29 13:42
閱讀 1914·2019-08-29 13:02