jquery table

open-open.com 看到N多老外寫的插件 

因而今天看了下jquery文檔也本身來兩個,獻醜啦! 

需求: 

一:操做table 
一、無侵入式可編輯 

二、隔行換色 

三、拉動表頭,自定義寬度 

四、可編輯 

五、編輯後的數據顏色區分 

五、css文件本身定義,無需和插件綁定,這樣更加靈活 

六、一切可配置 


1:名字就叫bestTable 

二:拖動div 

萬惡的IE6,在自定義的js文件中有時候加備註會讓IE6報錯,我很是蛋疼,多是中文註釋的緣由因此鍵盤事件的代碼取消了註釋,一切正常,只要在一寫備註ie6就運行不了, 

jquery.bestTable.js 

Js代碼  複製代碼 收藏代碼spinner.gif
  1. (function($){      javascript

  2.     $.fn.bestTable = function(options)   css

  3.     {      html

  4. /** java

  5.          * isDrog 是否能夠拖動表頭寬度 jquery

  6.          * oddtrBackgroundColor odd背景顏色 瀏覽器

  7.          * isEffect 是否開啓鼠標特效 ide

  8.          * effectBackgroundColor 鼠標移動後的背景色 ui

  9.          * isEditor 是否開啓可編輯狀態 this

  10.          * isEditorNewColor 編輯狀態背景色 spa

  11.          * isEditorNewColor 是否開啓編輯後狀態 

  12.          * editorNewColorBackgroundColor 編輯後背景色 

  13.          */

  14. var defaults = {   

  15.             isDrog : true,   

  16.             oddtrBackgroundColor:"#EEE",   

  17.             isEffect:true,   

  18.             effectBackgroundColor:"#CCCCCC",   

  19.             isEditor:true,   

  20.             editorBackgroundColor:"#FFFFCC",   

  21.             isEditorNewColor:true,   

  22.             editorNewColorBackgroundColor : "0099FF"

  23.         };   

  24. var opts = $.extend(defaults, options);   

  25. var backgroundColor='background-color';   

  26.         $(this).each(function()   

  27.         {   

  28. //獲取當前table 

  29. var newTable= $(this);   

  30. //是否容許拖動表頭 

  31. if(opts.isDrog)drog(newTable); //鼠標拖動th 

  32.             $(newTable).find("tbody tr:odd").css(backgroundColor,opts.oddtrBackgroundColor);   

  33. //獲取當前table中tbody中的td 

  34. var newtd = $(newTable).find('tbody td');   

  35. //編輯狀態(鼠標變手形)和鼠標特效狀態(改變背景色)都須要給當前td設置mouseover 

  36.             newtd.mouseover(function(){   

  37. //保存當前td的背景色 

  38. var oldbackgroundColor=$(this).css(backgroundColor);   

  39. if(opts.isEffect)//啓動特效狀態 

  40.                 {   

  41.                     $(this).css({'cursor':'pointer',backgroundColor:opts.effectBackgroundColor});//修改鼠標爲手狀、修改背景色 

  42.                     $(this).mouseout(function(){   

  43.                         $(this).css({backgroundColor:oldbackgroundColor}); //光標移開後恢復到最初背景色 

  44.                     });   

  45.                 }   

  46.             });   

  47. //不容許編輯 

  48. if(!opts.isEditor)returnfalse;   

  49. //單擊td 

  50.             newtd.click(function(){   

  51. var td = $(this);   

  52. //判斷當前td中是否已經包含了inpu文本框 

  53. if(td.children("input").length>0){returnfalse};   

  54. //爲當前td添加一個編輯框臨時input    

  55. var inputObject = $("<input type='text'/>").height("100%").width("100%").css({      

  56. "font-size":td.css("font-size"),      

  57.                         backgroundColor:opts.editorBackgroundColor,      

  58. "border-width":0      

  59.                     });   

  60. //取消當前input文本框單擊事件    

  61.                     inputObject.click(function(){returnfalse});      

  62. //獲取td文本框放入一個變量 

  63. var tdText = td.html();   

  64. //將td中的文本框賦值給input中    

  65.                     inputObject.val(tdText);   

  66. //將input放入td文本框當中    

  67.                     td.html(inputObject);   

  68. //選中編輯區域 兼容全部瀏覽器    

  69.                     inputObject.trigger("focus").trigger("select");   

  70.                     inputObject.blur(function(){    

  71. //恢復td的文本    

  72.                         td.html(tdText);      

  73. //刪除input    

  74.                         $(this).remove();      

  75.                     });   

  76. //鍵盤   

  77.                     inputObject.keydown(function(event){      

  78. var keyCode = event.which;   

  79. switch(keyCode){      

  80. case 13:   

  81. var inputText = $(this).val();      

  82.                             td.html(inputText);      

  83.                             $(this).remove();      

  84. if(!opts.isEditorNewColor)returnfalse;      

  85.                             td.css(backgroundColor,opts.editorNewColorBackgroundColor);   

  86. break;      

  87. case 27:    

  88.                             td.html(tdText);        

  89.                             $(this).remove();        

  90. break;      

  91.                         }      

  92.                     });          

  93.             });   

  94.         });   

  95. //不多的代碼實現拖動表頭 

  96. function drog(table){   

  97. var tr = $(table).find("thead tr");   

  98. var th = $(table).find('thead tr th');   

  99.             $(tr).mousemove(function(event){   

  100.                 $(this).css("cursor","e-resize");   

  101.             });   

  102.             $(th).mousedown(function(event){   

  103.                 $(this).mousemove(function(e){   

  104. var width = $(this).width();   

  105. var px = e.clientX-event.clientX;   

  106.                     $(this).width(width+px);   

  107.                 });   

  108.             });   

  109.             $(th).mouseup(function(){   

  110.                 $(th).unbind('mousemove');   

  111.             });    

  112.         }   

  113.     };      

  114. })(jQuery);    

(function($){   
	
    $.fn.bestTable = function(options)
    {   
        /**
         * isDrog 是否能夠拖動表頭寬度
       	 * oddtrBackgroundColor odd背景顏色
       	 * isEffect 是否開啓鼠標特效
       	 * effectBackgroundColor 鼠標移動後的背景色
       	 * isEditor 是否開啓可編輯狀態
       	 * isEditorNewColor 編輯狀態背景色
       	 * isEditorNewColor 是否開啓編輯後狀態
       	 * editorNewColorBackgroundColor 編輯後背景色
       	 */
		var defaults = {
			isDrog : true,
			oddtrBackgroundColor:"#EEE",
			isEffect:true,
			effectBackgroundColor:"#CCCCCC",
			isEditor:true,
			editorBackgroundColor:"#FFFFCC",
			isEditorNewColor:true,
			editorNewColorBackgroundColor : "0099FF"
		};
		var opts = $.extend(defaults, options);
		
       
      	var backgroundColor='background-color';
		$(this).each(function()
		{
			
			
			//獲取當前table
			var newTable= $(this);
			//是否容許拖動表頭
			if(opts.isDrog)drog(newTable); //鼠標拖動th
			
			$(newTable).find("tbody tr:odd").css(backgroundColor,opts.oddtrBackgroundColor);
			//獲取當前table中tbody中的td
			var newtd = $(newTable).find('tbody td');
			
			//編輯狀態(鼠標變手形)和鼠標特效狀態(改變背景色)都須要給當前td設置mouseover
			newtd.mouseover(function(){
				//保存當前td的背景色
				var oldbackgroundColor=$(this).css(backgroundColor);
				if(opts.isEffect)//啓動特效狀態
				{
					
					$(this).css({'cursor':'pointer',backgroundColor:opts.effectBackgroundColor});//修改鼠標爲手狀、修改背景色
					
					$(this).mouseout(function(){
						$(this).css({backgroundColor:oldbackgroundColor}); //光標移開後恢復到最初背景色
					});
				}
			});
			
			//不容許編輯
			if(!opts.isEditor)return false;
			//單擊td
			newtd.click(function(){
				var td = $(this);
				//判斷當前td中是否已經包含了inpu文本框
				if(td.children("input").length>0){return false};
				//爲當前td添加一個編輯框臨時input   
                    var inputObject = $("<input type='text'/>").height("100%").width("100%").css({   
                        "font-size":td.css("font-size"),   
                        backgroundColor:opts.editorBackgroundColor,   
                        "border-width":0   
                    });
                    //取消當前input文本框單擊事件   
                    inputObject.click(function(){return false});   
                    //獲取td文本框放入一個變量
                    var tdText = td.html();
                    //將td中的文本框賦值給input中   
                    inputObject.val(tdText);
                    //將input放入td文本框當中   
                    td.html(inputObject);
                    //選中編輯區域 兼容全部瀏覽器   
                    inputObject.trigger("focus").trigger("select");
                    
                    
                    inputObject.blur(function(){ 
                        //恢復td的文本   
                        td.html(tdText);   
                        //刪除input   
                        $(this).remove();   
                    });
                    
                    //鍵盤  
                    inputObject.keydown(function(event){   
                        var keyCode = event.which;
                        switch(keyCode){   
                            case 13:
                            var inputText = $(this).val();   
                            td.html(inputText);   
                            $(this).remove();   
                            if(!opts.isEditorNewColor)return false;   
                            td.css(backgroundColor,opts.editorNewColorBackgroundColor);
                            break;   
                            case 27: 
                            td.html(tdText);     
                            $(this).remove();     
                            break;   
                        }   
       
                    });       
			});
			
			
		});
        //不多的代碼實現拖動表頭
		function drog(table){
			
			var tr = $(table).find("thead tr");
			
			var th = $(table).find('thead tr th');
			
			$(tr).mousemove(function(event){
				
				$(this).css("cursor","e-resize");
				
			});
			
			$(th).mousedown(function(event){
				
				$(this).mousemove(function(e){

					var width = $(this).width();
					
					var px = e.clientX-event.clientX;
					
					$(this).width(width+px);

				});
				
			});
			$(th).mouseup(function(){
				
				$(th).unbind('mousemove');
				
			});	
		}
    };   
	
})(jQuery);  


