摘要:起源通過實(shí)現(xiàn)代碼代碼執(zhí)行后,縮放瀏覽器,此時(shí)彈窗顯示。不符合預(yù)期代碼分析按常理,綁定事件后,將會丟失所指向的上下文,所以第一個(gè)代碼執(zhí)行的結(jié)果是。源碼分析可以看到在實(shí)例上綁定的方法,都是被處理過的。
起源 通過 Class 實(shí)現(xiàn)代碼
class Demo { constructor() { this.num = 1 this.init() } resize() { alert(this.num) } init() { window.addEventListener("resize", this.resize) } } new Demo()
代碼執(zhí)行后,縮放瀏覽器,此時(shí)彈窗顯示 undefined。
符合預(yù)期!!
通過 Vue 實(shí)現(xiàn)的代碼import Vue from "vue" new Vue({ template: "", data: { num: 1 }, methods: { resize() { alert(this.num) } }, mounted() { window.addEventListener("resize", this.resize) } }).$mount("#app")
縮放瀏覽器,此時(shí)彈框顯示 1。
不符合預(yù)期!!
代碼分析按常理,綁定事件 this.resize 后,將會丟失 this 所指向的上下文,所以第一個(gè)代碼執(zhí)行的結(jié)果是 undefined。
因此猜想,在 Vue 的實(shí)現(xiàn)版本中,綁定是一定不是定義在 methods 下的 resize 方法。
源碼分析src/core/instance/state.js#L258
function initMethods (vm: Component, methods: Object) { const props = vm.$options.props for (const key in methods) { // ... vm[key] = methods[key] == null ? noop : bind(methods[key], vm) } }
可以看到在 Vue 實(shí)例上綁定的方法,都是被 bind 處理過的。
src/shared/util.js#L203
function polyfillBind (fn: Function, ctx: Object): Function { function boundFn (a) { const l = arguments.length return l ? l > 1 ? fn.apply(ctx, arguments) : fn.call(ctx, a) : fn.call(ctx) } boundFn._length = fn.length return boundFn } function nativeBind (fn: Function, ctx: Object): Function { return fn.bind(ctx) } export const bind = Function.prototype.bind ? nativeBind : polyfillBind
由此可見, Vue 的實(shí)例調(diào)用的方法,是經(jīng)過 bind 后帶有上下文的新方法。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/98580.html
摘要:開始研究核心代碼這個(gè)類首先是構(gòu)造函數(shù)看完上面的內(nèi)容大家應(yīng)該有點(diǎn)印象,上掛了和,是默認(rèn)的配置,顧名思義就是攔截器,目測包含了和兩種類型。喜歡就點(diǎn)個(gè)贊吧參考文章源代碼重點(diǎn)難點(diǎn)分析源代碼重點(diǎn)難點(diǎn)分析 axios是一個(gè)基于promise的http庫,支持瀏覽器和node端,最近我在做beauty-we的api設(shè)計(jì),研讀一個(gè)成熟的http庫勢在必行,axios功能完整、api簡潔、注釋清晰,再適...
摘要:這種解決方式也是相當(dāng)優(yōu)雅,值得學(xué)習(xí)源碼解析系列源碼解析一準(zhǔn)備工作源碼解析二函數(shù)源碼解析三對象源碼解析四方法源碼解析五鉤子源碼解析六模塊源碼解析七事件處理個(gè)人博客地址 事件處理 我們在使用 vue 的時(shí)候,相信你一定也會對事件的處理比較感興趣。 我們通過 @click 的時(shí)候,到底是發(fā)生了什么呢! 雖然我們用 @click綁定在模板上,不過事件嚴(yán)格綁定在 vnode 上的 。 event...
摘要:在學(xué)習(xí)源碼的過程中,給我?guī)椭畲蟮木褪沁@個(gè)系列文章,于是決定基于這個(gè)系列文章談一下自己的理解。說明就算拋出了錯(cuò)誤,部分的代碼也要繼續(xù)執(zhí)行,隨后再將錯(cuò)誤往上層代碼拋。和都能保證其中一個(gè)成員拋出錯(cuò)誤的時(shí)候,余下的能繼續(xù)執(zhí)行。 前言 React 是一個(gè)十分龐大的庫,由于要同時(shí)考慮 ReactDom 和 ReactNative ,還有服務(wù)器渲染等,導(dǎo)致其代碼抽象化程度很高,嵌套層級非常深,閱讀...
摘要:項(xiàng)目地址和的區(qū)別其實(shí)和最大的區(qū)別就是多了一個(gè)虛擬,其他的區(qū)別都是很小的。 項(xiàng)目地址 Vue1和Vue2的區(qū)別 其實(shí)Vue1和Vue2最大的區(qū)別就是Vue2多了一個(gè)虛擬DOM,其他的區(qū)別都是很小的。所以理解了Vue1的源碼,就相當(dāng)于理解了Vue2,中間差了一個(gè)虛擬DOM的Diff算法 文檔 數(shù)據(jù)雙向綁定 Vue主流程走向 組件 nextTick異步更新 MVVM 先來科普一下MVVM...
摘要:沒有具體對應(yīng)源碼分析,只是閱讀源碼的筆記,等之后學(xué)好點(diǎn)再寫成文章,構(gòu)造生成的。帶指令的所有元素,通過獲取,涉及,返回屬性選擇器對里的進(jìn)行綁定處理節(jié)點(diǎn)提取所有,返回?cái)?shù)組,元素是對象,包含。 沒有具體對應(yīng)源碼分析,只是閱讀源碼的筆記,等之后學(xué)好點(diǎn)再寫成文章 Vue self,構(gòu)造生成的this。 root根元素。 els帶指令的所有元素,通過querySelectorAll獲取,涉及ge...
閱讀 2934·2021-11-24 09:39
閱讀 3619·2021-11-22 13:54
閱讀 3419·2021-11-16 11:45
閱讀 2449·2021-09-09 09:33
閱讀 3203·2019-08-30 15:55
閱讀 1299·2019-08-29 15:40
閱讀 928·2019-08-29 15:19
閱讀 3406·2019-08-29 15:14