我的网站Feed看起来像这样
<rss...>
<title> some title </title>
<content>
<![CDATA[ <div>this tag is ignored<div> who took the cookie in the cookie jar!? ]]>
</content>
</rss>
我需要在html中显示cdata的全部内容。我正在使用jquery 1.9.1,当我使用$(xml).find('rss content').text()
获取内容部分时,
它实际上忽略了整个<div>this tag is ignored<div>
部分。有什么方法可以使用javascript或jquery在CDATA中获取所有内容吗?
答案 0 :(得分:6)
有可能你的标记没有被jQuery解析为XML。尝试明确调用$.parseXML():
var contentText = $($.parseXML(xml)).find("rss content").text();
答案 1 :(得分:3)
底线:
xmlDoc.getElementsByTagName("content")[0].childNodes[0].nodeValue
来自工作代码的这段代码使用jquery加载xml,然后获取内容标记的第4次出现(包含CDATA)
var req = new AjaxRequest();
req.setMethod("POST");
...
req.loadXMLDoc(linkString, paramString);
var htmlContent = req.getResponse().responseXML.getElementsByTagName('content').item(3).childNodes[0].nodeValue;
答案 2 :(得分:1)
从字符串解析XML文档时,jQuery不是最佳。最好使用浏览器的原生DOM Parser。然后jQuery可以更好地处理解析的XML文档;否则我相信它会尝试像XML这样产生奇怪的结果。
$xml = $((new DOMParser).parseFromString(xml, "text/xml"));
http://jsfiddle.net/ExplosionPIlls/2MJt9/
编辑:基于另一个答案,$.parseXML
可能是一个更好的选择,因为它应该与其他浏览器一起使用,但你必须以与上面类似的方式使用它,因为结果是一个XML文档而不是jQuery对象。
$xml = $($.parseXML(xml));
答案 3 :(得分:0)
jQuery中CDATA的文本:
!$.ajax(YOUR_URL,{
dataType: 'xml',
success: function (dataR, textStatus, jqXHR){
var rrsobj = $(dataR).find('rss');
if(rrsobj ){
desc = $(rrsobj [0]).children('content');
if(desc)
var txt = desc[0].childNodes[0].data; }
}});
其中dataR是从YOUR_URL读取的,而txt包含来自CDATA的信息