jquery中val函數重載的實作方法(附程式碼)
這篇文章帶給大家的內容是關於jquery中val函數重載的實作方法(附程式碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
所謂重載,就是一組相同的函數名,有不同個數的參數,使用時呼叫一個函數名,傳入不同參數,根據你的參數個數,來決定使用不同的函數!但我們知道js中是沒有重載的,因為後面定義的函數會覆寫前面的同名函數,但是我們又想實作函數重載該怎麼辦呢?
第一種方法:
這種方法比較簡單,給一個思路,大家一定都能理解,就是函數內部用switch語句,根據傳入參數的個數呼叫不同的case語句,從而在功能上達到重載的效果。
這個方法簡單粗暴
第二種方法:
function method(obj,name,fnc){ var old = obj[name]; console.log(old instanceof Function); obj[name] = function(){ console.log(arguments.length+" "+fnc.length); if(arguments.length === fnc.length){ return fnc.apply(this,arguments); }else if(typeof old === "function"){ return old.apply(this,arguments); } } } var people = { values:["Zhang san","Li si"] }; method(people,"find",function(){ console.log("无参数"); return this.values; }) method(people,"find",function(firstname){ console.log("一个参数"); var ret = []; for(var i = 0;i < this.values.length;i++){ if(this.values[i].indexOf(firstname) === 0){ ret.push(this.values[i]) } } return ret; }) method(people,"find",function(firstname,lastname){ console.log("两个参数"); var ret = []; for(var i = 0;i < this.values.length;i++){ if(this.values[i] == firstname + " " + lastname){ ret.push(this.values[i]) } } return ret; }) console.log(people.find()); console.log(people.find("Zhang"));
實作過程:我們看一下上面這段程式碼,最重要的是method方法的定義:這個方法中最重要的一點就是這個old,這個old真的很巧妙。它的作用相當於一個指針,指向上一次被呼叫的method函數,這樣說可能有點不太懂,我們根據程式碼來說,js的解析順序從上到下為。
1.解析method(先不管裡面的東西)
2.method(people,"find",function() 執行這句話的時候,它就回去執行上面定義的方法,然後此時old的值為空,因為你還沒有定義過這個函數,所以它此時是undefined,然後繼續執行,這是我們才定義obj[name] = function(),然後js解析的時候發現回傳了fnc函數,更重要的是fnc函數裡面還呼叫了method裡面的變量,這不就是閉包了,因為fnc函數的實作是在呼叫時候才會去實現,所以js就想,這我執行完也不能刪除啊,要不外面那個用啥,就留著吧先(此處用call函數改變了fnc函數內部的this指向)
3.好了第一次method的使用結束了,開始了第二句,method(people,"find",function(firstname) 然後這次使用的時候,又要執行old = obj[name]此時的old是什麼,是函數了,因為上一條語句定義過了,而且沒有刪除,那我這次的old實際上指向的是上次定義的方法,它起的作用好像一個指針,指向了上一次定義的obj[name]。然後繼續往下解析,又是閉包,還得留著。
4.第三此的method調用開始了,同理old指向的是上次定義的obj[name] 同樣也還是閉包,還得留著。
5.到這裡,內存中實際上有三個obj[name],因為三次method的內存都沒有刪除,這是不是實現了三個函數共存,同時還可以用old將它們連結起來是不是很巧妙
6.我們people.find() 的時候,就會最先調用最後一次調用method時定義的function,如果參數個數相同也就是 arguments.length === fnc.length 那就執行就好了,也不用找別的函數了,如果不相同的話,那就得用到old了 return old.apply(this,arguments); old指向的是上次method調用時定義的函數,所以我們就去上一次的找,如果找到了,繼續執行arguments.length === fnc.length 如果找不到,再次調用old 繼續向上找,只要你定義過,肯定能找到的,對吧!
總結:運用閉包的原理使三個函數共存於內存中,old相當於一個指針,指向上一次定義的function,每次調用的時候,決定是否需要尋找。
後續:說完上面的再對比下面的理解,會更深入的理解原型與原型鏈
var array=[] addMethod(array,'sub0',function(){ return 0; }) addMethod(array,'sub0',function(prefix){ console.log("prefix===>",prefix); return prefix[0]; }) array.sub0([1,2,3,5]) //这里是array对象拥有了sub0这样的方法,而不是Array,addMethod是继承 // 区别于方法直接作用于原型上 //例子 String的 startsWith 实现 function addstartsWithToString(){ if (typeof String.prototype.startsWith1 != 'function' ) { String.prototype.startsWith1 = function(subString){ return this.slice(0,subString.length)==subString } } } addstartsWithToString(); '120000'.startsWith1('1')
相關推薦:
##如何實作JS函數的重載_javascript技巧以上是jquery中val函數重載的實作方法(附程式碼)的詳細內容。更多資訊請關注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)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數
