vue注冊(cè)全局插件的兩種方式

一、模仿element-ui中this.$message()方式創(chuàng)建全局插件

vue2.x環(huán)境下:寫(xiě)好的任意組件VantAlert.vue,需要注冊(cè)全局組件:

1、首先創(chuàng)建vantAlert.js文件開(kāi)發(fā)插件:

此文件暴露出一個(gè)擁有install方法的對(duì)象,install方法的第一個(gè)參數(shù)是Vue構(gòu)造器囤采,第二個(gè)參數(shù)option是可選的對(duì)象參數(shù)。使用vue.use()可以直接調(diào)用install方法。


import VantAlert from './VantAlert.vue'

export default {

install: (Vue) => {

// 利用Vue.extend創(chuàng)建構(gòu)造器

    const CommentAlert = Vue.extend(VantAlert)

// 實(shí)例化組件

    const instance = new CommentAlert()

// 為vue原型添加$commentAlert方法

    Vue.prototype.$commentAlert = (options = {}) => {

    // 掛載組件

      instance.$mount()

    // 將組件元素添加到body中

      document.body.appendChild(instance.$el)

    // 改變實(shí)例中data的值

      instance.show =true

    }

}

}

2畜挥、在main.js文件中導(dǎo)出的方法放到vue的原型鏈上


// main.js中引入函數(shù)文件

import vantAlert from "./components/commentAlert/component/vantAlert";

//使用插件,Vue.use應(yīng)該在new Vue()之前調(diào)用婴谱,并且Vue.use會(huì)阻止多次注冊(cè)相同組件蟹但,即使多次調(diào)用也只會(huì)注冊(cè)一次該組件。

Vue.use(vantAlert)

3谭羔、使用


this.$vantAlert({content:‘傳遞的參數(shù)’})

4华糖、注冊(cè)的組件內(nèi)正常編寫(xiě)代碼:傳遞過(guò)來(lái)的參數(shù)data接收


export default {

  name:"VantAlert",

  data() {

    return {

        show:true,

        content:'默認(rèn)的內(nèi)容',  //能夠接收傳遞過(guò)來(lái)的參數(shù)

        showTitle:false

     }

  }

}

vue3.0環(huán)境下:只是寫(xiě)法上稍微有些不同:

1、vantAlert.js文件更改如下


import {createApp } from 'vue'

import VantAlert './VantAlert.vue'

const vantAlert=function(options = {}) {

  //注冊(cè)組件,并接收傳遞的參數(shù)

  let messageConstructor =createApp(VantAlert, { ...options })

  //將組件掛載到body下瘟裸,instance.$el是需要掛載的組件

  messageConstructor.mount('body')

}

export default vantAlert

2客叉、main.js中將組件方法綁定到原型鏈上:


import {createApp } from 'vue'

import App from './App.vue'

import vantAlertfrom './components/vantAlert'

const app =createApp(App)

app.config.globalProperties.$vantAlert=vantAlert

3、使用傳參數(shù)跟vue2.x一樣

4景描、組件內(nèi)接收參數(shù)通過(guò)props接收參數(shù)


export default {

    name:"index",

    props: {

      content: {

         type:String,

         default:'暫無(wú)文案'

       }

  }

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末十办,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子超棺,更是在濱河造成了極大的恐慌向族,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,589評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件棠绘,死亡現(xiàn)場(chǎng)離奇詭異件相,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)氧苍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門(mén)夜矗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人让虐,你說(shuō)我怎么就攤上這事紊撕。” “怎么了赡突?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,933評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵对扶,是天一觀的道長(zhǎng)区赵。 經(jīng)常有香客問(wèn)我,道長(zhǎng)浪南,這世上最難降的妖魔是什么笼才? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,976評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮络凿,結(jié)果婚禮上骡送,老公的妹妹穿的比我還像新娘。我一直安慰自己絮记,他們只是感情好摔踱,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,999評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著怨愤,像睡著了一般昌渤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上憔四,一...
    開(kāi)封第一講書(shū)人閱讀 51,775評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音般眉,去河邊找鬼了赵。 笑死,一個(gè)胖子當(dāng)著我的面吹牛甸赃,可吹牛的內(nèi)容都是我干的柿汛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,474評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼埠对,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼络断!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起项玛,我...
    開(kāi)封第一講書(shū)人閱讀 39,359評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤貌笨,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后襟沮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體锥惋,經(jīng)...
    沈念sama閱讀 45,854評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,007評(píng)論 3 338
  • 正文 我和宋清朗相戀三年开伏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了膀跌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,146評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡固灵,死狀恐怖捅伤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巫玻,我是刑警寧澤丛忆,帶...
    沈念sama閱讀 35,826評(píng)論 5 346
  • 正文 年R本政府宣布祠汇,位于F島的核電站,受9級(jí)特大地震影響蘸际,放射性物質(zhì)發(fā)生泄漏座哩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,484評(píng)論 3 331
  • 文/蒙蒙 一粮彤、第九天 我趴在偏房一處隱蔽的房頂上張望根穷。 院中可真熱鬧,春花似錦导坟、人聲如沸屿良。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,029評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)尘惧。三九已至,卻和暖如春递递,著一層夾襖步出監(jiān)牢的瞬間喷橙,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,153評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工登舞, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贰逾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,420評(píng)論 3 373
  • 正文 我出身青樓菠秒,卻偏偏與公主長(zhǎng)得像疙剑,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子践叠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,107評(píng)論 2 356

推薦閱讀更多精彩內(nèi)容