亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

實(shí)例教學(xué)如何寫(xiě)vue插件

 更新時(shí)間:2017年11月30日 10:10:45   投稿:laozhang  
本次小編通過(guò)一個(gè)簡(jiǎn)單的實(shí)例來(lái)教給大家如何寫(xiě)一個(gè)vue插件,以及需要注意的地方,如果有需要的讀者跟著學(xué)習(xí)一下吧。

在學(xué)習(xí)之前,先問(wèn)問(wèn)自己,為什么要編寫(xiě)vue的插件。

在一個(gè)項(xiàng)目中,尤其是大型項(xiàng)目,有很多部分需要復(fù)用,比如加載的loading動(dòng)畫(huà),彈出框。如果一個(gè)一個(gè)的引用也稍顯麻煩,而且在一個(gè)vue文件中引用的組件多了,會(huì)顯得代碼臃腫,所以才有了封裝vue插件的需求。

說(shuō)完需求,就來(lái)看看具體實(shí)現(xiàn)。目前我嘗試了兩種不一樣的插件編寫(xiě)的方法,逐個(gè)介紹。

這是我的項(xiàng)目目錄,大致的結(jié)構(gòu)解釋這樣,盡量簡(jiǎn)單,容易理解。

一個(gè)是loading插件,一個(gè)是toast插件,不同的地方在于:loading插件是作為組件引入使用,而toast插件是直接添加在掛載點(diǎn)里,通過(guò)方法改變狀態(tài)調(diào)用的。

目前使用起來(lái)是醬紫的:

toast插件

toast文件下有兩個(gè)文件,后綴為vue的文件就是這個(gè)插件的骨架,js文件一個(gè)是將這個(gè)骨架放入Vue全局中,并寫(xiě)明操作邏輯。

可以看一下toast.vue的內(nèi)容:

<template>
 <transition name="fade">
  <div v-show="show">
   {{message}}
  </div>

 </transition>
</template>

<script>
export default {
 data() {
 return {
  show: false,
  message: ""
 };
 }
};
</script>

<style lang="scss" scoped>
.toast {
 position: fixed;
 top: 40%;
 left: 50%;
 margin-left: -15vw;
 padding: 2vw;
 width: 30vw;
 font-size: 4vw;
 color: #fff;
 text-align: center;
 background-color: rgba(0, 0, 0, 0.8);
 border-radius: 5vw;
 z-index: 999;
}

.fade-enter-active,
.fade-leave-active {
 transition: 0.3s ease-out;
}
.fade-enter {
 opacity: 0;
 transform: scale(1.2);
}
.fade-leave-to {
 opacity: 0;
 transform: scale(0.8);
}
</style>

 

這里面主要的內(nèi)容只有兩個(gè),決定是否顯示的show和顯示什么內(nèi)容的message。

粗看這里,有沒(méi)有發(fā)現(xiàn)什么問(wèn)題?

這個(gè)文件中并沒(méi)有props屬性,也就是無(wú)論是show也好,message也好,就沒(méi)有辦法通過(guò)父子組件通信的方式進(jìn)行修改,那他們是怎么正確處理的呢。別急,來(lái)看他的配置文件。

index.js:

import ToastComponent from './toast.vue'

const Toast = {};

// 注冊(cè)Toast
Toast.install = function (Vue) {
 // 生成一個(gè)Vue的子類
 // 同時(shí)這個(gè)子類也就是組件
 const ToastConstructor = Vue.extend(ToastComponent)
 // 生成一個(gè)該子類的實(shí)例
 const instance = new ToastConstructor();

 // 將這個(gè)實(shí)例掛載在我創(chuàng)建的div上
 // 并將此div加入全局掛載點(diǎn)內(nèi)部
 instance.$mount(document.createElement('div'))
 document.body.appendChild(instance.$el)
 
 // 通過(guò)Vue的原型注冊(cè)一個(gè)方法
 // 讓所有實(shí)例共享這個(gè)方法 
 Vue.prototype.$toast = (msg, duration = 2000) => {
  instance.message = msg;
  instance.show = true;

  setTimeout(() => {
   
   instance.show = false;
  }, duration);
 }
}

