我正在从内容脚本向后台页面发送一条消息。该消息是一个URL,然后在后台对其进行Ajax解析。当我console.log检索到background.js的数据时,控制台日志是纯HTML,但是当我将消息发送回我的内容脚本时,消息突然出现在一个对象中,我不确定为什么。

这是我的代码:


  Content_Script.js:


chrome.runtime.sendMessage({greeting: URL}, function(response) {
      console.log(response.farewell); //logs an object: Object {farewell: Object}
      $('#stats-table2').append(response.farewell); //doesn't output anything.
    });



  Background.js:


chrome.runtime.onMessage.addListener(
  function(message, sender, sendResponse) {
      getStats(message, sender, sendResponse);
      return true;
});

function getStats(message, sender, sendResponse){
   $.ajax({
     url: message.greeting,
     dataType: 'text',
     success: function(data) {
          var info = $("<div>").html(data)[0].getElementsByTagName("table")[1];
          if(info != undefined) {
            console.log(info); //logs pure HTML into the console..
            sendResponse({farewell:info}); //sends message back.
          }

      }
  });
}


我已经为重要部分添加了评论。.我似乎无法弄清楚这一点,这使我发疯。有任何想法吗?谢谢!

最佳答案

您不能通过Messaging传递DOM节点;数据必须是JSON可序列化的,而DOM节点则不是。

仅传递您真正需要的数据(例如textContent),然后在另一侧重建节点。

10-07 19:56
查看更多