gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長(zhǎng)資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

如何從0擼出一個(gè)Vue組件庫(kù)并發(fā)布到npm

如何從0擼出一個(gè)Vue組件庫(kù)并發(fā)布到npm?下面本篇文章手把手帶大家從0開發(fā)一個(gè)Vue組件庫(kù),看看怎么發(fā)布到npm,希望對(duì)大家有所幫助。

如何從0擼出一個(gè)Vue組件庫(kù)并發(fā)布到npm

1、新建文件夾在終端打開執(zhí)行 npm init -y

生成package.json如下,注意如果要發(fā)布到npm,name不能有下劃線,大寫字母等

{   "name": "vuecomponentdi",   "version": "1.0.0",   "description": "",   "main": "index.js",   "scripts": {     "test": "echo "Error: no test specified" && exit 1"   },   "keywords": [],   "author": "",   "license": "ISC" }

2、建立目錄結(jié)構(gòu)

目錄結(jié)構(gòu)如下

-- vueComponentDi     -- packages         -- button             -- index.js             -- index.vue         -- toast             -- index.js             -- index.vue     -- index.js     -- package.json

3、本地調(diào)試

  • vueComponentDi/index.js
export default function(){     console.log('本地調(diào)試') }
  • 新建一個(gè)vue項(xiàng)目
vue create testvue

在testvue下的package.json下的測(cè)試依賴devDependencies添加vueComponentDi/index.js絕對(duì)地址

