Python's Archiver

為方便港臺同胞閱覽,Python中國特別推出簡繁體內容轉換功能

xieaotian 发表于 2008-8-18 10:42

双击单元格变成可编辑的文本框

不知道有没有用过google的在线文档服务, 有excel类型的文档, 大家都知道excel每个单元格都可以编辑, 这里我来说说我实现的思路, 高手有高手的想法和做法, 但是我们菜鸟也可以偶尔的冒充一把, 不亦乐乎, 呵呵。

第一步: 准备工作,建立个tabedit.html
里面的内容很简单, 建立个5X5的表格, 代码如下: <html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>双击单元格变成可编辑的文本框</title>
</head>

<body>

<table border="1" width="100%" id="table1">
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
</table>

</body>

</html>



2. 设计思路:
     当鼠标双击的时候 也就是document.ondblclick的时候, 判断当前鼠标事件作用的对象,可以用event.srcElement获得到,然后判断event.srcElement是否是td, 也就是判断event.srcElement.tagName是否是单元格, 是的话就进行转换成编辑框, 转换成编辑框有几种做法 1. 动态创建,即使用document.createElement('标签的名字'), 代码如下:

   inputItem = document.createElement('input');
   inputItem.type = 'text';
   inputItem.style.width = '100%';
   inputItem.style.height = '18px';
   inputItem.style.fontSize = '12px';

2. 直接用字符串的创建,代码如下:
  var str = "<input id='inputItem type=text>'"


完成该功能还需要一个变量(g_activeItem), 用来保存当前编辑的td引用, 以便切换到其他td后恢复当前td为文本模式


3. 主要功能实现:

文本转换成可以编辑的输入框
代码如下: function changeToEdit(obj){
if( !inputItem ) {
  inputItem = document.createElement('input');
  inputItem.type = 'text';
  inputItem.style.width = '100%';
  inputItem.style.height = '18px';
  inputItem.style.fontSize = '12px';
}
inputItem.style.display = '';
inputItem.value = obj.innerText; // 将该单元格的数据文本读到控件上
obj.innerHTML = ''; // 清空单元格的数据
obj.appendChild(inputItem);
inputItem.focus();
g_activeItem = obj;
}



恢复文本显示, 代码如下
function changeToText(obj){
if( obj && inputItem ) {
  // 如果存在正在编辑的单元格, 则取消编辑状态, 并将编辑的数据保存起来
  var str = inputItem.value;
  obj.innerText = str;   
}
}



综合上面所说给出全部代码: <html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>新建网页 1</title>

<script language="javascript">
<!--

var inputItem; // 输入框句柄
var g_activeItem; // 保存正在编辑的单元格

function changeToText(obj){
if( obj && inputItem ) {
  // 如果存在正在编辑的单元格, 则取消编辑状态, 并将编辑的数据保存起来
  var str = inputItem.value;
  obj.innerText = str;   
}
}

function changeToEdit(obj){
if( !inputItem ) {
  inputItem = document.createElement('input');
  inputItem.type = 'text';
  inputItem.style.width = '100%';
  inputItem.style.height = '18px';
  inputItem.style.fontSize = '12px';
}
inputItem.style.display = '';
inputItem.value = obj.innerText; // 将该单元格的数据文本读到控件上
obj.innerHTML = ''; // 清空单元格的数据
obj.appendChild(inputItem);
inputItem.focus();
g_activeItem = obj;


}

document.attachEvent('ondblclick',function(){
if (event.srcElement.tagName.toLowerCase() == "td") {
  if( !inputItem ) {
   inputItem = document.createElement('input');
   inputItem.type = 'text';
   inputItem.style.width = '100%';
   inputItem.style.height = '18px';
   inputItem.style.fontSize = '12px';
  }
  changeToText()
  changeToEdit(event.srcElement);
} else {
  event.returnValue = false;
  return false;  
}
});

document.attachEvent('onclick', function(){
if( event.srcElement.parentNode == g_activeItem || event.srcElement == g_activeItem ) {
  return;
} else {
  changeToText(g_activeItem);
}
})

//-->
</script>
</head>
<body>
<table border="1" width="100%" id="table1">
<tr>
  <td width='130'>Test </td>
  <td width='130'> </td>
  <td width='130'> </td>
  <td width='130'> </td>
  <td width='130'> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
<tr>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
  <td> </td>
</tr>
</table>
</body></html>



演示地址: [url]http://www.onlyaa.com/examples/tabedit/index.htm[/url]

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.