在JavaScript中重寫jQuery對(duì)象的方法實(shí)例教程
jQuery是一個(gè)款非常優(yōu)秀的類庫,它給我們解決了很多的客戶端編程,但是任何東西都不是萬能的,當(dāng)它不能滿足我們的需求時(shí)我們就需要對(duì)它進(jìn)行重寫,同時(shí)也不要影響其原有的功能或者修改其原有的功能;比如我現(xiàn)在的web應(yīng)用程序大多數(shù)時(shí)候的數(shù)據(jù)交互都是通過Ajax來完成的,這樣就可以將一些隱藏字段的數(shù)據(jù)保存在HTML標(biāo)簽的屬性中,使HTML標(biāo)簽的代碼量減少,如:ID,Timestamp等等,這些不需要用戶輸入但又不得不提交的字段,通過表單提交的做法是
<input name="ID" value="343" type="hidden" />
把ID的值保存在一個(gè)隱藏標(biāo)簽中,然后隨表單提交。
代碼如下所示:
<div> <label data-field="id" data-property="data-id" data-id="343">First Name</label><input type="text" data-field="FirstName" /> </div>
注意藍(lán)色的部分這個(gè)屬性名稱請(qǐng)不要太在意,您完全可以取一些更簡(jiǎn)潔名字,現(xiàn)在我們來重寫jQuery的val方法來讀取和設(shè)置data-id的值,給$.prototype.val重新定義一個(gè)函數(shù),以閉包的形式將基類函數(shù)傳入,以便在新函數(shù)中調(diào)用它,看下面這段代碼:
<script> $.prototype.val = function (base) { return function () { var s = this, a = "data-property", p = s.attr(a), isset = arguments.length > 0, v = isset ? arguments[0] : null; //這里調(diào)用基類方法,當(dāng)然基類方法在何時(shí)調(diào)用或者是否要調(diào)用取決于您的業(yè)務(wù)邏輯,在這里我們是要調(diào)用的,因?yàn)橐3炙械墓δ堋? if (isset&&typeof(base)=="function") { base.call(s, v); } else { v = base.call(s); } if (p) { if (isset) { s.attr(p, v); return s } else { return s.attr(p) } } else { if (!s.is(":input")) { if (isset) { s.text(v); return s; } else { return s.text(); } } else { return isset ? s : v; } } } //在這里傳入基類方法 }($.prototype.val); </script>
這個(gè)重寫了之后,當(dāng)在標(biāo)簽中指定了data-property屬性時(shí),jQuery對(duì)象調(diào)用val() 等同于調(diào)用attr("data-property"),但沒有指定data-property也就是默認(rèn)情況下,如果是非表單元素則是val()等同于text(),如果是表單元素則保持原來的功能也就是讀寫value屬性的值,這樣就可以通過這種方式:$("[data-field='id']").val(345)和$("[data-field='id']").val() 讀取或者設(shè)置它的值了,“data-field” 這個(gè)屬性將會(huì)映射到服務(wù)器上對(duì)應(yīng)類型的字段中,關(guān)于重寫JavaScript中的jQuery的方法就到這里了,其他方法的重寫是異曲同工的,大家可以舉一反三的思考。
全部代碼如下:
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>在JavaScript中重寫對(duì)象的方法</title> <script src="Scripts/jquery-1.8.2.min.js"></script> <script src="Scripts/jquery-ui-1.8.24.min.js"></script> <script> $.prototype.val = function (base) { return function () { var s = this, a = "data-property", p = s.attr(a), isset = arguments.length > 0, v = isset ? arguments[0] : null; if (isset&&typeof(base)=="function") { base.call(s, v); } else { v = base.call(s); } if (p) { if (isset) { s.attr(p, v); return s } else { return s.attr(p) } } else { if (!s.is(":input")) { if (isset) { s.text(v); return s; } else { return s.text(); } } else { return isset ? s : v; } } } }($.prototype.val); </script> </head> <body> <span id="lbl">Hello world!</span> <input type="text" id="txt" value="hello world" /> <input type="checkbox" value="哈哈哈。。。" /> </body> </html>
希望本文所述對(duì)大家的web前段設(shè)計(jì)有所幫助。
相關(guān)文章
在一個(gè)頁面實(shí)現(xiàn)兩個(gè)zTree聯(lián)動(dòng)的方法
最近發(fā)現(xiàn)項(xiàng)目中很多地方都是樹形菜單,而這些樹形菜單都是使用樹形插件zTree來制作的,下面這篇文章主要給大家介紹了關(guān)于在一個(gè)頁面實(shí)現(xiàn)兩個(gè)zTree聯(lián)動(dòng)的相關(guān)資料,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12jQuery實(shí)現(xiàn)動(dòng)態(tài)表單驗(yàn)證時(shí)文本框抖動(dòng)效果完整實(shí)例
這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)表單驗(yàn)證時(shí)文本框抖動(dòng)效果,可實(shí)現(xiàn)表單元素左右晃動(dòng)的抖動(dòng)功能,涉及jquery中元素的匹配與動(dòng)畫animate效果實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-08-08jQuery基于cookie實(shí)現(xiàn)的購(gòu)物車實(shí)例分析
這篇文章主要介紹了jQuery基于cookie實(shí)現(xiàn)購(gòu)物車的方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了jQuery基于cookie實(shí)現(xiàn)針對(duì)商品信息的購(gòu)物車存儲(chǔ)功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-12-12JQuery與Ajax調(diào)用新浪API獲取短網(wǎng)址的代碼
這篇文章主要介紹了調(diào)用新浪API獲取短網(wǎng)址的方法有很多,本例為大家介紹下使用JQuery與Ajax來實(shí)現(xiàn),需要的朋友可以參考下2014-02-02jQuery實(shí)現(xiàn)動(dòng)畫效果的簡(jiǎn)單實(shí)例
本篇文章主要是對(duì)jQuery實(shí)現(xiàn)動(dòng)畫效果的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-01-01