我尝试使用.load()
并$.ajax
获取一些需要附加到容器的 HTML,但是当我将返回的 HTML 中的 Javascript 附加到元素时,它没有被执行。
使用.load()
:
$('#new_content').load(url+' #content > *',function() {
alert('returned');
});
我也尝试过切换到 $.ajax 调用。然后我从返回的 HTML 中提取脚本,然后将其附加到容器中,但同样的问题是,在这种情况下,JS 没有被执行甚至附加,据我所知,试图将 a 附加<script>
到 DOM 元素像这样不受欢迎?
使用$.ajax
:
$.ajax({ url: url }).done(function(response) {
var source = $("<div>").html(response).find('#overview_script').html();
var content = $("<div>").html(response).find('#content').html();
$('#new_content').html(content);
$('<script>').appendTo('#new_content').text(source).html();
});
理想情况下,我会在附加 HTML 后在回调中运行这个 javascript,但是变量被设置为从控制器返回的值。
因此,总而言之,我正在尝试获取一些包含 JS 的 HTML,这些 JS 需要在附加该 HTML 之后运行,但是我没有运气使用.load()
或者$.ajax()
返回的 HTML 中的脚本在附加它时消失,或者它确实根本不执行。