"devDependencies": {     ...     "vuecomponentdi": "F:/vueComponent@Di/vueComponentDi",//根據(jù)自己實(shí)際項(xiàng)目地址填寫     ...     }
  • 執(zhí)行npm link

在testvue執(zhí)行npm link將vuecomponentdi軟鏈接到node_modules中

  • vuecomponentdi安裝Eslint

由于testvue引入組件會(huì)進(jìn)行Eslint檢測(cè),不安裝會(huì)報(bào)錯(cuò)(testvue關(guān)閉Eslint可省略這一步)

安裝方法:

 npm install eslint@6.7.2 --save-dev  ./node_modules/.bin/eslint --init
  • 在testvue使用vuecomponentdi

import test from "vuecomponentdi"

<template>   <div class="home">     <img alt="Vue logo" src="../assets/logo.png">     <HelloWorld msg="Welcome to Your Vue.js App"/>   </div> </template>  <script> // @ is an alias to /src import HelloWorld from '@/components/HelloWorld.vue' import test from "vuecomponentdi" export default {   name: 'Home',   components: {     HelloWorld   },   created(){     test()   } } </script>

控制臺(tái)打印>本地調(diào)試

4、開發(fā)一個(gè)button組件

  • button模塊:進(jìn)入vueComponentDi/packages/button/index.vue

type只支持傳入primary屬性,v-on="

listeners"表示包含了父作用域中的(不含.native修飾器的)v?on事件監(jiān)聽器。它可以通過v?on="listeners"表示包含了父作用域中的 (不含 .native 修飾器的) v-on 事件監(jiān)聽器。它可以通過 v-on="

listeners" 傳入內(nèi)部組件

<template>     <div>         <button class="di-button"  v-on="$listeners" :class="[type?`di-button--${type}`:'']"><slot></slot></button>     </div> </template> <script> export default {     name:"di-button",     props:{         type:String     } } </script> <style> .di-button{     display: inline-block;     line-height: 1;     white-space: nowrap;     cursor: pointer;     background: #fff;     border: 1px solid #dcdfe6;     color: #606266;     -webkit-appearance: none;     text-align: center;     box-sizing: border-box;     outline: none;     margin: 0;     transition: .1s;     font-weight: 500;     -moz-user-select: none;     -webkit-user-select: none;     -ms-user-select: none;     padding: 12px 20px;     font-size: 14px;     border-radius: 4px; } .di-button:focus, .di-button:hover {     color: #409eff;     border-color: #c6e2ff;     background-color: #ecf5ff; } .di-button:active {     color: #3a8ee6;     border-color: #3a8ee6;     outline: none; } .di-button--primary {     color: #fff;     background-color: #409eff;     border-color: #409eff; } .di-button--primary:focus, .di-button--primary:hover {     background: #66b1ff;     border-color: #66b1ff;     color: #fff; } .di-button--primary.is-active, .di-button--primary:active {     background: #3a8ee6;     border-color: #3a8ee6;     color: #fff; } </style>
  • button模塊導(dǎo)出:進(jìn)入vueComponentDi/packages/button/index.js

如果導(dǎo)出一個(gè)帶有install函數(shù)的對(duì)象,則在Vue2中可以直接使用Vue.use(xx)調(diào)用此函數(shù),既執(zhí)行 Vue.component(name,option)創(chuàng)建了一個(gè)組件

import button from "./index.vue" button.install=(Vue)=>{     Vue.component(button.name,button) } export default button
  • 聚合導(dǎo)出button:進(jìn)入vueComponentDi/index.js

因?yàn)殚_發(fā)的組件不止一個(gè),所以需要在入口文件統(tǒng)一導(dǎo)出

import diButton from "./packages/button" export {     diButton }
  • 在testvue使用
<template>   <div class="home">     <di-button type="primary">按鈕</di-button>   </div> </template> <script> // @ is an alias to /src  import Vue from 'vue' import {diButton} from "vuecomponentdi" Vue.use(diButton) export default {   name: 'Home' } </script>

5、開發(fā)一個(gè)toast彈窗

  • toast模塊:vueComponentDi/packages/toast/index.vue

type只支持warning和success

<template>     <div class="di-toast" :class="`di-toast--${type}`" v-if="show">         {{message}}     </div> </template> <script> export default {     data(){         return {             message:'',             show:false,             type:''         }     } } </script> <style> .di-toast{     width: 60%;     width: 200px;     background: rgb(15, 15, 15);     padding:3px;     text-align: center;     color: #fff;     border-radius: 10px;     position: fixed;     left: calc(50% - 100px);     top: 200px; } .di-toast--warning{     background: #FDF6EC;     color: #E6A28B; } .di-toast--success{     background: #F0F9EB;     color: #93C26D; } </style>
  • toast模塊導(dǎo)出:vueComponentDi/packages/toast/index.js

因?yàn)閠oast彈窗需要在vue中支持this.$toast調(diào)用,所以用了Vue.extend方法,這個(gè) API 在日常開發(fā)中很少使用,一般在開發(fā)組件的時(shí)候它才能派上用場(chǎng),官方定義:使用基礎(chǔ) Vue 構(gòu)造器,創(chuàng)建一個(gè)“子類”。參數(shù)是一個(gè)包含組件選項(xiàng)的對(duì)象

import toast from './index.vue' toast.install = (Vue) => {     const toastConstructor = Vue.extend(toast);//使用基礎(chǔ) Vue 構(gòu)造器,創(chuàng)建一個(gè)“子類”。參數(shù)是一個(gè)包含組件選項(xiàng)的對(duì)象。     let $vm = new toastConstructor();//將這個(gè)子類實(shí)例化     let $el = $vm.$mount().$el;//$vm執(zhí)行$mount()手動(dòng)掛載會(huì)返回一個(gè)帶有$el的對(duì)象,$el就是一個(gè)dom對(duì)象     document.querySelector("body").appendChild($el);//將這個(gè)dom對(duì)象添加到body中     //在Vue原型上注入$toast方法     Vue.prototype.$toast = (option) => {         $vm.show = true         if (!(option instanceof Object)) {             //如果傳的不是對(duì)象直接彈出             $vm.message = option         } else {             $vm.message = option.message             $vm.type = option.type         }         setTimeout(() => {             $vm.show = false         }, 2000)     } }   export default toast
  • 聚合導(dǎo)出:vueComponentDi/index.js
import diButton from "./packages/button"  import toast from "./packages/toast"   export {     diButton,     toast }
  • vuetest中使用toast
<template>   <div class="home">     <di-button type="primary" @click="toast">按鈕</di-button>   </div> </template> <script> // @ is an alias to /src  import Vue from "vue"; import { diButton, toast } from "vuecomponentdi"; Vue.use(diButton); Vue.use(toast); export default {   name: "Home",   methods: {     toast() {       // this.toast("這是一個(gè)普通彈窗");       // this.$toast({       //   message: "這是一個(gè)成功彈窗",       //   type: "success",       // });       this.$toast({         message: "這是一個(gè)警告彈窗",         type: "warning",       });     },   }, }; </script>

6、發(fā)布到npm

  • 公有配置

組件開發(fā)完成需要發(fā)布到npm以便于別人使用;因?yàn)榘l(fā)布的是公有包,所以需要在vueComponentDi/package.json中配置

"publishConfig": {     "access": "public"   },

完整package.json:

{   "name": "vuecomponentdi",   "version": "1.0.0",   "description": "",   "main": "index.js",   "scripts": {     "test": "echo "Error: no test specified" && exit 1"   },   "keywords": [],   "author": "",   "license": "ISC",   "devDependencies": {     "eslint": "^6.7.2",     "eslint-plugin-vue": "^8.2.0"   },   "publishConfig": {     "access": "public"   } }
  • 發(fā)布

npm發(fā)布很簡(jiǎn)單,只需要兩個(gè)命令:

npm login npm publish

執(zhí)行npm login需要你有npm賬號(hào),可以到 npm官網(wǎng) 注冊(cè)

npm官網(wǎng)地址:https://www.npmjs.com/

發(fā)布完成之后就可以在任何一個(gè)vue2項(xiàng)目中安裝使用了:

npm install vuecomponentdi

git地址: vue組件開發(fā)(https://gitee.com/geeksdidi/vue-component-di)

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
久久99中文字幕| 免费极品av一视觉盛宴| 久久国产精品国产精品| 黄色成人在线免费观看| 午夜免费福利视频在线观看| 日韩成人手机在线| 亚洲制服在线观看| 69堂免费视频| 国产精品久久中文字幕| 国产精品视频一二三四区| 污污的视频免费观看| 杨幂毛片午夜性生毛片| 成人性生生活性生交12| 超碰97人人射妻| 一卡二卡三卡视频| 欧美视频在线第一页| 青娱乐国产精品视频| 午夜激情视频网| 色一情一乱一乱一区91| 一区二区三区四区毛片| 久久成年人网站| 久久精品亚洲天堂| 欧美一区二区激情| 国产自产在线视频| 成人av在线播放观看| 日b视频免费观看| 无码aⅴ精品一区二区三区浪潮 | 日韩欧美国产片| 中文字幕一区二区三区四区在线视频| 91九色在线观看视频| 四虎4hu永久免费入口| 日本免费a视频| 国产老熟妇精品观看| 精品久久一二三| 激情内射人妻1区2区3区| 国产精品夜夜夜爽张柏芝| 国产精品入口芒果| 国产男女无遮挡| 国产91色在线观看| 深爱五月综合网| a级片一区二区| 人妻熟女一二三区夜夜爱| 成人免费毛片网| 久久久久久久久网| 国产伦精品一区二区三区四区视频_| 欧美 日韩精品| 在线观看中文av| 日本在线xxx| 人妻精品无码一区二区三区| 爽爽爽在线观看| 我的公把我弄高潮了视频| 毛葺葺老太做受视频| 小说区视频区图片区| 国产免费观看高清视频| 福利在线小视频| 亚洲免费av一区二区三区| 男人草女人视频| 99草草国产熟女视频在线| 色婷婷综合在线观看| 777视频在线| 日韩国产一级片| 国产性生活一级片| 国产激情在线观看视频| 国产精品jizz在线观看老狼| 欧美牲交a欧美牲交aⅴ免费下载| 蜜桃视频成人在线观看| 天堂中文av在线| 久久人人爽av| 亚洲免费一级视频| 在线视频日韩一区| 成人观看免费完整观看| 国产综合av在线| 日韩欧美精品在线观看视频| 免费无码不卡视频在线观看| 精品视频免费在线播放| 婷婷无套内射影院| 波多野结衣综合网| 黄色片网址在线观看| 欧美日韩精品在线一区二区 | 国模杨依粉嫩蝴蝶150p| www.中文字幕在线| 黄色手机在线视频| 永久av免费在线观看| 国产精品69久久久| 大香煮伊手机一区| 在线一区二区不卡| 青青草精品视频在线| 狠狠热免费视频| 异国色恋浪漫潭| 色综合久久久久无码专区| 日本成年人网址| 中文字幕丰满乱码| 日韩亚洲欧美视频| 午夜两性免费视频| 三年中国中文在线观看免费播放| 日本精品免费视频| 国产肥臀一区二区福利视频| 狠狠热免费视频| 免费网站永久免费观看| 免费看a级黄色片| 婷婷视频在线播放| 大香煮伊手机一区| 男插女免费视频| 漂亮人妻被中出中文字幕| 成人亚洲视频在线观看| 国产香蕉一区二区三区| 日本福利视频在线| 免费观看黄色的网站| 国产v亚洲v天堂无码久久久| 91制片厂免费观看| 亚洲人成无码www久久久| 国产精品88久久久久久妇女| 欧美性久久久久| 免费cad大片在线观看| 久久精品午夜福利| 国产精品免费看久久久无码| 日韩一级理论片| 无码人妻丰满熟妇区96| 手机成人av在线| 亚欧美在线观看| 999在线免费视频| 久久久久久久午夜| www.欧美黄色| 大桥未久一区二区| aaaaaaaa毛片| 91插插插影院| 看看黄色一级片| 亚洲精品综合在线观看| 一本久道中文无码字幕av| 超碰人人爱人人| 欧美一区二区视频在线播放| 欧美爱爱视频网站| 99精品视频网站| 亚洲天堂第一区| 日本精品福利视频| 精品一区二区三区毛片| 色乱码一区二区三区熟女 | bt天堂新版中文在线地址| 天天综合中文字幕| 免费成人深夜夜行网站视频| 在线免费观看视频黄| 四季av一区二区| 天天操,天天操| 中文字幕黄色大片| 亚洲AV无码成人精品一区| 欧美爱爱视频网站| 九九热只有这里有精品| 久久综合色视频| 色播五月综合网| 搡的我好爽在线观看免费视频| 久久6免费视频| 欧美精品在欧美一区二区| 久久久久久www| 日本www高清视频| 手机精品视频在线| 国产精品视频网站在线观看| 野外做受又硬又粗又大视频√| 成人精品视频在线播放| 久久精品香蕉视频| 色男人天堂av| 国产主播在线看| www激情五月| 国产精品久久国产| 300部国产真实乱| 欧美中文字幕在线观看视频| www婷婷av久久久影片| 免费网站在线观看视频| 欧美精品成人网| www.亚洲成人网| www.99r| 日韩xxxx视频| 五月天六月丁香| 18禁裸男晨勃露j毛免费观看| 天堂av2020| 色婷婷狠狠18| 国产天堂视频在线观看| 国产无套粉嫩白浆内谢的出处| 欧美国产日韩另类 | 妞干网在线免费视频| 天天色天天干天天色| 成人精品视频一区二区| www.激情网| 中文字幕55页| 亚洲最大成人在线观看| 欧美久久久久久久久久久久久| 特级西西444www| 日本肉体xxxx裸体xxx免费| 男人日女人视频网站| 天天操夜夜操很很操| 亚洲综合婷婷久久| 北条麻妃av高潮尖叫在线观看| 日韩av在线播放不卡| 久久免费一级片| 欧美精品色视频| 伊人色在线视频| 天天干天天操天天做| 日本www.色| 校园春色 亚洲色图| 国模杨依粉嫩蝴蝶150p| 日韩手机在线观看视频|