【问题标题】:HTML Web Worker and Jquery Ajax callHTML Web Worker 和 Jquery Ajax 调用
【发布时间】:2011-06-17 20:31:51
【问题描述】:

我想知道是否可以在 web worker 文件中使用 jQuery。谷歌浏览器给了我这个错误:“Uncaught ReferenceError: $ is not defined”。

代码如下: 父文件:

var loader = new Worker(BASE_URL + "js/rss_loader_worker.js");
// Ask the worker to start loading the RSS from the server
loader.postMessage("loadRss");
// When receive the response from the server
loader.onmessage = function (event) {
  console.log(event.data);
}

工人档案:

onmessage = function (event) {
  if (event.data === "loadRss") {
    loadRss();
  }
}

/**
 * This function handles the AJAX request to the server side
 * then pass the content to the view page
 * @param none
 * @return html text
 */
loadRss = function () {
  $.ajax({
    data: {city: CITY_LOCATION},
    url: BASE_URL + "/getfeeds",
    onsucess: function (data) {

    }
  });
}

请帮忙,谢谢:)

【问题讨论】:

  • importScripts("jquery.js");不能工作:jQuery 使用'window' 变量,网络工作者无法访问该变量。但是您可以使用其他库来完成这项工作 =)
  • 为了让入站搜索者清楚,从Worker 运行 ajax 请求是可能的,而且通常是有益的。与传统的jQuery 不同,因为jQuery 是一个DOM 操作库,而Web Worker 有一个WorkerGlobalScope 而不是Window,因此无法访问文档或DOM。

标签: jquery ajax html web-worker


【解决方案1】:

不,你不能。无法访问非线程安全组件或 DOM,您必须通过序列化对象将特定数据传入和传出线程。所以你必须非常努力地在你的代码中引起问题。 jQuery 是一个 JavaScript DOM 库

但是您可以在您的工作人员中使用本机 XMLHttpRequest

而且,导入外部脚本不会通过带有script 标签的页面:在您的工作文件中使用importScripts()

【讨论】:

  • 好的,感谢您的帮助。现在很清楚了。我会找到另一种方式。
【解决方案2】:

Node.JS 中的执行环境也缺少原生 DOM 实现。我认为可以公平地说 Node.JS 和 HTML5 Web Workers 有一定的限制。

为了在 Node.JS 中使用 jQuery,有一些方法可以模拟 DOM 实现。如果您仍然想在 Web Workers 中使用 jQuery,我认为您应该搜索 Node.JS 解决方案,看看它们是否适用。

【讨论】:

    【解决方案3】:

    【讨论】:

    • jQuery hive 是在 jQuery 中使用 web worker 的抽象,而不是相反
    • 这个插件现在已经过时了。它的界面与您在当前 jQ 中习惯的不同。
    • @Anzeo 虽然 jQuery Hive 将用于面向 DOM 的脚本中,但 jQuery Hive Pollen 将用于您的 Worker 内部。也许在撰写本文时,Pollen 不可用。
    【解决方案4】:

    这是我发现的:

    您可以使用 importScripts()函数。

    http://www.html5rocks.com/en/tutorials/workers/basics/#toc-enviornment-loadingscripts

    importScripts('script1.js');
    importScripts('script2.js');
    

    importScripts('script1.js', 'script2.js');
    

    虽然,你不能加载 jQuery,因为 jQuery 需要 DOM 访问权限,而 web worker 没有。

    【讨论】:

    • 也赞成,因为您解释了有关 DOM 访问的问题。
    【解决方案5】:

    jQuery 主要用于处理 DOM 和处理网页。所以它不太适合没有访问 DOM 的 Web Worker。

    您可能想要使用实用程序库而不是 DOM 库,例如 underscore.js,或者也许有人应该制作一个 jQuery Worker 库,这是 jQuery 的精简版,没有所有 DOM 操作功能,只是保持实用函数。

    【讨论】:

      【解决方案6】:

      由于网络工作者在外部文件中,他们无权访问以下 JavaScript 对象:

      • 窗口对象
      • 文档对象
      • 父对象

      所以你不能在工作文件中使用 $。更好的是你可以使用像这样的传统 AJAX

      if (window.XMLHttpRequest)
      {
        // code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp=new XMLHttpRequest();
      }
      else
      {
        // code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
      }
      

      参考http://www.w3schools.com/html/html5_webworkers.asp

      【讨论】:

      猜你喜欢
      • 2013-11-12
      • 2013-09-17
      • 1970-01-01
      • 1970-01-01
      • 2014-07-31
      • 1970-01-01
      • 1970-01-01
      • 2010-10-01
      相关资源
      最近更新 更多