我正在尝试让 Web 组件和 HTML 导入在 Firefox 和 IE 中工作。
我按照Web Components GitHub repo中的说明进行操作,通过 npm 安装文件,并将其包含在文档的开头。
我有一个在文档正文中调用的自定义脚本。
在 Firefox 中,polyfill 是动态(同步)加载的,但会将正文中的脚本标签从以下位置转换:
<script type="module" src="./src/scripts/init.js"></script>
至
<script src="/components/requirejs/require.js"></script>
<script>require(["./src/scripts/init.js"]);</script>
我收到以下错误:
ReferenceError: require is not defined
。
我还尝试遵循这个 StackOverflow 答案并分别下载了 polyfill:
(旁注:是否建议从 repo 文件中复制/粘贴原始代码?我不知道另一种方法。我还发现实际上定位正确的文件非常令人困惑,因为有时文件位于根目录中文件夹,其他时候在“src”中。我错过了什么吗?)
我对文件进行排序,head
如下所示:
<!-- <script src="src/scripts/helper/web-components-polyfill.js"></script> -->
<script type="text/javascript" src="src/scripts/helper/html-imports-polyfill.js"></script>
<script type="text/javascript" src="src/scripts/helper/custom-element-polyfill.js"></script>
注意:当我尝试遵循参考问题的建议时,我注释掉了“通用”Web 组件 polyfill。
在 Firefox 和 IE 中,我得到同样的错误:require is not defined
. 我在 Firefox 中得到了这个额外的好处:
我还尝试根据 WebComponents.org 使用特征检测来加载polyfill:
<script type="text/javascript">
(function() {
if ('registerElement' in document
&& 'import' in document.createElement('link')
&& 'content' in document.createElement('template')) {
// platform is good!
} else {
// polyfill the platform!
console.log('loading the polyfills');
var e = document.createElement('script');
e.type = "text/javascript";
e.src = './src/scripts/helper/html-imports-polyfill.js';
document.head.appendChild(e);
var f = document.createElement('script');
f.src = './src/scripts/helper/custom-elements-polyfill.js';
document.head.appendChild(f);
}
})();
</script>
启动应用程序的脚本,init.js
我在 polyfill 被“加载”后调用,被设置为导入 HTML 片段并将它们附加到文档中。这是我用来执行此操作的函数:
/**
* Dynamically imports HTML into the Main file
*
* @param {String} path The path to the document to import
* @return {[type]} [description]
*/
function _importHTML(path) {
console.log('importHTML called', path);
let link = document.createElement('link');
link.rel = 'import';
link.href = path;
link.onload = (e) => {
// console.log('Successfully loaded', e.target.href);
}
link.onerror = (e) => {
console.log('Error loading', e.target.href);
}
document.head.appendChild(link);
}
不用说,但在 Chrome 中一切正常。
请帮忙!:D