頁面 引入 jquery.js 和 自定義的 jquery.bestTable.js 
Html代碼  複製代碼 收藏代碼spinner.gif
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

  2. <html>

  3. <head>

  4. <title>a.html</title>

  5. <metahttp-equiv="keywords"content="keyword1,keyword2,keyword3">

  6. <metahttp-equiv="description"content="this is my page">

  7. <metahttp-equiv="content-type"content="text/html; charset=UTF-8">

  8. <scripttype="text/javascript"src="js/jquery.min.js"></script>

  9. <scripttype="text/javascript"src="js/jquery.bestTable.js"></script>

  10. <scripttype="text/javascript">

  11.         $(document).ready(function()      

  12.         {      

  13.             //最簡單配置  默認配置      

  14.             $('table#demo').bestTable();      

  15.             //按需求配置      

  16.             $('table#demo2').bestTable({      

  17.                 isDrog:false, //不容許拖動表頭寬度   

  18.                 oddtrBackgroundColor:'red', //改變odd背景色      

  19.                 isEffect:false, //關閉鼠標滑動特效      

  20.                 isEditorNewColor:false //編輯完成後不改變背景色      

  21.             });      

  22.         });      

  23. </script>

  24. <style>

  25.         table {   

  26.           border: solid 1px #D5D5D5;   

  27.           border-collapse: collapse;   

  28.           height:auto;   

  29.         }   

  30.         tbody td {   

  31.             border:1px solid #D5D5D5;   

  32.             font-size:12px;   

  33.         }   

  34.         thead th {   

  35.             border:1px solid #D5D5D5;   

  36.             background-color:#EEE;   

  37.             font-size:12px;   

  38.         }   

  39. </style>

  40. </head>

  41. <body>

  42. <!-- demo -->

  43. <tableid="demo">

  44. <thead>

  45. <tr>

  46. <th>userName</th>

  47. <th>email</th>

  48. <th>sex</th>

  49. </tr>

  50. </thead>

  51. <tbody>

  52. <tr>

  53. <td>胡**</td>

  54. <td>1016181216@163.com</td>

  55. <td></td>

  56. </tr>

  57. <tr>

  58. <td>胡**</td>

  59. <td>1016181216@163.com</td>

  60. <td></td>

  61. </tr>

  62. <tr>

  63. <td>胡**</td>

  64. <td>1016181216@163.com</td>

  65. <td></td>

  66. </tr>

  67. <tr>

  68. <td>胡**</td>

  69. <td>1016181216@163.com</td>

  70. <td></td>

  71. </tr>

  72. </tbody>

  73. </table>

  74. <br/>

  75. <!-- demo2 -->

  76. <tableid="demo2">

  77. <thead>

  78. <tr>

  79. <th>userName</th>

  80. <th>email</th>

  81. <th>sex</th>

  82. </tr>

  83. </thead>

  84. <tbody>

  85. <tr>

  86. <td>xiaomaha</td>

  87. <td>xiaomaha@163.com</td>

  88. <td></td>

  89. </tr>

  90. <tr>

  91. <td>xiaomaha2</td>

  92. <td>xiaomaha2@163.com</td>

  93. <td></td>

  94. </tr>

  95. <tr>

  96. <td>xiaomaha3</td>

  97. <td>xiaomaha3@163.com</td>

  98. <td></td>

  99. </tr>

  100. <tr>

  101. <td>xiaomaha4</td>

  102. <td>xiaomaha4@163.com</td>

  103. <td></td>

  104. </tr>

  105. </tbody>

  106. </table>

  107. <spanid="a"></span><br/><spanid="b"></span><br/><spanid="c"></span><br/><spanid="d"></span><br/>

  108. </body>

  109. </html>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>a.html</title>
	
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="this is my page">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    <script type="text/javascript" src="js/jquery.min.js"></script>
    <script type="text/javascript" src="js/jquery.bestTable.js"></script>
	
	<script type="text/javascript">
		$(document).ready(function()   
        {   
            //最簡單配置  默認配置   
            $('table#demo').bestTable();   
               
               
            //按需求配置   
            $('table#demo2').bestTable({   
            	isDrog:false, //不容許拖動表頭寬度
                oddtrBackgroundColor:'red', //改變odd背景色   
                isEffect:false, //關閉鼠標滑動特效   
                isEditorNewColor:false //編輯完成後不改變背景色   
            });   
        });   

	</script>

	<style>
		
		table {
		  border: solid 1px #D5D5D5;
		  border-collapse: collapse;
		  
		  height:auto;
  
		}

		tbody td {
			border:1px solid #D5D5D5;
			font-size:12px;
		}

		thead th {
			border:1px solid #D5D5D5;
			background-color:#EEE;
			font-size:12px;
		
		}
	</style> 

  </head>
  
  <body>
  	
  <!-- demo -->
  		<table id="demo">
     	<thead>
     		<tr>
     			<th>userName</th>
     			<th>email</th>
     			<th>sex</th>
     		</tr>
     	</thead>
     	<tbody>
     		<tr>
     			<td>胡**</td>
     			<td>1016181216@163.com</td>
     			<td>男</td>
     		</tr>
     		<tr>
     			<td>胡**</td>
     			<td>1016181216@163.com</td>
     			<td>男</td>
     		</tr>
     		<tr>
     			<td>胡**</td>
     			<td>1016181216@163.com</td>
     			<td>男</td>
     		</tr>
     		<tr>
     			<td>胡**</td>
     			<td>1016181216@163.com</td>
     			<td>男</td>
     		</tr>
     	</tbody>
     </table>
  
  
  <br/>
  <!-- demo2 -->
  	
     <table id="demo2">
     	<thead>
     		<tr>
     			<th>userName</th>
     			<th>email</th>
     			<th>sex</th>
     		</tr>
     	</thead>
     	<tbody>
     		<tr>
     			<td>xiaomaha</td>
     			<td>xiaomaha@163.com</td>
     			<td>男</td>
     		</tr>
     		<tr>
     			<td>xiaomaha2</td>
     			<td>xiaomaha2@163.com</td>
     			<td>男</td>
     		</tr>
     		<tr>
     			<td>xiaomaha3</td>
     			<td>xiaomaha3@163.com</td>
     			<td>男</td>
     		</tr>
     		<tr>
     			<td>xiaomaha4</td>
     			<td>xiaomaha4@163.com</td>
     			<td>男</td>
     		</tr>
     	</tbody>
     </table>
     <span id="a"></span><br/><span id="b"></span><br/><span id="c"></span><br/><span id="d"></span><br/>
  </body>
