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

站長資訊網
最全最豐富的資訊網站

如何從0擼出一個Vue組件庫并發布到npm

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

如何從0擼出一個Vue組件庫并發布到npm

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

生成package.json如下,注意如果要發布到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、建立目錄結構

目錄結構如下

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

3、本地調試

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

在testvue下的package.json下的測試依賴devDependencies添加vueComponentDi/index.js絕對地址

"devDependencies": {     ...     "vuecomponentdi": "F:/vueComponent@Di/vueComponentDi",//根據自己實際項目地址填寫     ...     }
  • 執行npm link

在testvue執行npm link將vuecomponentdi軟鏈接到node_modules中

  • vuecomponentdi安裝Eslint

由于testvue引入組件會進行Eslint檢測,不安裝會報錯(testvue關閉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>

控制臺打印>本地調試

4、開發一個button組件

  • button模塊:進入vueComponentDi/packages/button/index.vue

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

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

listeners" 傳入內部組件

<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模塊導出:進入vueComponentDi/packages/button/index.js

如果導出一個帶有install函數的對象,則在Vue2中可以直接使用Vue.use(xx)調用此函數,既執行 Vue.component(name,option)創建了一個組件

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

因為開發的組件不止一個,所以需要在入口文件統一導出

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、開發一個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模塊導出:vueComponentDi/packages/toast/index.js

因為toast彈窗需要在vue中支持this.$toast調用,所以用了Vue.extend方法,這個 API 在日常開發中很少使用,一般在開發組件的時候它才能派上用場,官方定義:使用基礎 Vue 構造器,創建一個“子類”。參數是一個包含組件選項的對象

import toast from './index.vue' toast.install = (Vue) => {     const toastConstructor = Vue.extend(toast);//使用基礎 Vue 構造器,創建一個“子類”。參數是一個包含組件選項的對象。     let $vm = new toastConstructor();//將這個子類實例化     let $el = $vm.$mount().$el;//$vm執行$mount()手動掛載會返回一個帶有$el的對象,$el就是一個dom對象     document.querySelector("body").appendChild($el);//將這個dom對象添加到body中     //在Vue原型上注入$toast方法     Vue.prototype.$toast = (option) => {         $vm.show = true         if (!(option instanceof Object)) {             //如果傳的不是對象直接彈出             $vm.message = option         } else {             $vm.message = option.message             $vm.type = option.type         }         setTimeout(() => {             $vm.show = false         }, 2000)     } }   export default toast
  • 聚合導出: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("這是一個普通彈窗");       // this.$toast({       //   message: "這是一個成功彈窗",       //   type: "success",       // });       this.$toast({         message: "這是一個警告彈窗",         type: "warning",       });     },   }, }; </script>

6、發布到npm

  • 公有配置

組件開發完成需要發布到npm以便于別人使用;因為發布的是公有包,所以需要在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"   } }
  • 發布

npm發布很簡單,只需要兩個命令:

npm login npm publish

執行npm login需要你有npm賬號,可以到 npm官網 注冊

npm官網地址:https://www.npmjs.com/

發布完成之后就可以在任何一個vue2項目中安裝使用了:

npm install vuecomponentdi

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

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
国产裸体舞一区二区三区| 91免费视频黄| www成人免费| av在线网站免费观看| 日韩高清第一页| 亚洲第一色av| 日本成人xxx| 在线观看18视频网站| 99中文字幕在线| 涩多多在线观看| 异国色恋浪漫潭| 亚洲区成人777777精品| 中国 免费 av| 日韩精品综合在线| 男人的天堂狠狠干| 国产三区在线视频| 噼里啪啦国语在线观看免费版高清版 | 91aaa精品| 青青草影院在线观看| 久久久久久久9| 日韩欧美精品在线观看视频| 欧美丰满熟妇bbbbbb百度| 免费看a级黄色片| 久久久九九九热| 国产二区视频在线| 亚洲一二三区av| 最新视频 - x88av| avav在线看| 红桃视频 国产| 高清欧美精品xxxxx| 日韩手机在线观看视频| 亚洲最新免费视频| 精品少妇在线视频| 欧美午夜aaaaaa免费视频| a级网站在线观看| 国产裸体免费无遮挡| 不卡中文字幕在线| 免费黄色特级片| 成人免费a级片| 午夜免费看毛片| 国产极品粉嫩福利姬萌白酱| 一区二区成人网| 中文字幕无码精品亚洲资源网久久| 大陆极品少妇内射aaaaa| 欧美xxxxxbbbbb| 成年人小视频网站| 国产欧美精品aaaaaa片| 国产又大又黄又粗又爽| 成人毛片视频网站| 国产成人生活片| 91av视频免费观看| 992kp快乐看片永久免费网址| 无码毛片aaa在线| 国产传媒免费观看| 十八禁视频网站在线观看| 成人免费观看在线| 黄黄视频在线观看| 日本高清免费在线视频| 亚欧美在线观看| 无码人妻精品一区二区三区在线 | 日韩免费视频播放| 国产一区二区三区在线免费| 色婷婷.com| 色综合五月婷婷| 亚洲a级黄色片| 91极品视频在线观看| 欧美亚洲另类色图| 日本a在线免费观看| 欧美 日韩 国产精品| 国产又大又长又粗又黄| 中文字幕一区二区在线观看视频| 污网站免费在线| av免费一区二区| 中文字幕55页| 超碰人人爱人人| 国产人妻人伦精品| 女人帮男人橹视频播放| 国产在线视频在线| 自慰无码一区二区三区| 国产淫片av片久久久久久| 天天影视综合色| 在线播放免费视频| 黄色一级视频播放| 人体内射精一区二区三区| 亚洲国产精品成人天堂| 国产第一页视频| 97人人爽人人| 青青草原网站在线观看| 日本福利视频一区| 激情五月开心婷婷| 日本中文字幕影院| 日本国产中文字幕| avav在线看| 9l视频自拍9l视频自拍| 777久久久精品一区二区三区| 国产成人综合一区| 色乱码一区二区三区熟女| 日韩av中文字幕第一页| 天天干天天操天天做| 日本黄色片一级片| 日本人视频jizz页码69| 成人在线免费观看视频网站| 日韩中文字幕三区| 一区二区三区一级片| 日韩网址在线观看| 免费观看国产视频在线| 香蕉视频网站入口| 青青青青草视频| 国产高清精品软男同| 人妻内射一区二区在线视频| 美国av在线播放| 熟妇人妻无乱码中文字幕真矢织江| 国产一区一区三区| 最新中文字幕免费视频| 国产成人在线免费看| 喜爱夜蒲2在线| mm131亚洲精品| 波多野结衣之无限发射| 日韩成人午夜影院| 亚洲一区二区福利视频| 熟妇人妻va精品中文字幕 | 欧美一级中文字幕| 日本人视频jizz页码69| aa在线免费观看| 大荫蒂性生交片| 免费成人深夜夜行网站视频| mm131亚洲精品| 91色国产在线| 男人插女人下面免费视频| 欧美性大战久久久久xxx| 超碰成人免费在线| www.av蜜桃| 精品成在人线av无码免费看| 天天爱天天做天天操| gogogo免费高清日本写真| 不卡中文字幕在线| 福利网在线观看| 国产午夜精品视频一区二区三区| 九九九九九九九九| 在线视频日韩欧美| 成人短视频在线看| 日韩专区第三页| 日韩视频在线视频| 国产最新免费视频| 日本新janpanese乱熟| 校园春色 亚洲色图| 亚洲欧美久久久久| 一级黄色片在线免费观看| 国产精品探花在线播放| 免费看av软件| av在线观看地址| 激情综合网婷婷| 超碰在线播放91| 97人人模人人爽人人澡| 男人天堂av片| 婷婷激情四射五月天| 欧美精品色视频| 无码播放一区二区三区| 国产av人人夜夜澡人人爽| 日本人69视频| 日本手机在线视频| wwwwww.色| 免费看日b视频| 国内自拍视频网| 国产91在线亚洲| 国产精品一区二区羞羞答答| 国产高潮呻吟久久久| 欧美 国产 小说 另类| 91丝袜超薄交口足| 日韩av在线综合| 日本精品免费视频| 青青在线免费观看视频| 天天做天天躁天天躁| 亚洲成人福利在线观看| 日本福利视频网站| 中文字幕免费高清在线| 亚洲美免无码中文字幕在线| 精品亚洲视频在线| 欧美色图另类小说| 日本精品福利视频| 日本xxxx黄色| 欧美 国产 日本| 黄色三级中文字幕| 中文字幕 欧美日韩| 午夜欧美福利视频| 5月婷婷6月丁香| avav在线播放| 日本老太婆做爰视频| 日韩一级免费片| 国产一区二区在线免费播放| 欧美 丝袜 自拍 制服 另类| 免费看污污视频| 永久免费在线看片视频| 激情文学亚洲色图| 国产成人美女视频| av在线网址导航| 中文字幕免费高清在线| www午夜视频| 五月天av在线播放| 亚洲涩涩在线观看|