正则精确匹配html,正则表达式匹配HTML正文的内容

每个人似乎都死于使用正则表达式,所以我想我会走另一条路并回答你的第二个查询。

理论上可以将AJAX的结果解析为xmlDocument。

如果你想要这个工作,你可能会想要采取几个步骤。

使用库。我推荐jQuery

如果您使用的是库,则必须确保响应的MIME类型是xml mimetype!

确保在所有目标浏览器中进行彻底测试。你会被绊倒。

话虽如此,我在jsbin上创建了一个快速示例。

它适用于IE和Firefox,不幸的是为了让它工作,我不得不推出我自己的XMLHttpRequest对象。

View the example source code here

(说真的,这段代码很难看。值得使用库并正确设置mime类型......)

function getXHR() {

var xmlhttp;

//Build the request

if (window.XMLHttpRequest) {

// code for IE7+, Firefox, Chrome, Opera, Safari

xmlhttp=new XMLHttpRequest();

} else if (window.ActiveXObject) {

// code for IE6, IE5

xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");

} else {

alert("Your browser does not support XMLHTTP!");

}

//Override the mime type for firefox so that it returns the

//result as an XMLDocument.

if( xmlhttp.overrideMimeType ) {

xmlhttp.overrideMimeType('application/xhtml+xml; charset=x-user-defined');

}

return xmlhttp;

}

function runVanillaAjax(url,functor)

{

var xmlhttp = getXHR();

xmlhttp.onreadystatechange=function() { functor(xmlhttp); };

xmlhttp.open("GET",url,true);

xmlhttp.send(null);

}

function vanillaAjaxDone( response ) {

if(response.readyState==4) {

//Get the xml document element for IE or firefox

var xml;

if ($.browser.msie) {

xml = new ActiveXObject("Microsoft.XMLDOM");

xml.async = false;

xml.loadXML(response.responseText);

} else {

xml = response.responseXML.documentElement;

}

var textarea = document.getElementById('textarea');

var bodyTag = xml.getElementsByTagName('body')[0];

if( $.browser.msie ) {

textarea.value = bodyTag.text;

} else {

textarea.value = bodyTag.textContent;

}

}

}

function vanillaAjax() {

runVanillaAjax('http://jsbin.com/ulevu',vanillaAjaxDone);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值