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

Vue中methods實現(xiàn)原理是什么

 更新時間:2023年11月15日 11:44:59   作者:軟工不禿頭  
methods是如何綁定this的 methods綁定上下文執(zhí)行環(huán)境是通過bind來進行的呢,本文給大家介紹Vue中methods實現(xiàn)原理是什么,感興趣的朋友一起看看吧

前言

vue實例對象為什么可以訪問methods中的函數(shù)方法?methods的實現(xiàn)原理是什么?

回調(diào)函數(shù)中的this指向問題

在解答前言中的問題前,需要了解一下回調(diào)函數(shù)中的this指向問題

在正常函數(shù)中

 <div class="app">
        <h1>{{msg}}</h1>
        <button @click="app">+1</button>
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'this指向問題',
                count:0
            },
            methods:{
                app(){
                    console.log(this);
                    console.log(vm === this);
                }
            }
        })
    </script>

由上述代碼驗證得出,在普通函數(shù)中,this是指向vm的,也就是vue實例對象

在箭頭函數(shù)中

 app2:()=>{
                    console.log(this);
                    console.log(vm === this);
                }

由上得知,在箭頭函數(shù)中,this不是指向vue實例對象的,而是指向window。其實在箭頭函數(shù)是沒有this的箭頭函數(shù)的this是從父級作用域中繼承過來的,在上述代碼中,window作用域就是父級作用域

vue實例訪問methods

   <div class="app">
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'methods的實現(xiàn)原理'
            },
            methods:{
                app(){
                    alert('hh')
                }
            }
        })
    </script>

由上述代碼及結(jié)果得出,Vue實例對象訪問methods中的函數(shù)是沒有做數(shù)據(jù)代理的,數(shù)據(jù)代理會調(diào)用getter方法,也就是上述截圖中msg后面的...,當我們點擊時,就會調(diào)用getter方法查看數(shù)據(jù),所有數(shù)據(jù)代理只會代理數(shù)據(jù),不會代理函數(shù)方法

methods實現(xiàn)原理

我們可以自己寫一個僅針對于methods配置項的js文件(methods實現(xiàn)原理)

// 定義一個類
class Vue {
    // 定義構(gòu)造函數(shù)
    // options是一個純粹的js對象:{}
    constructor(options){
        // 獲取所有的方法名
        Object.keys(options.methods).forEach((methodName,index)=>{
            // 給當前的Vue實例一個擴展方法
            this[methodName] = options.methods[methodName]
        })
    }
}

原理:

通過Object.keys()獲取vue實例中所有的方法名,然后通過forEach()遍歷,在上述代碼中,this就是指向vm,也就是vue實例對象,給實例對象一個拓展方法,而是什么拓展方法與methods中的方法同名,從而達到了通過vue實例可以訪問到methods中的方法

將該文件引入到代碼中

 <div class="app">
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'methods的實現(xiàn)原理'
            },
            methods:{
                app(){
                    alert('hh')
                },
                app2(){
                    alert('xx')
                }
            }
        })
    </script>

若上即是methods實現(xiàn)原理

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

相關(guān)文章

  • Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認值方式

    Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認值方式

    這篇文章主要介紹了Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認值方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3.0封裝輪播圖組件的步驟

    vue3.0封裝輪播圖組件的步驟

    這篇文章主要介紹了vue3.0封裝輪播圖組件的步驟,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-03-03
  • Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式

    Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式

    這篇文章主要介紹了Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 在vue中使用v-bind:class的選項卡方法

    在vue中使用v-bind:class的選項卡方法

    今天小編就為大家分享一篇在vue中使用v-bind:class的選項卡方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vant組件中 dialog的確認按鈕的回調(diào)事件操作

    vant組件中 dialog的確認按鈕的回調(diào)事件操作

    這篇文章主要介紹了vant組件中 dialog的確認按鈕的回調(diào)事件操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • element ui 對話框el-dialog關(guān)閉事件詳解

    element ui 對話框el-dialog關(guān)閉事件詳解

    下面小編就為大家分享一篇element ui 對話框el-dialog關(guān)閉事件詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue給?elementUI?中的?this.$confirm、this.$alert、?this.$prompt添加按鈕加載效果

    Vue給?elementUI?中的?this.$confirm、this.$alert、?this.$promp

    這篇文章主要介紹了Vue給?elementUI?中的?this.$confirm、this.$alert、?this.$prompt添加按鈕的加載效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • vue-cli3.0如何修改端口號

    vue-cli3.0如何修改端口號

    這篇文章主要介紹了vue-cli3.0如何修改端口號,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • VUE識別訪問設(shè)備是pc端還是移動端的實現(xiàn)步驟

    VUE識別訪問設(shè)備是pc端還是移動端的實現(xiàn)步驟

    經(jīng)常在項目中會有支持pc與手機端需求,并且pc與手機端是兩個不一樣的頁面,這時就要求判斷設(shè)置,下面這篇文章主要給大家介紹了關(guān)于VUE識別訪問設(shè)備是pc端還是移動端的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • vue3?process.env.XXX環(huán)境變量不生效的解決方法

    vue3?process.env.XXX環(huán)境變量不生效的解決方法

    這篇文章主要給大家介紹了關(guān)于vue3?process.env.XXX環(huán)境變量不生效的解決方法,通過文中介紹的方法可以很方便的解決遇到的問題,對大家學(xué)習(xí)或者使用vue3具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08

最新評論