通過js實現單擊或雙擊直接修改內容


代碼並不重要,關鍵是思路,這里簡要說一下:

    1.展示的時候直接將內容展示在文本框中,文本框的邊框設置為0,也可以在設置一下readonly,這樣在展示到頁面上的時候給人一種普通文本的假象, 實際是顯示在邊框為0的文本框中,給文本框加單擊或者雙擊事件,觸發時將邊框更改為1,並且去掉readonly屬性,這樣就可以修改了,同時也要有失去 焦點事件,失去焦點時通過ajax將相應的數據發送到服務器端進行修改,修改成功文本框恢復原狀。這種方式給用戶一種假象,有時體驗不太好,比如設置雙擊 觸發事件,而單擊時就會出現光標(雖然有readonly不能改)。下面再說一種方式。

    2.展示的時候內容直接展示在一些容器類標簽中例如<span>標簽,單擊或雙擊時同樣觸發事件,將內容更改為文本框,並且將 是原來容器中的內容作為文本框中的value,設置失去焦點事件,當失去焦點時觸發事件通過ajax實現修改,並且再將文本框的位置替換為修改后的內容, 當然還有一些細節,比如沒有做任何修改的情況下失去焦點,這樣就不應該發送數據到服務器端了。給出代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<title>(單擊)雙擊直接修改內容的代碼</title>

<script type="text/javascript">

function edit(element){

 var oldhtml = element.innerHTML;//獲得元素之前的內容
 var newobj = document.createElement('input');//創建一個input元素
 newobj.type = 'text';//為newobj元素添加類型
  newobj.value=oldhtml;
 element.innerHTML = '';   //設置元素內容為空
 element.appendChild(newobj);//添加子元素
 newobj.focus();//獲得焦點
  //設置newobj失去焦點的事件
 newobj.onblur = function(){
   //下面應該判斷是否做了修改並使用ajax代碼請求服務端將id與修改后的數據提交
   alert(element.id);
      //當觸發時判斷newobj的值是否為空,為空則不修改,並返回oldhtml
      element.innerHTML = this.value ? this.value : oldhtml;
   }
}
</script>

</head>
<body>

 姓名:<span id="1" ondblclick="edit(this)">張三</span><br/>
 家庭住址:<span id="2" ondblclick="edit(this)">張三</span><br/>

</body>

</html>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM