javascript:FF/Chrome與IE動態(tài)加載元素的區(qū)別說明
更新時間:2014年01月26日 09:30:58 作者:
今天在寫一段js時,發(fā)現(xiàn)IE與FF在動態(tài)加載Html元素時,有一些差別,一起過來看看下面的代碼吧
復(fù)制代碼 代碼如下:
<!doctype html>
<html>
<head>
<title>ff 與 ie 動態(tài)加載元素的區(qū)別</title>
<script type="text/javascript" src="jquery-1.4.4.min.js"></script>
<style type="text/css">
li{margin:0;padding:0;list-style:none}
</style>
<script type="text/javascript">
function add(){
var liTemplate = $("#template");
liTemplate.find("input[name='awbpre']").val("999");
liTemplate.find("input[name='awbno']").val("12312311");
$("#box").append("<li>" + liTemplate.html() + "</li>");
}
</script>
</head>
<body>
<ul id="box">
<li id="template" style="display:none">
awbpre:
<input type="text" value="#awbno#" name="awbpre"/>
awbno:
<input type="text" value="#awbno#" name="awbno"/>
</li>
</ul>
<input type="button" value="add" onclick="return add()"/>
</body>
</html>
代碼本意為:點擊Add按鈕時,動態(tài)向頁面添加二個輸入框,同時給二個新加的輸入框賦值。IE 6,7,8,9(兼容模式)下運行正常,見下面的截圖:

但是在FF,Chrome,IE9(非兼容模式)下,就不對了:

把add()方法改成
復(fù)制代碼 代碼如下:
<script type="text/javascript">
function add(){
var liTemplate = $("#template");
$("#box").append("<li>" + liTemplate.html() + "</li>")
var new_li = $("#box li:last");
new_li.find("input[name='awbpre']").val("999");
new_li.find("input[name='awbno']").val("12312311");
}
</script>
就對了,二者的區(qū)別在于:第一種是先做賦值處理,再添加到dom樹中;第二種寫法是先加到dom樹中,再找出對應(yīng)的處理賦值。我對于前端技術(shù)實屬菜鳥,個人理解:第一種寫法類似"按值傳遞",var liTemplate = $("#template");后,不管再對liTemplate里的元素做何處理,因為liTemplate尚未加入到dom樹中,最終調(diào)用liTemplate.html()時,返回的html代碼,還是最初處理前的html代碼(有點按值傳遞,使用的是一個副本,不管怎么處理,不影響原值的意味);而第二種寫法,先加入到dom樹后,再從dom中查找到該元素時,這時相當(dāng)于得到的對象的指針引用,對“指針”指向的對象做任何修改,都會直接影響對象本身(有點按"引用傳遞"的意味)
相關(guān)文章
javascript trim 去空格函數(shù)實現(xiàn)代碼
去除字符串左右兩端的空格,在vbscript里面可以輕松地使用 trim、ltrim 或 rtrim,但在js中卻沒有這3個內(nèi)置方法,需要手工編寫。下面的實現(xiàn)方法是用到了正則表達式,效率不錯,并把這三個方法加入String對象的內(nèi)置方法中去。2008-10-10JavaScript將數(shù)組轉(zhuǎn)換成CSV格式的方法
這篇文章主要介紹了JavaScript將數(shù)組轉(zhuǎn)換成CSV格式的方法,實例分析了javascript使用valueOf方法將數(shù)組值轉(zhuǎn)換為csv格式字符串的技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03Array數(shù)組對象中的forEach、map、filter及reduce詳析
這篇文章主要給大家介紹了關(guān)于Array數(shù)組對象中forEach、map、filter及reduce的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用array數(shù)據(jù)具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08JavaScript判斷變量是否為空的自定義函數(shù)分享
這篇文章主要介紹了JavaScript判斷變量是否為空的自定義函數(shù)分享,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2015-01-01javascript中call apply 的應(yīng)用場景
call, apply都屬于Function.prototype的一個方法,它是JavaScript引擎內(nèi)在實現(xiàn)的,因為屬于Function.prototype,所以每個Function對象實例,也就是每個方法都有call, apply屬性.2015-04-04JS解決Date對象在IOS中的“大坑” 以及時間格式兼容問題
這篇文章主要介紹了JS解決Date對象在IOS中的“大坑” 以及時間格式兼容問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10easyui-edatagrid.js實現(xiàn)回車鍵結(jié)束編輯功能的實例
下面小編就為大家?guī)硪黄猠asyui-edatagrid.js實現(xiàn)回車鍵結(jié)束編輯功能的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04