不用ajax實(shí)現(xiàn)點(diǎn)擊文字即可編輯的方法
剛接觸creatElement ,appendChild 等東東!呵呵!
寫了這個(gè)東西,可能在高手看來,非常的稚嫩!不過完全自己寫的!
還沒有完善,請(qǐng)大俠指導(dǎo)??!
看代碼
<!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("已經(jīng)存在在數(shù)組里!"); //alert(str); var b=$(e+"fa"); str=$(e+"faz").value; b.removeChild($(e+"faz")); x.innerText=str; }else{ //alert("沒有存在在數(shù)組里!"); 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')">可編輯的內(nèi)容</div> <div class="test" id="test1" onclick="edit('test1')">可編輯的內(nèi)容</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);//封裝獲取函數(shù) } function edit(e){ //parseInt $(e).style.display="none"; $(e+"fm").style.display="block"; $(e+"fm").childNodes[0].focus(); //div的子元素自動(dòng)獲得焦點(diǎn) } function hide(e){ //parseInt $(e).style.display="none"; $(e=e.replace("fm","")).style.display="block"; } --> </script> </HEAD> <BODY>
唉!!忙了一晚上,就這么解決了?。∥?nbsp; 呵呵
郁悶!<br> <font color=red><b>在firefox下 由于DOM有很小的差異,含有input的div中除標(biāo)簽內(nèi)的空格外</b></font><br> <font color=red><b>不能有空格因?yàn)槲覀冇玫氖莄hildNodes[0]!否則需要點(diǎn)兩下!</b></font> <div> <div class="show" id="test" onclick="edit(this.id)">可編輯的內(nèi)容一</div> <div class="hide" id="testfm"><input type="text" name="nn" value="可編輯的內(nèi)容一" onBlur="hide(this.parentNode.id)" /></div> <div class="show" id="test1" onclick="edit(this.id)">可編輯的內(nèi)容二</div> <div class="hide" id="test1fm"><input type="text" name="nn" value="可編輯的內(nèi)容二" onBlur="hide(this.parentNode.id)" /></div> <div class="show" id="test2" onclick="edit(this.id)">可編輯的內(nèi)容三</div> <div class="hide" id="test2fm"> <input type="text" name="nn" value="可編輯的內(nèi)容三" onBlur="hide(this.parentNode.id)" > </div> <div class="show" id="test3" onclick="edit(this.id)">可編輯的內(nèi)容四</div> <div class="hide" id="test3fm"> <input type="text" name="nn" value="可編輯的內(nèi)容四" onBlur="hide(this.parentNode.id)" > </div> </div> </BODY> </HTML>
以上所述是小編給大家介紹的不用ajax實(shí)現(xiàn)點(diǎn)擊文字即可編輯的方法,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
javascript學(xué)習(xí)基礎(chǔ)筆記之DOM對(duì)象操作
javascript是一種基于對(duì)象和世界驅(qū)動(dòng),并且安全性較強(qiáng)的腳本語(yǔ)言。一個(gè)完整的javascript實(shí)現(xiàn)包括核心(ECMAScript),文檔對(duì)象模型(DOM)和瀏覽器對(duì)象模型(BOM)2011-11-11javascript通過獲取html標(biāo)簽屬性class實(shí)現(xiàn)多選項(xiàng)卡的方法
這篇文章主要介紹了javascript通過獲取html標(biāo)簽屬性class實(shí)現(xiàn)多選項(xiàng)卡的方法,涉及javascript針對(duì)頁(yè)面元素屬性與事件的相關(guān)操作技巧,需要的朋友可以參考下2015-07-07js實(shí)現(xiàn)DIV的一些簡(jiǎn)單控制
js實(shí)現(xiàn)DIV的一些簡(jiǎn)單控制...2007-06-06微信小程序使用form表單獲取輸入框數(shù)據(jù)的實(shí)例代碼
這篇文章主要介紹了微信小程序使用form表單獲取輸入框數(shù)據(jù)的實(shí)例代碼,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05JS中將blob返回值轉(zhuǎn)換為json格式的問題小結(jié)
這篇文章主要介紹了JS中如何將blob返回值轉(zhuǎn)換為json格式,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12window.onload與$(document).ready()的區(qū)別分析
這篇文章主要介紹了window.onload與$(document).ready()的區(qū)別,實(shí)例分析了二者在加載頁(yè)面元素使用過程中的區(qū)別,需要的朋友可以參考下2015-05-05