不用ajax實現點擊文字即可編輯的方法_javascript技巧

來源:互聯網
上載者:User
剛接觸creatElement ,appendChild 等東東!呵呵!
寫了這個東西,可能在高手看來,非常的稚嫩!不過完全自己寫的!
還沒有完善,請大俠指導!!
看代碼
複製代碼 代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
 <HEAD>
  <TITLE> New Document </TITLE>
  <style>
  .test{border:1px solid #ccc;background-color:#eee;width:200px;height:60px;}
  </style>
  <script language="javascript">
  <!--
  function isIE(){ //ie? 
    if (window.navigator.userAgent.indexOf("MSIE")>=1) return true; 
    else return false; 

if(!isIE()){ //firefox innerText define
    HTMLElement.prototype.__defineGetter__("innerText", 
        function(){ 
            return this.textContent; 
        } 
    ); 
    HTMLElement.prototype.__defineSetter__("innerText", 
        function(sText){ 
            this.textContent=sText; 
        } 
    ); 
}function $(e){
    return document.getElementById(e);
  }
 var arr=new Array();
 function check(e){
 var v=0;
    for(i=0;i<arr.length;i++)
    {if(arr[i]==e) v=1;
    else v=0;}
    if(v) return true;
    else return false;
 }
 function edit(e){
    var x=$(e);
    var str=x.innerText;
    if (check(e))
    {
        //alert("已經存在在數組裡!");
        //alert(str);
        var b=$(e+"fa");
        str=$(e+"faz").value;
        b.removeChild($(e+"faz"));
        x.innerText=str;
    }else{
        //alert("沒有存在在數組裡!");
        a1=document.createElement("div");
        a1.id=e+"fa";
        a=document.createElement("INPUT");
        a.name=e;
        a.id=e+"faz";
        a.value=str;
        x.innerHTML="";
        x.appendChild(a1);
        a1.appendChild(a);
        if(arr.length==0) arr[0]=e;
        else arr[arr.length]=e;
        //alert(a.name);
    }
  }
  -->
  </script>
 </HEAD>
 <BODY>
 <div class="test" id="test" onclick="edit('test')">可編輯的內容</div>
 <div class="test" id="test1" onclick="edit('test1')">可編輯的內容</div>
 </BODY>
</HTML>

最後解決瀏覽器問題的代碼
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> New Document </tITLE> <style> body{font-size:14px;} input{border:none;font-size:14px;} .show{border:1px solid #ccc;background-color:#eee;width:150px;height:20px;} .hide{border:1px solid #ccc;background-color:#eee;width:150px;height:20px;display:none;} </style> <script language="javascript"> <!-- function $(e){ return document.getElementById(e);//封裝擷取函數 } function edit(e){ //parseInt $(e).style.display="none"; $(e+"fm").style.display="block"; $(e+"fm").childNodes[0].focus(); //div的子項目自動獲得焦點 } function hide(e){ //parseInt $(e).style.display="none"; $(e=e.replace("fm","")).style.display="block"; } --> </script> </hEAD> <BODY> 唉!!忙了一晚上,就這麼解決了!!嘻嘻 呵呵 鬱悶! <font color=red><b>在firefox下 由於DOM有很小的差異,含有input的div中除標籤內的空格外</b></font> <font color=red><b>不能有空格因為我們用的是childNodes[0]!否則需要點兩下!</b></font> <div> <div class="show" id="test" onclick="edit(this.id)">可編輯的內容一</div> <div class="hide" id="testfm"><input type="text" name="nn" value="可編輯的內容一" onBlur="hide(this.parentNode.id)" /></div> <div class="show" id="test1" onclick="edit(this.id)">可編輯的內容二</div> <div class="hide" id="test1fm"><input type="text" name="nn" value="可編輯的內容二" onBlur="hide(this.parentNode.id)" /></div> <div class="show" id="test2" onclick="edit(this.id)">可編輯的內容三</div> <div class="hide" id="test2fm"> <input type="text" name="nn" value="可編輯的內容三" onBlur="hide(this.parentNode.id)" > </div> <div class="show" id="test3" onclick="edit(this.id)">可編輯的內容四</div> <div class="hide" id="test3fm"> <input type="text" name="nn" value="可編輯的內容四" onBlur="hide(this.parentNode.id)" > </div> </div> </bODY> </hTML>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.