Vue中methods實(shí)現(xiàn)原理是什么
前言
vue實(shí)例對象為什么可以訪問methods中的函數(shù)方法?methods的實(shí)現(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>
由上述代碼驗(yàn)證得出,在普通函數(shù)中,this是指向vm的,也就是vue實(shí)例對象
在箭頭函數(shù)中
app2:()=>{ console.log(this); console.log(vm === this); }
由上得知,在箭頭函數(shù)中,this不是指向vue實(shí)例對象的,而是指向window。其實(shí)在箭頭函數(shù)是沒有this的,箭頭函數(shù)的this是從父級作用域中繼承過來的,在上述代碼中,window作用域就是父級作用域
vue實(shí)例訪問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í)例對象訪問methods中的函數(shù)是沒有做數(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)原理
我們可以自己寫一個(gè)僅針對于methods配置項(xiàng)的js文件(methods實(shí)現(xiàn)原理)
// 定義一個(gè)類 class Vue { // 定義構(gòu)造函數(shù) // options是一個(gè)純粹的js對象:{} constructor(options){ // 獲取所有的方法名 Object.keys(options.methods).forEach((methodName,index)=>{ // 給當(dāng)前的Vue實(shí)例一個(gè)擴(kuò)展方法 this[methodName] = options.methods[methodName] }) } }
原理:
通過Object.keys()獲取vue實(shí)例中所有的方法名,然后通過forEach()遍歷,在上述代碼中,this就是指向vm,也就是vue實(shí)例對象,給實(shí)例對象一個(gè)拓展方法,而是什么拓展方法與methods中的方法同名,從而達(dá)到了通過vue實(shí)例可以訪問到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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式
這篇文章主要介紹了Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式
這篇文章主要介紹了Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04在vue中使用v-bind:class的選項(xiàng)卡方法
今天小編就為大家分享一篇在vue中使用v-bind:class的選項(xiàng)卡方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09vant組件中 dialog的確認(rèn)按鈕的回調(diào)事件操作
這篇文章主要介紹了vant組件中 dialog的確認(rèn)按鈕的回調(diào)事件操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11element ui 對話框el-dialog關(guān)閉事件詳解
下面小編就為大家分享一篇element ui 對話框el-dialog關(guān)閉事件詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02Vue給?elementUI?中的?this.$confirm、this.$alert、?this.$promp
這篇文章主要介紹了Vue給?elementUI?中的?this.$confirm、this.$alert、?this.$prompt添加按鈕的加載效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07VUE識別訪問設(shè)備是pc端還是移動(dòng)端的實(shí)現(xiàn)步驟
經(jīng)常在項(xiàng)目中會(huì)有支持pc與手機(jī)端需求,并且pc與手機(jī)端是兩個(gè)不一樣的頁面,這時(shí)就要求判斷設(shè)置,下面這篇文章主要給大家介紹了關(guān)于VUE識別訪問設(shè)備是pc端還是移動(dòng)端的相關(guān)資料,需要的朋友可以參考下2023-05-05vue3?process.env.XXX環(huán)境變量不生效的解決方法
這篇文章主要給大家介紹了關(guān)于vue3?process.env.XXX環(huán)境變量不生效的解決方法,通過文中介紹的方法可以很方便的解決遇到的問題,對大家學(xué)習(xí)或者使用vue3具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08