如何通过Ajax发送HTML和Javascript

时间:2012-06-28 02:45:00

标签: javascript jquery ajax

我想使用AJAX调用从同一页面检索HTML和Javascript。但是,我不确定最好,最干净,最安全的方法是什么。我希望我的Javascript编辑客户端上已定义的对象。到目前为止,我的想法是:

在某些事件上执行的客户端脚本:

getMoreStuff = function () {
  $.ajax({
    url: '/someRoute',
    success: function (data) {
      $data = $(data);
      $things = $data.find('#things');
      $('#content').append($things);
      // Execute the script
    }
  })
}

AJAX请求主体:

<div id="things">
  <div class="post">...</div>
  <div class="post">...</div>
  <div class="post">...</div>
  <div class="post">...</div>
  <div class="post">...</div>
</div>
<script>
  (function() {
    window.things || (window.things = []);
    things.concat([...some array...]);
  })();
</script>

在定义$data时,我不确定我的jQuery代码是否执行它。或者我应该将脚本作为字符串发送并使用eval?

这会有用吗?

$(document.body).append($data.find('script'));

1 个答案:

答案 0 :(得分:2)

请参阅dataType here

  

“html”:以纯文本形式返回HTML;包含的脚本标记被评估   插入DOM时。