0

$.getScript(fileURL)请在说“使用或”之前阅读情况$('body').append($('<script>', {type" 'text/javascript', src: fileURL}))

我正在尝试使用Amara Embedder链接到视频。通常,对于这么简单的任务,我不会同时使用 jQuery,但在这件事上我别无选择。

所以,我首先尝试了最简单的选项:

$(function() {
  $.getScript('https://amara.org/embedder-iframe');
});
<div class="amara-embed" data-height="480px" data-width="854px" data-url="http://www.youtube.com/watch?v=5CKwCfLUwj4"></div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>

这将失败并出现类似于以下内容的控制台条目:

GET https://domain.com/embedder-widget-iframe/?data=%7B%22hei…22url%22%3A%22http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D5CKwCfLUwj4%22%7D 404 (Not Found)

从示例中应该可以看出,这不是很好。问题在于,不是执行脚本并使用amara.org域作为其基本 URL,而是使用$.getScript()已执行的域执行脚本。

使用 JavaScript,创建SCRIPT元素并将其附加到BODY它以使其工作很简单。

window.onload = (function() {
  var link = document.createElement('script');
  link.type = 'text/javascript';
  link.src = 'https://amara.org/embedder-iframe';
  document.getElementsByTagName('body')[0].appendChild(link);
})();
<div class="amara-embed" data-height="480px" data-width="854px" data-url="http://www.youtube.com/watch?v=5CKwCfLUwj4"></div>

这成功了,因为它从域执行GETs :amara.org

https://amara.org/embedder-widget-iframe/?data=%7B%22height%22%3A%22480px%22%2C%22width%22%3A%22854px%22%2C%22url%22%3A%22http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D5CKwCfLUwj4%22%7D

现在,我尝试了 jQuery 的变体,例如$('body').append($('<script>', {type" 'text/javascript', src: 'https://amara.org/embedder-iframe'}))$('<script>', {type" 'text/javascript', src: 'https://amara.org/embedder-iframe'}).appendTo('body')得到相同的结果。

我一直无法找到将其标识为预期功能的文档,也无法找到如何解决它。

4

2 回答 2

1

404 错误来自 amara.org 脚本,而不是 jQuery 请求。当它在 jQuery 函数中运行时,我敢打赌某种上下文this被错误地分配了。

编辑:找到了。该代码取决于其 url 在脚本标记的源属性中。

// This must be done when the js file is first loaded
var scriptFiles = document.getElementsByTagName("script");
var THIS_JS_FILE = scriptFiles[scriptFiles.length-1].src;
于 2016-05-27T20:01:19.053 回答
0

看起来 jQuery 添加了script标签,然后尽快将其删除。当您使用“vanilla” JS 添加脚本时,脚本会保留在那里。 jQuery 将script标签附加到head元素,而您正在附加scriptbody元素的末尾。

Amara 似乎试图通过获取 last script tag 来获取其“环境”域src,因为它假定最后一个将是加载它的那个。在这种情况下这是错误的,这就是为什么它得到错误的域名。

于 2016-05-27T20:30:25.740 回答