</html>



顯示結果 


8d9ebf68-e276-38e3-8874-d5f42753b86b.png
拖動表頭寬度 

0377261c-d76d-30e3-b57d-7bf4646b9ad9.png

編輯狀態改變背景色 

ab5a0dc7-78d5-36d6-93fb-10a7e5c5edaf.png
編輯後回車 被編輯過的td會改變顏色 


33cf4305-7805-35dc-86c7-6ff999b91792.png

---------------------bestTableOver------------------ 

可拖動的div 
Js代碼  複製代碼 收藏代碼spinner.gif
  1. (function($){    

  2.     $.fn.bestDrag = function(options)   

  3.     {   

  4. var defaults = {   

  5.         }   

  6. var opts = $.extend(defaults, options);   

  7. this.each(function()   

  8.         {   

  9. var tag = $(this);   

  10.             drog(tag);   

  11.         });   

  12. //處處亂拖 

  13. function drog(tag){   

  14.             $(tag).mousedown(function(e){   

  15.                  $(this).css("cursor","move");   

  16. var offset = $(this).offset();   

  17. var x = e.clientX-offset.left;   

  18. var y = e.clientY-offset.top;   

  19.                  $(document).bind("mousemove",function(event){   

  20. var _x = event.clientX-x;   

  21. var _y = event.clientY-y;   

  22.                       $(tag).animate({left:_x,top:_y},0);   

  23.                  });   

  24.             });   

  25.             $(document).mouseup(function()      

  26.             {      

  27.                 $(tag).css("cursor","default");      

  28.                 $(this).unbind("mousemove");      

  29.             });      

  30.         }   

  31.     };   

  32. })(jQuery);  