export default Toast

 

這里的邏輯大致可以分成這么幾步:

創(chuàng)建一個(gè)空對(duì)象,這個(gè)對(duì)象就是日后要使用到的插件的名字。此外,這個(gè)對(duì)象中要有一個(gè)install的函數(shù)。使用vue的extend方法創(chuàng)建一個(gè)插件的構(gòu)造函數(shù)(可以看做創(chuàng)建了一個(gè)vue的子類),實(shí)例化該子類,之后的所有操作都可以通過(guò)這個(gè)子類完成。之后再Vue的原型上添加一個(gè)共用的方法。

這里需要著重提的是Vue.extend()。舉個(gè)例子,我們?nèi)粘J褂胿ue編寫(xiě)組件是這個(gè)樣子的:

Vue.component('MyComponent',{
 template:'<div>這是組件</div>'
})

 

這是全局組件的注冊(cè)方法,但其實(shí)這是一個(gè)語(yǔ)法糖,真正的運(yùn)行過(guò)程是這樣的:

let component = Vue.extend({
 template:'<div>這是組件</div>'
})

Vue.component('MyComponent',component)

 

Vue.extend會(huì)返回一個(gè)對(duì)象,按照大多數(shù)資料上提及的,也可以說(shuō)是返回一個(gè)Vue的子類,既然是子類,就沒(méi)有辦法直接通過(guò)他使用Vue原型上的方法,所以需要new一個(gè)實(shí)例出來(lái)使用。

在代碼里console.log(instance)

得出的是這樣的結(jié)果:

可以看到$el:div.toast

也就是toast組件模板的根節(jié)點(diǎn)。

疑惑的是,我不知道為什么要?jiǎng)?chuàng)建一個(gè)空的div節(jié)點(diǎn),并把這個(gè)實(shí)例掛載在上面。我嘗試注釋這段代碼,但是運(yùn)行會(huì)報(bào)錯(cuò)。

查找這個(gè)錯(cuò)誤的原因,貌似是因?yàn)?/p>

document.body.appendChild(instance.$el)

 

這里面的instance.$el的問(wèn)題,那好,我們console下這個(gè)看看。WTF?。。?!結(jié)果居然是undefined。

那接著

console.log(instance)

 

和上一張圖片比對(duì)一下,發(fā)現(xiàn)了什么?對(duì),$el消失了,換句話說(shuō)在我注釋了

instance.$mount(document.createElement('div'))

 

這句話之后,掛載點(diǎn)也不存在了。接著我試著改了一下這句:

instance.$mount(instance.$el)

 

$el又神奇的回來(lái)了………………

暫時(shí)沒(méi)有發(fā)現(xiàn)這種改動(dòng)有什么問(wèn)題,可以和上面一樣運(yùn)行。但無(wú)論如何,這也就是說(shuō)instance實(shí)例必須掛載在一個(gè)節(jié)點(diǎn)上才能進(jìn)行后續(xù)操作。

之后的代碼就簡(jiǎn)單了,無(wú)非是在Vue的原型上添加一個(gè)改變插件狀態(tài)的方法。之后導(dǎo)出這個(gè)對(duì)象。

接下來(lái)就是怎么使用的問(wèn)題了。來(lái)看看main.js是怎么寫(xiě)的:

import Vue from 'vue'
import App from './App'
// import router from './router'
import Toast from './components/taost'
Vue.use(Toast)

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({

 // router,
 render: h => h(App)
}).$mount('#app')

 

這樣就可以在其他vue文件中直接使用了,像這樣:

// app.vue
<template>
 <div id="app">
 <loading duration='2s' :isshow='show'></loading>
 <!-- <button @click="show = !show">顯示/隱藏loading</button> -->
 <button @click="toast">顯示taost彈出框</button>
 </div>
