开发者

jquery: Keep <script> tag after .find()

I'm trying to add ajax to WordPress by jquery-ajaxy plugin, and I'm stuck with one thing:

My page is loaded by ajax call, filtered, and appended to dom. So in short, it would be:

data = this.state.Response.data; //full html of page returned by ajax
$mainContent = $(data).find("#content"); //we filter out what we need 
$('#content_div').append($mainContent); //we display it

Easy for now, but there are inline js scripts in $mainContent, which are striped by jquery. I need them, somehow.

It a开发者_JS百科ll works, if I just do

.append(data);  

But data contains full html (doctype, head, meta) which I can't append. So, is there a way to make those tags work after .find()?


Whenever you create a jQuery object from a string, script tags are automatically stripped. You can see a discussion in here: JavaScript RegEx for div tags

What I would do, as suggested in a post in the thread above, is to wrap the content in special comment tags and use javascript match() to extract it, the append the whole string.

data = this.state.Response.data; //full html of page returned by ajax

//Assuming your data looks like: ...<!--Content Start-->CONTENT<!--Content End-->...
//we filter out what we need 
data = data.match(/<\!\-\-Content Start\-\->(.*?)<\!\-\-Content End\-\->/)[1];

$('#content_div').append(data); //we display it


Try with jQuery Filter instead of find method.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