HTML导入自己的WebComponent

Chr*_*her 3 html javascript import platform web-component

在我的 index.html 中,我导入了一个带有模板、Shadow DOM 等自定义 Web 组件的外部 HTML 文件。

// 索引.html

... 
<script src="//cdnjs.cloudflare.com/ajax/libs/polymer/0.3.4/platform.js"></script>
<link rel="import" href="/html-components/userlogin-header.html" >
<head>
<body>
<userlogin-header username="Test User"userimage="http://domain.com/img.jpg"></userlogin-header>
...
Run Code Online (Sandbox Code Playgroud)

另一个文件 userlogin-header.html:

// 用户登录-header.html

<template id="userlogin-header">

    <div class="imgbox">
        <img src="" class="userimage">
    </div>
    <div class="userinfo">                          
        <div class="name"><span class="username"></div>                     
    </div>
</template>


<script>
    var doc = this.document.currentScript.ownerDocument,
    UserLoginProto = Object.create( HTMLElement.prototype );
    UserLoginProto.createdCallback = function() {
        var template = doc.querySelector( "#userlogin-header" ),
        box = template.content.cloneNode( true );

        this.shadow = this.createShadowRoot();
        this.shadow.appendChild( box );

        var username = this.shadow.querySelector( '.userinfo .username' );
        username.innerHTML = ( this.getAttribute( 'username' ) || 'Unbekannt' );

        var imageurl = this.shadow.querySelector( 'img.userimage' );

        imageurl.src = 'https://secure.gravatar.com/avatar/' + this.getAttribute( 'userimage' ) + '1?s=40&d=http://s3-01.webmart.de/web/support_user.png';
    };

     var Xuserlogin = doc.registerElement( 'userlogin-header', { 'prototype' : UserLoginProto } );
</script>
Run Code Online (Sandbox Code Playgroud)

问题是调用index.html时出现以下错误

Uncaught TypeError: Cannot read property 'content' of null 
Run Code Online (Sandbox Code Playgroud)

如果我在 Chrome 中启用 HTML 导入,一切都会正常工作。但是当我禁用它并使用 platform.js 时,出现了这个错误。

这个问题有什么解决办法吗?我不想使用整个聚合物框架。

Cle*_*usW 5

这是Polyfill警告的一个症状。

在本机 HTML 导入中,document.currentScript.ownerDocument 引用导入文档本身。在polyfill中使用 document._currentScript.ownerDocument(注意下划线)。

更改后,您还需要使用document .registerElement 而不是doc .registerElement。您希望注册该元素,使其对导入文档可见,而不是对导入文档可见。

var Xuserlogin = document.registerElement(...);
Run Code Online (Sandbox Code Playgroud)

这是一个正在工作的 plunk