(function($){ 
	
	
	$.fn.bestDrag = function(options)
	{
		
		
		var defaults = {
			
		}
		
		var opts = $.extend(defaults, options);
		
		this.each(function()
		{
			var tag = $(this);
			drog(tag);
		});
		//處處亂拖
		function drog(tag){
			$(tag).mousedown(function(e){
				
				 $(this).css("cursor","move");
				 
				 var offset = $(this).offset();
				 
				 var x = e.clientX-offset.left;
				 var y = e.clientY-offset.top;
				
				 
				 $(document).bind("mousemove",function(event){
					  var _x = event.clientX-x;
					  var _y = event.clientY-y;
					  $(tag).animate({left:_x,top:_y},0);
				 });
				 
			});
			
			$(document).mouseup(function()   
        	{   
	            $(tag).css("cursor","default");   
	            $(this).unbind("mousemove");   
        	});   

			
		}
	};
	
	
})(jQuery);

頁面引入jquery和自定義的jquery.bestDrag.js 
Html代碼  複製代碼 收藏代碼spinner.gif
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

  2. <html>

  3. <head>

  4. <title>test.html</title>

  5. <metahttp-equiv="keywords"content="keyword1,keyword2,keyword3">

  6. <metahttp-equiv="description"content="this is my page">

  7. <metahttp-equiv="content-type"content="text/html; charset=UTF-8">

  8. <scripttype="text/javascript"src="js/jquery.min.js"></script>

  9. <scripttype="text/javascript"src="js/jquery.bestDrag.js"></script>

  10. <styletype="text/css">

  11.     div{      

  12.          background:#660099;      

  13.          width:100px;      

  14.          height:100px;      

  15.          text-align:center;      

  16.          position:absolute;      

  17.          z-index:1;      

  18.          left:100px;      

  19.          top:100px;      

  20.         }   

  21. </style>

  22. <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->

  23. <scripttype="text/javascript">

  24.         $(document).ready(function(){   

  25.             $('div').bestDrag();   

  26. </script>

  27. </head>

  28. <body>

  29. <div>可拖動的div</div>

  30. </body>

  31. </html>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>test.html</title>
	
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="this is my page">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    <script type="text/javascript" src="js/jquery.min.js"></script>
    <script type="text/javascript" src="js/jquery.bestDrag.js"></script>
    <style type="text/css">   
    div{   
	     background:#660099;   
	     width:100px;   
	     height:100px;   
	     text-align:center;   
	     position:absolute;   
	     z-index:1;   
	     left:100px;   
	     top:100px;   
    	}
    </style>  

    <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
	<script type="text/javascript">
		$(document).ready(function(){
			$('div').bestDrag();
	</script>
  </head>
  
  <body>
  	    <div>可拖動的div</div>
		
	</body>
</html>




顯示結果:很平滑、無延遲 

1e182331-43f1-303e-9cee-1428b52fb51e.png

aafe08e5-8ebe-3a3b-a005-1c2794383810.png


點擊下載




  • 8d9ebf68-e276-38e3-8874-d5f42753b86b-thu

  • 大小: 6.1 KB

  • 0377261c-d76d-30e3-b57d-7bf4646b9ad9-thu

  • 大小: 10.8 KB

  • ab5a0dc7-78d5-36d6-93fb-10a7e5c5edaf-thu

  • 大小: 11.1 KB

  • 33cf4305-7805-35dc-86c7-6ff999b91792-thu

  • 大小: 11.2 KB

  • 1e182331-43f1-303e-9cee-1428b52fb51e-thu

  • 大小: 2.3 KB

  • aafe08e5-8ebe-3a3b-a005-1c2794383810-thu

  • 大小: 2.5 KB

相關文章
相關標籤/搜索