欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

手寫Vue內(nèi)置組件component的實(shí)現(xiàn)示例

 更新時間:2022年07月18日 09:32:35   作者:CreatorRay  
本文主要介紹了手寫Vue內(nèi)置組件component的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

最近在復(fù)習(xí)Vue的源碼,今天帶大家手寫實(shí)現(xiàn)一下Vue內(nèi)置組件component,比較簡單,最近面試有被問到。

前言

Vue大家都很熟悉,除了原生的組件,其自己也封裝了一下內(nèi)置組件,比如componenttransition,keep-alive等等。

component算是用的比較多的了,當(dāng)我們遇到需要根據(jù)不同條件顯示不同組件的時候,一般都是用component來實(shí)現(xiàn)。當(dāng)然你也可以v-if,v-else-if,v-else,就顯的比較笨了。

大家如果沒用過,可以先自己嘗試一下這個component組件。最主要的就是它有一個is屬性,你給is賦予什么組件名,它就渲染什么組件。

內(nèi)置組件component的使用

我寫一個小demo演示一下。
先隨意的寫三個組件,A,BC。

在這里插入圖片描述

組件內(nèi)容就是aaaa,bbbb,cccc,方便我們辨認(rèn)當(dāng)然渲染的是哪個組件。

在這里插入圖片描述

然后集體引入,掛載。

在這里插入圖片描述

在這里插入圖片描述

視圖內(nèi)容大概這樣寫,需求就是,準(zhǔn)備三個按鈕,點(diǎn)擊哪個按鈕就顯示哪個組件。

    <div>
      <button @click="changeComp('A')">顯示A</button>
      <button @click="changeComp('B')">顯示B</button>
      <button @click="changeComp('C')">顯示C</button>
    </div>
    <component :is="compList"></component>

compList提前聲明好,默認(rèn)是A組件。

  data() {
    return {
      compList: 'A'
    };
  },

changeComp函數(shù)內(nèi)容如下:

  methods: {
    changeComp(comp) {
      this.compList = comp;
    },
  }

OK,這就完事了,大家可以自己試一下,是可以完成既定的需求的。

在這里插入圖片描述

component組件的原理分析

我們今天的任務(wù)是,了解內(nèi)置組件component的原理,并手寫實(shí)現(xiàn)一個。

那么component的實(shí)現(xiàn)原理是怎么樣的呢,這個就需要牽扯一塊比較大的知識鏈了,也是Vue的核心內(nèi)容。關(guān)于Vue虛擬DOM以及模板編譯的部分內(nèi)容。

簡單來說,Vue內(nèi)部實(shí)現(xiàn)了一個虛擬DOM來妥善解決原生DOM的性能問題。

虛擬DOM與原生DOM

比如我們當(dāng)前需要插入1000DOM節(jié)點(diǎn),如果是原生DOM來做的話,就是扎扎實(shí)實(shí)的,一個個操作,改變DOMDOM需要被改變1000次,這對于性能是極大的損耗,造成很多的問題。

虛擬DOM的原理就是,先在框架內(nèi)部用對象模擬一下原生DOM的形態(tài),記錄你這1000次的DOM操作,最后將DOM被操作1000次后的形態(tài)賦給原生DOM。這樣就能極大的優(yōu)化大量DOM操作帶來的負(fù)面影響。

然后再來思考一下,我們平時寫的.vue文件,其實(shí)跟原生寫法是有區(qū)別的,無論是HTMLJS還是CSS,在編寫階段有做了些許的改動,這樣做有助于提高我們的編寫效率。但是瀏覽器是只認(rèn)原生的HTMLCSSJS的,所以我們編寫的組件內(nèi)容,其實(shí)只是一個template模板,需要進(jìn)行編譯轉(zhuǎn)換為原生的DOM才能渲染到瀏覽器上。

componet組件其實(shí)就是內(nèi)部做了這個事情,將你傳入的組件, 先轉(zhuǎn)換為虛擬DOM,然后渲染為真實(shí)DOM,展示到視圖上。

render函數(shù)的使用

這里面就涉及到一個知識點(diǎn)了,關(guān)于render函數(shù)的使用,具體的內(nèi)容大家可以去Vue文檔詳細(xì)了解一下render函數(shù)。可能大家日常開發(fā)用的比較少,涉及一些偏底層的東西時才會遇到。

我這里只介紹render函數(shù)做的事情。
它的形態(tài)大概是這個樣式。

render(h) {
    // return h('A');
    return h('div', '6666');
},

render函數(shù)接收一個參數(shù),比如叫它h,h也是一個函數(shù),它的作用就是將傳入的內(nèi)容構(gòu)建為虛擬DOM,這個傳入的內(nèi)容支持原生的寫法,也支持Vue組件。

比如我代碼里給出的,h('div', '6666'),h函數(shù)就會生成一個div組件,文本內(nèi)容是666。被注釋掉的,就是傳入Vue中自己的寫的組件名字為A,同樣支持。

但是h函數(shù)僅僅只是將傳入的內(nèi)容,生成虛擬DOM,不是真實(shí)的原生DOM,然后將它return出去,render函數(shù)才會將這個虛擬DOM渲染成為真實(shí)DOM。

上述關(guān)于render函數(shù)的內(nèi)容不知道大家是否理解,可以去Vue官方文檔里,詳細(xì)看一下,然后自己寫寫demo體驗(yàn)一下,render函數(shù)算是Vue進(jìn)階中比較重要的內(nèi)容了。

所以,話說回來,知道了render函數(shù)這個東西,我們就能夠比較好的實(shí)現(xiàn)component這個內(nèi)置組件了。component組件會接收一個屬性is,is的值就是我們要渲染的組件。component組件的內(nèi)容其實(shí)就是進(jìn)行了 Vue組件 => 虛擬DOM => 真實(shí)DOM,渲染視圖,其實(shí)就通過render函數(shù)實(shí)現(xiàn)就可以。