</template>

<script>
export default {
 name: "app",
 data() {
 return {
  show: false
 };
 },
 methods: {
 toast() {
  this.$toast("你好");
 }
 }
};
</script>

<style>
#app {
 font-family: "Avenir", Helvetica, Arial, sans-serif;
 -webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
 text-align: center;
 color: #2c3e50;
 margin-top: 60px;
}
</style>

通過(guò)在methods中增加一個(gè)方法控制寫(xiě)在Vue原型上的$toast對(duì)toast組件進(jìn)行操作。

這樣toast組件的編寫(xiě)過(guò)程就結(jié)束了,可以看到一開(kāi)始gif圖里的效果。

loading插件

經(jīng)過(guò)上一個(gè)插件的講解,這一部分就不會(huì)那么細(xì)致了,畢竟大多數(shù)都沒(méi)有什么不同,我只指出不一樣的地方。

<template>
 <div class='wrapper' v-if="isshow">
  <div class='loading'>
   <img src="./loading.gif">
  </div>
 </div>
</template>

<script>
export default {
 props: {
 duration: {
  type: String,
  default: "1s" //默認(rèn)1s
 },
 isshow: {
  type: Boolean,
  default: false
 }
 },
 data: function() {
 return {};
 }
};
</script>

<style lang="scss" scoped>

</style>

這個(gè)就只是一個(gè)模板,傳入兩個(gè)父組件的數(shù)據(jù)控制顯示效果。

那再來(lái)看一下該插件的配置文件:

import LoadingComponent from './loading.vue'

let Loading = {};

Loading.install = (Vue) => {
 Vue.component('loading', LoadingComponent)
}

export default Loading;

這個(gè)和taoat的插件相比,簡(jiǎn)單了很多,依然是一個(gè)空對(duì)象,里面有一個(gè)install方法,然后在全局注冊(cè)了一個(gè)組件。

比較

那介紹了這兩種不同的插件編寫(xiě)方法,貌似沒(méi)有什么不一樣啊,真的是這樣么?

來(lái)看一下完整的main.js和app.vue這兩個(gè)文件:

// main.js
import Vue from 'vue'
import App from './App'
// import router from './router'
import Toast from './components/taost'
import Loading from './components/loading'

Vue.use(Toast)

Vue.use(Loading)

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({

 // router,
 render: h => h(App)
}).$mount('#app')

// app.vue
<template>
 <div id="app">
 <loading duration='2s' :isshow='show'></loading>
 <!-- <button @click="show = !show">顯示/隱藏loading</button> -->
 <button @click="toast">顯示taost彈出框</button>
 </div>
</template>

<script>
export default {
 name: "app",
 data() {
 return {
  show: false
 };
 },
 methods: {
 toast() {
  this.$toast("你好");
 }
 }
};
</script>

<style>
#app {
 font-family: "Avenir", Helvetica, Arial, sans-serif;
 -webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
 text-align: center;
 color: #2c3e50;
 margin-top: 60px;
}
</style>

可以看出來(lái),loading是顯示的寫(xiě)在app.vue模板里的,而toast并沒(méi)有作為一個(gè)組件寫(xiě)入,僅僅是通過(guò)一個(gè)方法控制顯示。

來(lái)看一下html結(jié)構(gòu)和vue工具給出的結(jié)構(gòu):

看出來(lái)了么,toast插件沒(méi)有在掛載點(diǎn)里面,而是獨(dú)立存在的,也就是說(shuō)當(dāng)執(zhí)行

vue.use(toast)

之后,該插件就是生成好的了,之后的所有操作無(wú)非就是顯示或者隱藏的問(wèn)題了。

