jquery 可編輯的表格

jquery 入門 可編輯的表格

 

 editTable.css


 table {
 border: 1px solid black;
 /*修正單元格之間的邊框不能合併*/
 border-collapse: collapse;
 width: 400px;
}
table td {
 border: 1px solid black;
 width: 50%;
}
table th {
 border: 1px solid black;
 width: 50%;
}
tbody th {
 background-color: #A3BAE9; 
}

 

editTable.js

 

 //需要首先通過Javascript來解決內容部分奇偶行的背景色不同
//$(document).ready(function(){
//
//});
//簡化的ready寫法
$(function(){
 //找到表格的內容區域中所有的奇數行
 //使用even是爲了把通過tbody tr返回的所有tr元素中,在數組裏面下標是偶數的元素返回,因爲這些元素,實際上纔是我們期望的tbody裏面的奇數行
 $("tbody tr:even").css("background-color","#ECE9D8");

 //我們需要找到所有的學號單元格
 var numTd = $("tbody td:even");
 //給這些單元格註冊鼠標點擊的事件
 numTd.click(function() {
  //找到當前鼠標點擊的td,this對應的就是響應了click的那個td
  var tdObj = $(this);
  if (tdObj.children("input").length > 0) {
   //當前td中input,不執行click處理
   return false;
  }
  var text = tdObj.html();
  //清空td中的內容
  tdObj.html("");
  //創建一個文本框
  //去掉文本框的邊框
  //設置文本框中的文字字體大小是16px
  //使文本框的寬度和td的寬度相同
  //設置文本框的背景色
  //需要將當前td中的內容放到文本框中
  //將文本框插入到td中
  var inputObj = $("<input type='text'>").css("border-width","0")
   .css("font-size","16px").width(tdObj.width())
   .css("background-color",tdObj.css("background-color"))
   .val(text).appendTo(tdObj);
  //是文本框插入之後就被選中
  inputObj.trigger("focus").trigger("select");
  inputObj.click(function() {
   return false;
  });
  //處理文本框上回車和esc按鍵的操作
  inputObj.keyup(function(event){
   //獲取當前按下鍵盤的鍵值
   var keycode = event.which;
   //處理回車的情況
   if (keycode == 13) {
    //獲取噹噹前文本框中的內容
    var inputtext = $(this).val();
    //將td的內容修改成文本框中的內容
    tdObj.html(inputtext);
   }
   //處理esc的情況
   if (keycode == 27) {
    //將td中的內容還原成text
    tdObj.html(text);
   }
  });
 });
});

 


EditTable.html

 

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
 <head>
  <title>JQuery實例2:可以編輯的表格</title>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <link type="text/css" rel="stylesheet" href="css/editTable.css" />
  <script type="text/javascript" src="js/jquery-1.4.1.js"></script>
  <script type="text/javascript" src="js/editTable.js"></script>
 </head>
 <body>
  <table>
   <thead>
    <tr>
     <th colspan="2">鼠標點擊表格項就可以編輯</th>
    </tr>
   </thead>
   <tbody>
    <tr>
     <th>學號</th>
     <th>姓名</th>
    </tr>
    <tr>
     <td>000001</td>
     <td>張三</td>
    </tr>
    <tr>
     <td>000002</td>
     <td>李四</td>
    </tr>
    <tr>
     <td>000003</td>
     <td>王五</td>
    </tr>
    <tr>
     <td>000004</td>
     <td>趙六</td>
    </tr>
   </tbody>
  </table>
 </body>
</html>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章