【面試題】為什麼有時用Vue.use()?及Vue.use()的作用及原理是什麼?

来源:https://www.cnblogs.com/mochenxiya/archive/2022/08/10/16574177.html
-Advertisement-
Play Games

Vue.use()的作用及原理 點擊打開視頻講解 在Vue中引入使用第三方庫通常我們都會採用import的形式引入進來 但是有的組件在引入之後又做了Vue.use()操作 有的組件引入進來又進行了Vue.prototype.$axios = axios 那麼它們之間有什麼聯繫呢? 例如:Vue.us ...


Vue.use()的作用及原理

點擊打開視頻講解

在Vue中引入使用第三方庫通常我們都會採用import的形式引入進來
但是有的組件在引入之後又做了Vue.use()操作
有的組件引入進來又進行了Vue.prototype.$axios = axios
那麼它們之間有什麼聯繫呢?

例如:Vue.use(VueRouter)、Vue.use(MintUI)。但是用 axios時,就不需要用 Vue.use(axios),就能直接使用。那這是為什麼吶?
因為 axios 沒有 install。

Vue.use是什麼?

官方對 Vue.use() 方法的說明:通過全局方法 Vue.use() 使用插件,Vue.use 會自動阻止多次註冊相同插件,它需要在你調用 new Vue() 啟動應用之前完成,Vue.use() 方法至少傳入一個參數,該參數類型必須是 Object 或 Function,如果是 Object 那麼這個 Object 需要定義一個 install 方法,如果是 Function 那麼這個函數就被當做 install 方法。在 Vue.use() 執行時 install 會預設執行,當 install 執行時第一個參數就是 Vue,其他參數是 Vue.use() 執行時傳入的其他參數。就是說使用它之後調用的是該組件的install 方法。

Vue.use()什麼時候使用?

ElementUI、VueRouter等官方插件的使用
在vue官方社區中提供了一系列輔助開發的插件,其中就有很多插件具有install方法,
比如ElementUI和VueRouter,我們使用Vue.use()進行引入。
import Vue from 'vue'
import VueRouter from 'vue-router';
import Element from 'element-ui'

Vue.use(VueRouter);
Vue.use(Element);
自定義插件,並提供install方法
除了使用官方的插件,我們也可以自定義一些含有install方法的插件或函數插件

src\main.js

import Vue from 'vue'
import App from './App.vue'
//引入ElementUI組件庫
import ElementUI from 'element-ui';
//引入ElementUI全部樣式
import 'element-ui/lib/theme-chalk/index.css';

import {Plugin1,Plugin2} from './plugins/plugins.js'

Vue.config.productionTip = false

//使用ElementUI
Vue.use(ElementUI)

Vue.use(Plugin1,'參數1')

Vue.use(Plugin2,'參數2')

new Vue({
  render: h => h(App),
}).$mount('#app')

src\plugins\plugins.js

// 對象形式
const Plugin1 = {

    install(Vue,b){
  
      console.log('Plugin1 第一個參數:',Vue)
  
      console.log('Plugin1 第二個參數:',b)
  
    }
  
  }

// 函數形式
function Plugin2(Vue,b){

    console.log('Plugin2 第一個參數:',Vue)

    console.log('Plugin2 第二個參數:',b)

}

export{ Plugin1, Plugin2 }

效果:
在這裡插入圖片描述

Vue.prototype作用

vue.prototype是一種註冊全局變數的方式,使用vue.prototype的變數可以全局訪問。
最典型的例子就是axios。
import axios from 'axios';
Vue.prototype.$http = axios;

註冊了axios之後就能在項目的位置使用了,使用的方法:
調用this.$http進行訪問。

實際上我們還要註意,使用Vue.prototype註冊的全局變數前面都要加上$符號,這是一種規範,主要是為了防止命名衝突。

Vue.use()和Vue.prototype的區別

Vue.use()用於註冊具有install方法的變數,註冊後install函數會自動調用,使得install的具體變數能夠全局使用,包括全局變數,全局標簽等等。

而Vue.prototype就是一個註冊全局變數的方法,註冊的全局的變數以$開頭,調用this方法調用。

Vue.use()總結

通過以上分析我們可以知道,在我們以後編寫插件的時候可以有兩種方式。

一種是將這個插件的邏輯封裝成一個對象,最後將在 install 編寫業務代碼暴露給 Vue 對象。這樣做的好處是可以添加任意參數在這個對象上方便將 install 函數封裝得更加精簡,可拓展性也比較高。推薦使用object;

還有一種則是將所有邏輯都編寫成一個函數暴露給 Vue。

其實兩種方法原理都一樣,無非第二種就是將這個插件直接當成 install 函數來處理。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先nosql可以被理解為not only sql 泛指非關係型資料庫,也就是說不僅僅是sql,所以它既包含了sql的一些東西,但是又和sql不同,併在其的基礎上改變或者說擴展了一些東西。 提到nosql,首先我們就要分析一下關係型資料庫的行式存儲和非關係型資料庫的列式存儲區別在哪? 行式存儲我們都 ...
  • Redis命令手冊 字元串 SET SET key value [EX seconds] [PX milliseconds] [NX|XX] 將字元串值value關聯到key。 如果key已經持有其他值,set就覆寫舊值,無視類型。 當set命令對一個帶有生存時間(TTL)的鍵進行設置之後,該鍵原有 ...
  • 概述 Redis 官方提供了兩種不同的持久化方法來將數據存儲到硬碟,分別是: 快照(Snapshot) AOF(Append Only File)只追加日誌文件 預設開啟快照,同時啟用兩種持久化方式時,優先 AOF 快照(Snapshot) 這種方式可以將某一時刻的所有數據都寫入硬碟,保存的文件以 ...
  • 《在 S3 備份恢復 RadonDB MySQL 集群數據》一文中我們展示了在 S3 存儲中對集群數據備份恢復的具體操作過程,但只是手動備份。RadonDB MySQL Kubernetes 2.2.0 新增支持 S3 的定時備份功能(NFS 的支持也在路上)。 下麵讓我們來看一下該功能是如何使用的 ...
  • Maven使用與學習 一、Maven是什麼 maven像是一種管理的工具,實現的原理是使用插件。比如說,一個公司需要做一個項目,這個項目被分成了很多模塊,每個模塊又分成了許多的業務,這些最後都需要整合到一起。那麼就會出現一個很大的問題,在項目開發中每個人使用的jar包版本、軟體版本等如果不一樣的話, ...
  • 伺服器環境:centos7 x64 需要安裝:mysql5.7+ 一、卸載CentOS7系統自帶mariadb # 查看系統自帶的Mariadb [root@CDH-141 ~]# rpm -qa|grep mariadb mariadb-libs-5.5.44-2.el7.centos.x86_6 ...
  • GreatSQL社區原創內容未經授權不得隨意使用,轉載請聯繫小編並註明來源。 GreatSQL是MySQL的國產分支版本,使用上與MySQL一致。 前言 JMeter是apache公司基於java開發的一款開源壓力測試工具,體積小,功能全,使用方便,是一個比較輕量級的測試工具,使用起來非常簡單。而且 ...
  • 因為喜愛,人們會將二次元形象製作成玩偶手辦,然而沒有生命氣息的冰冷模型並不能滿足人們互動性的情感需求。如何能讓帶有情感寄托的玩偶手辦更具表現力和感染力呢? 近日,HMS Core 3D建模服務上線自動骨骼綁定能力,可以讓已建成模型的二足人形物體根據自定義動作活動起來,甚至與用戶產生互動,不再只是冰冷 ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...