自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

拋磚引玉 自定義jQuery擴(kuò)展接口

開發(fā) 開發(fā)工具 前端
jQuery是一款很優(yōu)秀的輕量級JavaScript框架,有其獨(dú)特的優(yōu)點(diǎn),本文將用一個(gè)簡單的例子演示jQuery的擴(kuò)展接口的簡單示例,希望能對讀者起到拋磚引玉的作用。

jQuery是一款很優(yōu)秀的輕量級JavaScript框架,有其獨(dú)特的優(yōu)點(diǎn)。很多Web開發(fā)者都卻對其樂此不疲。因?yàn)樵谶@個(gè)框架中,除了擁有豐富的客戶端處理功能、動(dòng)畫功能外,更是提供了很自定義擴(kuò)展接口,方便更多的開發(fā)者來擴(kuò)展jQuery。

51CTO推薦專題: jQuery從入門到精通

  1. $.extend({  
  2.       max: function(a, b) {  
  3.           return a > b ? a : b;  
  4.       },  
  5.       min: function(a, b) {  
  6.           return a > b ? b : a;  
  7.       },  
  8.       avg: function(a, b) {  
  9.           return a / b;  
  10.       }  
  11. });  

該示例用以在jQuery中增加新函數(shù),該函數(shù)是靜態(tài)函數(shù)。調(diào)用如下:

  1. jQuery.min(2,3); // => 2  
  2. jQuery.max(4,5); // => 5 


