亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

前言

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

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

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

在正常函數(shù)中

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

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

在箭頭函數(shù)中

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

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

vue實(shí)例訪問(wèn)methods

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

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

methods實(shí)現(xiàn)原理

我們可以自己寫(xiě)一個(gè)僅針對(duì)于methods配置項(xiàng)的js文件(methods實(shí)現(xiàn)原理)

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

原理:

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

將該文件引入到代碼中

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

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

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

相關(guān)文章

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

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

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

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

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

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

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

    在vue中使用v-bind:class的選項(xiàng)卡方法

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

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

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

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

    下面小編就為大家分享一篇element ui 對(duì)話框el-dialog關(guān)閉事件詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    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添加按鈕的加載效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • vue-cli3.0如何修改端口號(hào)

    vue-cli3.0如何修改端口號(hào)

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

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

    經(jīng)常在項(xiàng)目中會(huì)有支持pc與手機(jī)端需求,并且pc與手機(jī)端是兩個(gè)不一樣的頁(yè)面,這時(shí)就要求判斷設(shè)置,下面這篇文章主要給大家介紹了關(guān)于VUE識(shí)別訪問(wèn)設(shè)備是pc端還是移動(dòng)端的相關(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)境變量不生效的解決方法,通過(guò)文中介紹的方法可以很方便的解決遇到的問(wèn)題,對(duì)大家學(xué)習(xí)或者使用vue3具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08

最新評(píng)論