相關(guān)文章

  • vue3+vite項(xiàng)目中按需引入vant報(bào)錯(cuò):Failed?to?resolve?import的解決方案

    vue3+vite項(xiàng)目中按需引入vant報(bào)錯(cuò):Failed?to?resolve?import的解決方案

    最近在vue項(xiàng)目中引入vant的時(shí)候發(fā)現(xiàn)報(bào)錯(cuò)了,經(jīng)過(guò)嘗試發(fā)現(xiàn)了問(wèn)題,現(xiàn)將完整引入流程提供給大家參考,下面這篇文章主要給大家介紹了關(guān)于vue3+vite項(xiàng)目中按需引入vant報(bào)錯(cuò):Failed?to?resolve?import的解決方案,需要的朋友可以參考下
    2022-12-12
  • vite+vue3搭建的工程熱更新失效問(wèn)題及解決

    vite+vue3搭建的工程熱更新失效問(wèn)題及解決

    這篇文章主要介紹了vite+vue3搭建的工程熱更新失效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 老生常談vue2中watch的使用

    老生常談vue2中watch的使用

    watch的基本用法是在Vue實(shí)例中定義一個(gè)watch對(duì)象,該對(duì)象內(nèi)部包含需要監(jiān)聽(tīng)的數(shù)據(jù)項(xiàng)和對(duì)應(yīng)的回調(diào)函數(shù),這篇文章主要介紹了vue2中watch的使用,需要的朋友可以參考下
    2024-01-01
  • Vue3插槽Slot實(shí)現(xiàn)原理詳解

    Vue3插槽Slot實(shí)現(xiàn)原理詳解

    這篇文章主要為大家介紹了Vue3插槽Slot實(shí)現(xiàn)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Vue.js 中的異步組件是什么及使用異步組件的示例

    Vue.js 中的異步組件是什么及使用異步組件的示例

    異步組件是 Vue.js 中提高應(yīng)用程序性能和加載速度的重要功能之一,在使用異步組件時(shí),需要注意組件的加載時(shí)間、錯(cuò)誤處理和命名規(guī)范等問(wèn)題,本文將介紹 Vue.js 中異步組件的概念、優(yōu)勢(shì)以及如何使用異步組件,感興趣的朋友一起看看吧
    2023-10-10
  • vuex頁(yè)面刷新數(shù)據(jù)丟失問(wèn)題的四種解決方式

    vuex頁(yè)面刷新數(shù)據(jù)丟失問(wèn)題的四種解決方式

    vuex是大家使用vue時(shí)大多數(shù)都會(huì)選擇的,但是當(dāng)頁(yè)面刷新之后vuex數(shù)據(jù)會(huì)丟失,下面這篇文章主要給大家介紹了關(guān)于vuex頁(yè)面刷新數(shù)據(jù)丟失問(wèn)題的四種解決方式,需要的朋友可以參考下
    2022-02-02
  • 前端vue?uni-app?cc-countdown倒計(jì)時(shí)組件使用詳解

    前端vue?uni-app?cc-countdown倒計(jì)時(shí)組件使用詳解

    cc-countdown是一個(gè)倒計(jì)時(shí)組件,它可以顯示剩余時(shí)間、天數(shù)、小時(shí)數(shù)、分鐘數(shù)和秒數(shù),在本文中,我們將介紹如何在uni-app中使用cc-countdown組件,需要的朋友可以參考下
    2023-08-08
  • vue快捷鍵與基礎(chǔ)指令詳解

    vue快捷鍵與基礎(chǔ)指令詳解

    這篇文章主要介紹了vue快捷鍵與基礎(chǔ)指令詳解,需要的朋友可以參考下
    2017-06-06
  • VueJS組件之間通過(guò)props交互及驗(yàn)證的方式

    VueJS組件之間通過(guò)props交互及驗(yàn)證的方式

    本篇文章主要介紹了VueJS組件之間通過(guò)props交互及驗(yàn)證的方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-09-09
  • Vue 列表渲染 key的原理和作用詳解

    Vue 列表渲染 key的原理和作用詳解

    這篇文章主要介紹了key在Vue列表渲染時(shí)的原理和作用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10

最新評(píng)論