javascript:FF/Chrome與IE動態(tài)加載元素的區(qū)別說明
更新時間:2014年01月26日 09:30:58 作者:
今天在寫一段js時,發(fā)現(xiàn)IE與FF在動態(tài)加載Html元素時,有一些差別,一起過來看看下面的代碼吧
復制代碼 代碼如下:
<!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()方法改成
復制代碼 代碼如下:
<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樹中,再找出對應的處理賦值。我對于前端技術(shù)實屬菜鳥,個人理解:第一種寫法類似"按值傳遞",var liTemplate = $("#template");后,不管再對liTemplate里的元素做何處理,因為liTemplate尚未加入到dom樹中,最終調(diào)用liTemplate.html()時,返回的html代碼,還是最初處理前的html代碼(有點按值傳遞,使用的是一個副本,不管怎么處理,不影響原值的意味);而第二種寫法,先加入到dom樹后,再從dom中查找到該元素時,這時相當于得到的對象的指針引用,對“指針”指向的對象做任何修改,都會直接影響對象本身(有點按"引用傳遞"的意味)
相關(guān)文章
javascript設(shè)計模式之中介者模式Mediator
這篇文章主要介紹了javascript設(shè)計模式之中介者模式Mediator,需要的朋友可以參考下2014-12-12
微信小程序?qū)崿F(xiàn)通過雙向滑動縮放圖片大小的方法
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)通過雙向滑動縮放圖片大小的方法,結(jié)合實例形式分析了微信小程序事件響應及圖片元素屬性動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-12-12
直接拿來用的頁面跳轉(zhuǎn)進度條JS實現(xiàn)
這篇文章主要為大家分享了一款直接拿來用的頁面跳轉(zhuǎn)進度條,由javascript實現(xiàn),可以直接跳轉(zhuǎn)到相應頁面,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-01-01
javascript的解析執(zhí)行順序在各個瀏覽器中的不同
javascript是一種解釋型語言,它的執(zhí)行是自上而下的。由于各個瀏覽器對它的理解有所差異,所以我們有必要深入理解js的執(zhí)行順序2014-03-03

