使用jquery ajax访问页面的注意问题
下午有个学弟向我请教问题,问题大概是这样的,使用jquery的ajax异步访问一个页面,异步得到结果之后再对结果进行DOM操作。
这对于大家来说都是不复杂的问题,但是在我向学弟演示的过程中我仍学习到了新的问题,并在这里向大家分享。
要被异步访问的页面如下(GetData.htm)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
</head>
<body>
<div id="d1" class="c1">
fdsafdsafdsafdsafds
</div>
<div id="d2" class="c2">
feweqrewqrewqrewqrewq
</div>
</body>
</html>
<head>
<title></title>
</head>
<body>
<div id="d1" class="c1">
fdsafdsafdsafdsafds
</div>
<div id="d2" class="c2">
feweqrewqrewqrewqrewq
</div>
</body>
</html>
而要进行的脚本操作如下 $.get("GetData.htm", function(data) {
var dom = $(data);
var div = document.createElement("div");
div.innerHTML = data;
alert($(div).find("#d1").text());
})
var div = document.createElement("div");
div.innerHTML = data;
alert($(div).find("#d1").text());
})
这是我改了之后的代码。可以成功运行。
很多人以为对于回叫回来的data字符串只要加上$(data)就可以随意对其进行find之类的jq操作。实则不然,对于这个要被异步访问的页面,被$(data)之后会产生一个对象,而这个对象最大的组成是一个数组,数组中装着该浏览器认为是可取dom的元素,而这个对象可不可以使用find等DOM方法却是视情况而定的(因为有时你需要使用filter),如果你访问上面的页面是会被直接无视的。而如果是访问下面的页面则不会被无视<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
</head>
<body>
<div>
<div id="d1" class="c1">
fdsafdsafdsafdsafds
</div>
<div id="d2" class="c2">
feweqrewqrewqrewqrewq
</div>
</div>
<div id="ccc">123</div>
</body>
</html>
<head>
<title></title>
</head>
<body>
<div>
<div id="d1" class="c1">
fdsafdsafdsafdsafds
</div>
<div id="d2" class="c2">
feweqrewqrewqrewqrewq
</div>
</div>
<div id="ccc">123</div>
</body>
</html>
而这段代码不会无视的原因是因为你要搜寻的元素的位置位于你使用$(data)返回对象里边的数组中元素的内部,而不是直接是这个数组中的一个元素。让我们观察这个var dom=$(data)在每个浏览器中的表现
。
。简单说来就是如果你要选择的元素在这个元素数组中,则不能直接使用find等操作,如果你要选择的元素在这个元素数组中的一个元素中,则你可以使用。(我的确感觉我有些小题大做了)。而对于第一种情况,你需要使用filter,它会对这个数组进行筛选找到希望找到的元素,而find是在子集中寻找目标。不过我仍然觉得
var div = document.createElement("div");
div.innerHTML = data;
然后对div对象进行dom操作的最好方法,直接、传统。
我写本文最大的收获是发现各个浏览器对元素的反应(IE会加入doctype,而ff会加入title) 。
我的确有些小题大做了。。。只是希望对需要的同学有点帮助,高手见谅。
浙公网安备 33010602011771号