JavaScript函數綁定用法解析
本文主要介紹了JavaScript函數綁定用法,結合實例形式分析了javascript函數綁定的原理、實現方法與相關操作技巧,需要的朋友可以參考下,希望能幫助到大家。
Perface
#如果讓你實現這個頁面和一些操作的,例如點擊1、2 、3等就在那個input text中顯示,還有刪除功能,撥打我們先不要管它,只是模擬而已。要是我剛開始做的話,我會這樣做:
1. 用css、HTML佈局那個介面
2. 用javascript的事件委託監聽那個按鈕的父節點的點擊事件
但是如果我想用物件導向的想法做呢?我是用Ext做的,所以我想說的是它幫我封裝了很多。可能有些沒用過Ext的人不太了解我下面貼的程式碼,但我會盡量解釋清楚的!
Description
ContactTelPanel =Ext.extend(Ext.Panel, { //构造方法 constructor : function(config) { Ext.apply(this, config);//直接把config对象的属性全复制到this对象中 Parent = this.parent; var me = this; ContactTelPanel.superclass.constructor.call(this, {//用ContactTelPanel的父类也就是Ext.Panel的构造函数 autoScroll : true, title : "拨打电话",//设置title,跟这篇文章的主体没关系,不要管他 id : "contacttelpanel", bodyStyle : "padding: 30px 300px;", defaults : {//可以为该对象(ContactTelPanel)包含的组件(也就是在items配置选项)设置一些相同属性 layout : "column", defaults : { xtype : "button", width : 50, height : 25, style : "margin:4px 15px", handler : this.press //为每个按钮都添加一个click的事件 }, bodyBorder : false }, items : [ {//textfield组件 height : 30, width : 250, xtype : "textfield", id : "tf", style : "margin-bottom:10px" }, {// 没有xtype就是默认为panel,下面也是,不然就不要纠结了,直接在这里想象成第一行按钮1、按钮2、按钮3 items : [ { text : "1" }, { text : "2" }, { text : "3" } ] }, {// 这里是按钮4、按钮5、按钮6 items : [ { text : "4" }, { text : "5" }, { text : "6" } ] }, {// 这里是按钮7、按钮8、按钮9 下同 items : [ { text : "7" }, { text : "8" }, { text : "9" } ] }, { items : [ { text : "*" }, { text : "0" }, { text : "#" } ] }, { items : [ { text : "拨打", }, { text : "删除", } ] } ] }); }, press : function() { var text = this.text, textfield = Ext.getDom("tf"); if (/[0-9*#]/.test(text)) {//在textfield中显示所点击按钮的数字 textfield.value += text; } else if (this.text == "删除") {//删除功能 textfield.value = textfield.value.slice(0, -1); } else if (this.text == "拨打") {//这个先不要管他 Tel.telcall(textfield.value); } } });
註:其實從上面可以知道ContactTelPanel是繼承Ext.Panel,然後這個面板中有很多個鍵,每個鍵都監聽click事件。確實在這裡覺得自己敲得不是很好,應該是用事件委託來實現,因為你每個按鈕都監聽了click事件,太影響效率了。用事件委託我們可以指監聽它的父節點的click事件就行了,然後根據事件流來判斷目的對象並操作。本文重點還是監聽事件裡面handler : this.press
這段程式碼中 。我遇見的問題就是如果我在press函數要用到這個類別ContactTelPanel的一些屬性,該怎麼辦?
Idea
我在想,我想要在press函數中用到這個類別的屬性,我直接在press上用this物件來取得不就行了,但是我錯了,例如你在press函數中console.dir(this)
,看chrome控制台出現的是什麼?不幸的是它出現的是Button對象,它的this指針改了。確實有點麻煩,然後我就想了三個方法,如下:
Solution
1 在每個監聽事件的函數中傳參考
程式碼:handler : this.press(this)
,然後在press函數體內寫alert(arguments[0])
出現的情況:確實在這個頁面載入的時候就彈出視窗是ContactTelPanel,但是你點擊那些按鈕的時候它沒出現了
原因:this.press(this)
,這樣子寫javascript解析器會當作呼叫press函數,然後在你載入頁面就執行了
2 在這個ContactTelPanel類別中設定全域變數
程式碼:例如在第五行設定me = this,然後在press函數體中寫alert(me)
出現的情況:確實可以在點擊按鈕的時候彈出窗口,成功了
缺點:污染全域變量,容易被別人無意篡改。例如我在引入這個頁面的js後面再引用其他js的時候,在後面的js中設定var me = "monkindey",那麼你再點擊那個頁面的按鈕的時候它會彈出123,為不是ContactTelPanel物件
3 簡單運用了閉包
代碼:handler : function(){me.press(me)}
註:me就是ContactTelPanel對象,因為在function中this指標已經是button物件了,所以應該在function外面用me(或其他變數名稱)保存this對象,即var me = this
出現的情況:這當然是成功
4 用call來實作函數綁定
程式碼:handler : function(){ me.press.call(this,me );}
相關推薦:
#ES6中javascript實作函數綁定及類別的事件綁定功能
JavaScript中困難:prototype與建構子綁定實例詳解
#以上是JavaScript函數綁定用法解析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

深入解析HTTP狀態碼460的作用和應用場景HTTP狀態碼是Web開發中非常重要的一部分,用來表示客戶端和伺服器之間的通訊狀態。其中,HTTP狀態碼460是較為特殊的狀態碼,本文將深入解析它的作用與應用場景。 HTTP狀態碼460的定義HTTP狀態碼460的具體定義是"ClientClosedRequest",意為客戶端關閉請求。此狀態碼主要用於表示

iBatis和MyBatis:區別和優勢解析導語:在Java開發中,持久化是一個常見的需求,而iBatis和MyBatis是兩個廣泛使用的持久化框架。雖然它們有很多相似之處,但也有一些關鍵的區別和優勢。本文將透過詳細分析這兩個框架的特性、用法和範例程式碼,為讀者提供更全面的了解。一、iBatis特性:iBatis是目前較老舊的持久化框架,它使用SQL映射文件

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

Oracle錯誤3114詳解:如何快速解決,需要具體程式碼範例在Oracle資料庫開發與管理過程中,我們常常會遇到各種各樣的錯誤,其中錯誤3114是比較常見的一個問題。錯誤3114通常表示資料庫連線出現問題,可能是網路故障、資料庫服務停止、或連接字串設定不正確等原因導致的。本文將詳細解釋錯誤3114的產生原因,以及如何快速解決這個問題,並附上具體的程式碼

Wormhole在區塊鏈互通性方面處於領先地位,專注於創建有彈性、面向未來的去中心化系統,優先考慮所有權、控制權和無需許可的創新。這個願景的基礎是對技術專業知識、道德原則和社群一致性的承諾,旨在以簡單、清晰和廣泛的多鏈解決方案套件重新定義互通性格局。隨著零知識證明、擴容方案和功能豐富的Token標準的興起,區塊鏈變得更加強大,而互通性也變得越來越重要。在這個不斷創新的應用程式環境中,新穎的治理系統和實用功能為整個網路的資產帶來了前所未有的機會。協議建構者現在正在努力思考如何在這個新興的多鏈

【PHP中點的意義和用法解析】在PHP中,中點(.)是常用的運算符,用來連接兩個字串或物件的屬性或方法。在本文中,我們將深入探討PHP中點的意義和用法,並透過具體的程式碼範例加以說明。 1.連接字串中點運算子.在PHP中最常見的用法是連接兩個字串。透過將.放置在兩個字串之間,可以將它們拼接在一起,形成一個新的字串。 $string1=&qu

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

Win11新功能解析:跳過登入微軟帳號的方法隨著Windows11的發布,許多用戶發現其帶來了更多的便利性和新功能。然而,有些用戶可能不喜歡將其係統與微軟帳戶綁定,希望跳過這一步驟。本文將介紹一些方法,幫助使用者在Windows11中跳過登入微軟帳戶,並實現更私密、更自主的使用體驗。首先,讓我們來了解為什麼有些用戶不願意登入微軟帳號。一方面,一些用戶擔心他們
