回顧以前對元件的定義:
元件就是把圖形、非圖形的各種邏輯均抽象為一個統一的概念(元件)來實現開發的模式,在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', { /* ... */ })
1\
區域性註冊只需在用到的地方通過components
屬性註冊一個元件
const component1 = {...} // 定義一個元件 export default { components:{ component1 // 區域性註冊 } }
外掛的註冊通過Vue.use()
的方式進行註冊(安裝),第一個引數為外掛的名字,第二個引數是可選擇的設定項
Vue.use(外掛名字,{ /* ... */} )
注意的是:
註冊外掛的時候,需要在呼叫 new Vue()
啟動應用之前完成
Vue.use
會自動阻止多次註冊相同外掛,只會註冊一次
具體的其實在外掛是什麼章節已經表述了,這裡在總結一下
元件 (Component)
是用來構成你的 App
的業務模組,它的目標是 App.vue
外掛 (Plugin)
是用來增強你的技術棧的功能模組,它的目標是 Vue
本身
簡單來說,外掛就是指對Vue
的功能的增強或補充
(學習視訊分享:、)
以上就是淺析Vue中的外掛和元件,聊聊它們的區別!的詳細內容,更多請關注TW511.COM其它相關文章!