亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

自定義Vue組件打包、發布到npm及使用教程

2019-11-19 11:30:14
字體:
來源:轉載
供稿:網友

本文將幫助:將自己寫的Vue組件打包到npm進行代碼托管,以及正常發布之后如何使用自己的組件。

  本文講述的僅僅是最基礎的實現,其他復雜的操作需要非常熟悉webpack的相關知識,作者將繼續學習。

  按照大佬文中寫的一步步操作,夠細心的話基本可以一步到位。下面總結一下發布步驟:

  1. 利用Vue的腳手架新建一個簡易版的Vue項目my-project:

  vue init webpack-simple my-project -> cd my-project -> npm i -> npm run dev

  2. 編寫組件:

  src下新建myPlugin文件夾用于存放所以開發的組件 -> 為每一個組件創建一個文件夾,其中存放一個vue組件文件和一個index.js配置文件 -> 在myPlugin下的最外層創建一個入口配置文件 -> 為每個人vue組件文件中加上一個name屬性

  3. 測試組件:

  在app.vue中測試一下自己的組件可不可以用

  4. 編寫配置文件

  為剛剛加入的每個組件文件夾中的index.js放入如下代碼:(其中ldcPagination為組件名)

import ldcPagination from './index.vue';ldcPagination.install = Vue => Vue.component(ldcPagination.name, ldcPagination);//.name就是開始說的vue文件暴露出來的name名,ldcPagination整個組件export default ldcPagination;

  為myPlugin下index.js放入如下代碼:(其中ldcPagination為組件名,多個組件直接在components數組中加入并在最后輸出出來就行)(引入的公共樣式文件等都可以放這個文件中)

import ldcPagination from './Pagination/index.js';const components = [ ldcPagination]const install = function(Vue, opts = {}) { components.forEach(component => {  Vue.component(component.name, component); });}if (typeof window !== 'undefined' && window.Vue) { install(window.Vue);}export default { install, ldcPagination}

  5. 改寫webpack.config.js配置文件

  將其中的輸入輸出換成如下代碼:

var path = require('path')var webpack = require('webpack')const NODE_ENV = process.env.NODE_ENV;module.exports = {//entry: './src/main.js',//output: {//  path: path.resolve(__dirname, './dist'),//  publicPath: '/dist/',//  filename: 'build.js'// },  entry: NODE_ENV == 'development' ? './src/main.js' : './src/myPlugin/index.js',  output: {   path: path.resolve(__dirname, './dist'),   publicPath: '/dist/',//路徑   filename: 'ldc-ui.js',//打包之后的名稱   library: 'ldc-ui', // 指定的就是你使用require時的模塊名   libraryTarget: 'umd', // 指定輸出格式   umdNamedDefine: true // 會對 UMD 的構建過程中的 AMD 模塊進行命名。否則就使用匿名的 define  },...}

  6. 發布前準備

  改寫package.json中的private為false,加入"main": "dist/ldc-ui.js", 其他的自定義 -> 新建.npmignore文件忽略不需要上傳的文件如.* *.md *.yml build/ node_modules/ src/ test/

  7. 發布

  npm run build 打包 -> 注冊npm賬號 -> npm login 登錄 -> npm publish 發布

  可能出現問題:

1. 登錄源錯誤, npm config get registry 可查看當前登錄源,npm config set registry=http://registry.npmjs.org 可切換到正確的登錄源

2. 版本號不能重復

3. 圖片資源打包后無法使用,所以自己的組件中不要使用

  使用組件方式:

1. npm i xxx -D

2. import XXX from 'xxx'

3. const { A, B } = XXX

4. 在Vue中注冊 components: { A, B }

總結

以上所述是小編給大家介紹的自定義Vue組件打包、發布到npm及使用教程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品白丝jk喷水视频一区| 欧美国产亚洲视频| 欧美理论电影在线观看| 欧美精品成人91久久久久久久| 国产欧美日韩专区发布| 亚洲国产婷婷香蕉久久久久久| 欧美性猛交丰臀xxxxx网站| 午夜精品三级视频福利| 精品中文字幕在线观看| 欧美在线观看网站| 成人www视频在线观看| 欧美成人中文字幕在线| 国产精品视频播放| 欧美中文字幕在线视频| 美女撒尿一区二区三区| 2018中文字幕一区二区三区| 国产欧美一区二区| 欧美一区视频在线| 欧美日韩国产激情| 91在线看www| 亚洲色图校园春色| 国内精品中文字幕| 美女啪啪无遮挡免费久久网站| 亚洲人成电影在线| 中文字幕日韩在线播放| 一道本无吗dⅴd在线播放一区| 久久91亚洲精品中文字幕| 精品亚洲一区二区三区在线播放| 精品久久久久人成| 亚洲新中文字幕| 亚洲美女性生活视频| 久久国产精品久久久| 欧美激情区在线播放| 日韩精品高清在线| 亚洲视频专区在线| 国产一区二区在线免费| 欧美成人精品h版在线观看| 久久精品久久久久久国产 免费| 欧美一级成年大片在线观看| 国产日韩精品综合网站| 亚洲国产97在线精品一区| 国产精品av在线| 日韩精品电影网| 亚洲国产成人精品久久| 69国产精品成人在线播放| 69久久夜色精品国产69| 日本一区二三区好的精华液| 久久久亚洲国产| 三级精品视频久久久久| 成人性生交大片免费看视频直播| 国产精品一二区| 最新69国产成人精品视频免费| 91精品视频免费观看| 亚洲天堂av在线免费观看| 亚洲色图激情小说| 日韩动漫免费观看电视剧高清| 国产精品嫩草影院久久久| 免费av一区二区| 精品综合久久久久久97| 国产精品精品久久久| 欧美理论电影在线观看| 欧美国产日本在线| 久久精视频免费在线久久完整在线看| 久久精品人人做人人爽| 久久精品国产69国产精品亚洲| 亚洲毛茸茸少妇高潮呻吟| 一个人看的www久久| 久久99青青精品免费观看| 隔壁老王国产在线精品| 国产一区二区三区日韩欧美| 国产日韩精品在线| 久久伊人色综合| 78色国产精品| 自拍偷拍亚洲在线| 亚洲精品日韩欧美| 成人免费网站在线| 国产美女精品免费电影| 亚洲国产精品高清久久久| 55夜色66夜色国产精品视频| 亚洲毛片在线观看.| 久久精品视频网站| 91久久在线视频| 午夜免费日韩视频| 亚洲另类激情图| 亚洲自拍偷拍在线| 伊人伊成久久人综合网小说| 日韩在线观看电影| 国产aaa精品| 青草热久免费精品视频| 日韩精品日韩在线观看| 中文欧美在线视频| 亚洲欧美一区二区三区在线| 日韩中文字幕视频在线观看| 96精品视频在线| 亚洲精品第一国产综合精品| 欧美性videos高清精品| 久久亚洲春色中文字幕| 成人做爽爽免费视频| 久热在线中文字幕色999舞| 国产欧美精品va在线观看| 午夜精品久久久久久久久久久久久| 亚洲高清久久久久久| 欧美高跟鞋交xxxxhd| 日韩免费在线播放| 欧美激情免费在线| 欧美日产国产成人免费图片| 亚洲国产精品va在线看黑人动漫| 国产91露脸中文字幕在线| 国产精品成人品| 国产精品三级在线| 久久手机精品视频| 视频直播国产精品| 久久理论片午夜琪琪电影网| 亚洲欧美成人一区二区在线电影| 亚洲欧美精品中文字幕在线| 国产精品国产自产拍高清av水多| 久久精品99久久香蕉国产色戒| 98视频在线噜噜噜国产| 欧美成人免费视频| 国产玖玖精品视频| 欧美色图在线视频| 精品在线观看国产| 国产精品亚洲激情| 欧美成人精品在线播放| 久久艹在线视频| 国产精品成人久久久久| 午夜精品久久久久久99热软件| 中文字幕免费精品一区高清| 欧美一区二区三区免费视| 91精品国产91久久久久久久久| 亚洲一区二区久久久久久| 亚洲欧洲在线观看| 97在线观看免费| 欧美第一页在线| 国产成人精彩在线视频九色| 亚洲高清久久久久久| 欧美xxxx做受欧美| 成人精品久久av网站| 成人动漫网站在线观看| 97香蕉超级碰碰久久免费的优势| 亚洲摸下面视频| 日韩免费在线看| 欧美性猛交xxxx乱大交3| 午夜精品久久久久久久久久久久久| 成人免费看片视频| 日本精品视频在线| 精品丝袜一区二区三区| 欧美在线视频免费| 欧美大尺度激情区在线播放| 亚洲男人天堂网| 欧美成年人网站| 国产精品视频久久| 国产亚洲欧美日韩美女| 欧美又大又粗又长| 欧美电影院免费观看| 国产精品亚洲一区二区三区| 黑人精品xxx一区一二区| 亚洲美女在线看| 国产综合在线看| 日韩激情av在线免费观看| 性欧美视频videos6一9| 日本三级韩国三级久久| 69**夜色精品国产69乱| 国产精品草莓在线免费观看|