嘗試手寫實(shí)現(xiàn)component

話不多說,我們試一下。

因?yàn)榻M件內(nèi)容比較少,所以我們直接使用Vue.component來編寫組件內(nèi)容。

Vue.component("myComponent", {
  props: ["is"],
  render(h) {
    return h(this.is);
  },
});

其實(shí)核心代碼就上面這幾行,組件名字是myComponent,props的作用就是指定組件要接收的參數(shù)is。然后編寫一下render函數(shù),因?yàn)槭卿秩?code>Vue組件,所以直接return h(this.is)就可以。

將這段代碼寫在JS里,然后就可以使用了。記得要import Vue from 'vue'來引入Vue,因?yàn)槲覀兪峭ㄟ^Vue.component來編寫組件的。

下面我們試一試,這個myComponent是否有用。

    <div>
      <button @click="changeComp('A')">顯示A</button>
      <button @click="changeComp('B')">顯示B</button>
      <button @click="changeComp('C')">顯示C</button>
    </div>
    <component :is="compList"></component>
    <my-component :is="compList"></my-component>

在這里插入圖片描述

實(shí)際操作后可以發(fā)現(xiàn),我們自己寫的myComponentVue內(nèi)置的component效果是一模一樣的,大家自己也可以試一下。

完整代碼:

<template>
  <div>
    <div>
      <button @click="changeComp('A')">顯示A</button>
      <button @click="changeComp('B')">顯示B</button>
      <button @click="changeComp('C')">顯示C</button>
    </div>
    <component :is="compList"></component>
    <my-component :is="compList"></my-component>
  </div>
</template>

<script>
import Vue from "vue";
import A from "../components/A.vue";
import B from "../components/B.vue";
import C from "../components/C.vue";

Vue.component("myComponent", {
  props: ["is"],
  render(h) {
    return h(this.is);
  },
});
export default {
  components: {
    A,
    B,
    C,
  },
  data() {
    return {
      compList: 'A'
    };
  },
  methods: {
    changeComp(comp) {
      this.compList = comp;
    },
  },
};
</script>

<style scoped>

</style>

總結(jié)

今天的內(nèi)容是帶著大家手寫實(shí)現(xiàn)Vue的內(nèi)置組件component,在嘗試實(shí)現(xiàn)某一個東西的時候,就需要先思考它的作用以及內(nèi)部原理。手寫component的過程比較簡單,但是涉及到了很多Vue的原理性知識點(diǎn),比如虛擬DOM、render函數(shù)、模板編譯等。

到此這篇關(guān)于手寫Vue內(nèi)置組件component的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Vue內(nèi)置組件component內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue-router 類似Vuex實(shí)現(xiàn)組件化開發(fā)的示例

    Vue-router 類似Vuex實(shí)現(xiàn)組件化開發(fā)的示例

    本篇文章主要介紹了Vue-router 類似Vuex實(shí)現(xiàn)組件化開發(fā)的示例,具有一定的參考價值,有興趣的可以了解一下
    2017-09-09
  • Vue router-view和router-link的實(shí)現(xiàn)原理

    Vue router-view和router-link的實(shí)現(xiàn)原理

    這篇文章主要介紹了Vue router-view和router-link的實(shí)現(xiàn)原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • vue2.0安裝style/css loader的方法

    vue2.0安裝style/css loader的方法

    下面小編就為大家分享一篇vue2.0安裝style/css loader的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue實(shí)現(xiàn)瀑布流布局的示例代碼

    vue實(shí)現(xiàn)瀑布流布局的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用vue實(shí)現(xiàn)簡單的瀑布流布局,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2023-09-09
  • vue.js,ajax渲染頁面的實(shí)例

    vue.js,ajax渲染頁面的實(shí)例

    下面小編就為大家分享一篇vue.js,ajax渲染頁面的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • vue-ajax小封裝實(shí)例

    vue-ajax小封裝實(shí)例

    下面小編就為大家?guī)硪黄獀ue-ajax小封裝實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Vue3中實(shí)現(xiàn)拖拽和縮放自定義看板 vue-grid-layout的方法

    Vue3中實(shí)現(xiàn)拖拽和縮放自定義看板 vue-grid-layout的方法

    這篇文章主要介紹了Vue3中實(shí)現(xiàn)拖拽和縮放自定義看板 vue-grid-layout的方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • vue報錯"vue-cli-service‘不是內(nèi)部或外部命令,也不是...”的解決辦法

    vue報錯"vue-cli-service‘不是內(nèi)部或外部命令,也不是...”的解決辦法

    這篇文章主要介紹了vue報錯"vue-cli-service‘不是內(nèi)部或外部命令,也不是...”的解決辦法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • vue使用中的內(nèi)存泄漏【推薦】

    vue使用中的內(nèi)存泄漏【推薦】

    內(nèi)存泄露是指new了一塊內(nèi)存,但無法被釋放或者被垃圾回收。這篇文章主要介紹了vue使用中的內(nèi)存泄漏,需要的朋友可以參考下
    2018-07-07
  • vue的rules驗(yàn)證部分可以部分又失效的原因及解決方案

    vue的rules驗(yàn)證部分可以部分又失效的原因及解決方案

    vue的rules驗(yàn)證失效,部分可以部分又失效,很多百度都有,但是我這里遇到了一個特別的,那就是prop沒有寫全,導(dǎo)致驗(yàn)證某一個失效,接下來就跟小編一起來看看這個失效的原因和解決方案吧
    2023-11-11

最新評論