日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

組件是什么?插件是什么?下面本篇文章帶大家了解一下Vue中的插件和組件,聊聊插件和組件的區別,希望對大家有所幫助!


淺析Vue中的插件和組件,聊聊它們的區別!


一、組件是什么

回顧以前對組件的定義:

組件就是把圖形、非圖形的各種邏輯均抽象為一個統一的概念(組件)來實現開發的模式,在Vue中每一個.vue文件都可以視為一個組件。

組件的優勢

降低整個系統的耦合度,在保持接口不變的情況下,我們可以替換不同的組件快速完成需求,例如輸入框,可以替換為日歷、時間、范圍等組件作具體的實現

調試方便,由于整個系統是通過組件組合起來的,在出現問題的時候,可以用排除法直接移除組件,或者根據報錯的組件快速定位問題,之所以能夠快速定位,是因為每個組件之間低耦合,職責單一,所以邏輯會比分析整個系統要簡單

提高可維護性,由于每個組件的職責單一,并且組件在系統中是被復用的,所以對代碼進行優化可獲得系統的整體升級

二、插件是什么

插件通常用來為 Vue 添加全局功能。插件的功能范圍沒有嚴格的限制——一般有下面幾種:

添加全局方法或者屬性。如: vue-custom-element

添加全局資源:指令/過濾器/過渡等。如 vue-touch

通過全局混入來添加一些組件選項。如vue-router

添加 Vue 實例方法,通過把它們添加到 Vue.prototype 上實現。

一個庫,提供自己的 API,同時提供上面提到的一個或多個功能。如vue-router

三、兩者的區別

兩者的區別主要表現在以下幾個方面:

編寫形式

注冊形式

使用場景

編寫形式

編寫組件

編寫一個組件,可以有很多方式,我們最常見的就是vue單文件的這種格式,每一個.vue文件我們都可以看成是一個組件

vue文件標準格式

<template>
</template>
<script>
export default{ 
    ...
}
</script>
<style>
</style>

我們還可以通過template屬性來編寫一個組件,如果組件內容多,我們可以在外部定義template組件內容,如果組件內容并不多,我們可直接寫在template屬性上

<template id="testComponent">     // 組件顯示的內容
    <div>component!</div>   
</template>
 
Vue.component('componentA',{ 
    template: '#testComponent' 
    template: `<div>component</div>`  // 組件內容少可以通過這種形式
})

編寫插件

vue插件的實現應該暴露一個 install 方法。這個方法的第一個參數是 Vue 構造器,第二個參數是一個可選的選項對象

MyPlugin.install = function (Vue, options) {
  // 1. 添加全局方法或 property
  Vue.myGlobalMethod = function () {
    // 邏輯...
  }
 
  // 2. 添加全局資源
  Vue.directive('my-directive', {
    bind (el, binding, vnode, oldVnode) {
      // 邏輯...
    }
    ...
  })
 
  // 3. 注入組件選項
  Vue.mixin({
    created: function () {
      // 邏輯...
    }
    ...
  })
 
  // 4. 添加實例方法
  Vue.prototype.$myMethod = function (methodOptions) {
    // 邏輯...
  }
}


注冊形式

組件注冊

vue組件注冊主要分為全局注冊與局部注冊

全局注冊通過Vue.component方法,第一個參數為組件的名稱,第二個參數為傳入的配置項

Vue.component('my-component-name', { /* ... */ })

局部注冊只需在用到的地方通過components屬性注冊一個組件

const component1 = {...} // 定義一個組件
 
export default {
    components:{
        component1   // 局部注冊
    }
}

插件注冊

插件的注冊通過Vue.use()的方式進行注冊(安裝),第一個參數為插件的名字,第二個參數是可選擇的配置項

Vue.use(插件名字,{ /* ... */} )

注意的是:

注冊插件的時候,需要在調用 new Vue() 啟動應用之前完成

Vue.use會自動阻止多次注冊相同插件,只會注冊一次


使用場景

具體的其實在插件是什么章節已經表述了,這里在總結一下

組件 (Component) 是用來構成你的 App 的業務模塊,它的目標是 App.vue

插件 (Plugin) 是用來增強你的技術棧的功能模塊,它的目標是 Vue 本身

簡單來說,插件就是指對Vue的功能的增強或補充


分享到:
標簽:Vue插件 Vue組件
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定