ajaxを使わずに文字をクリックして編集できる方法を実現します。
5333 ワード
creat Elementに接触したばかりです。 ,apendChild 待ってくださいふふっ
これを書きましたが、上級者から見ると、とても幼いです。でも完全に自分で書きました。
まだ完璧ではありません。侠客の指導をお願いします。
コードを見る
これを書きましたが、上級者から見ると、とても幼いです。でも完全に自分で書きました。
まだ完璧ではありません。侠客の指導をお願いします。
コードを見る
<!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>
えっ!一晩中忙しくしました。このように解決しました。にこにこする へへ
!<br>
<font color=red><b> firefox DOM , input div </b></font><br>
<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>
以上述べたのは小编がみんなに绍介したajaxを使わないで文字をクリックして编集することができる方法を実现して、みんなに対してある程度助けがあることを望んで、もしみんなはいかなる疑问があったら私にメッセージを歓迎して、小编は直ちにみんなのに返答することができます!