如果針對組件的功能擴(kuò)展函數(shù),同樣也是很簡單。比如,你想要擴(kuò)展TextBox的功能,使到它在獲取焦點(diǎn)時(shí),高亮顯示;失去焦點(diǎn)時(shí),則取消高亮。當(dāng)然,高亮的效果可以使用CSS來實(shí)現(xiàn),因此,你可以用一個(gè)顏色的名稱作為參數(shù)進(jìn)行調(diào)用。代碼如下:

  1. $.fn.hightlight = function(colorName) {  
  2.     this.mouseover(function() {  
  3.         $(this).css('background-color', colorName);   //this對是對組件自身的引用  
  4.     });  
  5.     this.mouseout(function() {  
  6.         $(this).css('background-color', '');  
  7.     });  

調(diào)用如下:

  1. $(function() {  
  2.     $('#test').hightlight('red');  
  3. });  

擴(kuò)展jQuery的Json技巧

下面我們將分析在jQuery基礎(chǔ)上擴(kuò)展了其處理Json字符串能力,偉大的jQuery將會(huì)更偉大用jQuery寫JavaScript非常高效,jQuery對Ajax的封裝也非常到位;使用jQuery一段時(shí)間后發(fā)現(xiàn),jQuery在處理Json字符串方面功能不是很強(qiáng),至少比prototype.js差遠(yuǎn)了。

以前用習(xí)慣了擴(kuò)展Jquery的Json,在進(jìn)行Ajax開發(fā)時(shí),處理json數(shù)據(jù)非常方便;而在jQuery中,只提供了一個(gè)簡單的jQuery.getJSON()方法,并未提供jQuery本身對json數(shù)據(jù)的轉(zhuǎn)換處理,將json字符串轉(zhuǎn)換為Javascript數(shù)據(jù)對象還比較容易利用eval()函數(shù)即可,但要將Javascript的數(shù)據(jù)類型轉(zhuǎn)換成json字符串就比較難了;剛開始不得同時(shí)使用prototype.js和jQuery。擴(kuò)展Jquery的Json代碼:

#p#

  1. //擴(kuò)展jQuery對json字符串的轉(zhuǎn)換    
  2. jQuery.extend({     
  3.  /** * @see 將json字符串轉(zhuǎn)換為對象   
  4.      * @param json字符串   
  5.      * @return 返回object,array,string等對象 */      
  6.  evalJSON: function(strJson)   
  7. {      return eval("(" + strJson + ")");      
  8. }    
  9. }); 

 

  1. jQuery.extend({      
  2. /** * @see 將javascript數(shù)據(jù)類型轉(zhuǎn)換為json字符串   
  3. * @param 待轉(zhuǎn)換對象,支持  
  4. object,  
  5. array,string,function,number,boolean,regexp   
  6. * @return 返回json字符串 */      
  7. toJSON: function(object) {        
  8. var type = typeof object;        
  9. if ('object' == type) {          
  10. if (Array == object.constructor) type = 'array';          
  11. else if (RegExp == object.constructor)   
  12. type = 'regexp';          
  13. else type = 'object';        
  14. }        
  15. switch (type) {        
  16. case 'undefined':        
  17. case 'unknown':          
  18. return;          
  19. break;        
  20. case 'function':        
  21. case 'boolean':        
  22. case 'regexp':          
  23. return object.toString();          
  24. break;   
  25. case 'number':          
  26. return isFinite(object) ?   
  27. object.toString() : 'null';          
  28. break;        
  29. case 'string':          
  30. return '"' + object.replace(/(\\|\")/g, "\\$1").replace(/\n|\r|\t/g, function()   
  31. {            
  32. var a = arguments[0];           
  33. return (a == '\n') ? '\\n': (a == '\r') ? '\\r': (a == '\t') ? '\\t': ""          
  34. }) + '"';          
  35. break;        
  36. case 'object':          
  37. if (object === null) return 'null';          
  38. var results = [];          
  39. for (var property in object) {            
  40. var value = jQuery.toJSON(object[property]);            
  41. if (value !== undefined) results.push(jQuery.toJSON(property) + ':' + value);          
  42. }          
  43. return '{' + results.join(',') + '}';          
  44. break;        
  45. case 'array':          
  46. var results = [];          
  47. for (var i = 0; i < object.length; i++) {            
  48. var value = jQuery.toJSON(object[i]);            
  49. if (value !== undefined) results.push(value);         
  50. }          
  51. return '[' + results.join(',') + ']';          
  52. break;        
  53. }      
  54. }    
  55. });  
  56. 示例:    
  57. var obj = {      
  58. name: "sean",      
  59. friend: ["fans", "bruce", "wawa"],      
  60. action: function() {      alert("gogogog")      
  61. },      
  62. boy: true,    age: 26,      
  63. reg: /\b([a-z]+) \1\b/gi,      
  64. child: {      name: "none",      age: -1    }  };   
  65.  var json = $.toJSON(obj);    
  66. var objx = $.evalJSON(json);  

【編輯推薦】

  1. 改變獲取對象方式 ***的jQuery選擇器
  2. 5種方法教你用jQuery重寫表單驗(yàn)證
  3. 你應(yīng)該學(xué)習(xí)jQuery的七大理由
  4. 即刻提升jQuery性能的十個(gè)技巧
  5. 12種jQuery性能優(yōu)化方法解析
責(zé)任編輯:王曉東 來源: 豆豆網(wǎng)
相關(guān)推薦

2016-12-02 19:14:16

數(shù)據(jù)科學(xué)大數(shù)據(jù)

2009-06-26 15:56:26

2023-09-14 15:37:11

2013-09-12 16:23:44

iOS開發(fā)

2015-10-15 09:33:55

3Dtouch蘋果游戲開發(fā)

2010-08-12 09:45:33

jQuery自定義事件

2011-03-11 15:31:52

數(shù)據(jù)中心虛擬接入

2011-06-01 14:51:54

jQuery

2015-02-12 15:33:43

微信SDK

2012-07-24 15:03:19

OpenStack架構(gòu)

2015-02-12 15:38:26

微信SDK

2012-09-06 10:07:26

jQuery

2009-05-18 10:57:35

.NETString特性

2018-03-26 12:58:52

數(shù)據(jù)庫OracleMySQL

2022-07-20 15:10:38

Docker大數(shù)據(jù)平臺

2010-10-26 09:23:03

Web Service

2009-02-10 12:55:39

自定義控件AJAX.NET

2013-01-10 09:36:19

NagiosNagios插件

2009-07-01 09:41:00

無線路由器固件番茄固件

2016-10-14 13:10:35

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號