gpt4 book ai didi

javascript - 自定义 HTML 元素属性未显示 - Web 组件

转载 作者:搜寻专家 更新时间:2023-11-01 05:10:07 25 4
gpt4 key购买 nike

我正在探索 Web 组件自定义 HTML 元素,但在向我的自定义元素添加自定义属性时遇到了问题:我在标记中设置的任何值都不会被接受。对于像这样的简单元素,它应该显示“flagtext”属性中提供的文本,它总是显示默认值。

<test-flag flagtext="my text"></test-flag> 

完整的 JSBin 样本是 here .

JSBin 使用 Polymer 库(因为这是我唯一可以拉进去的东西)。我一般使用 webcomponents.js,结果相同。在 Chrome 49 和 Firefox 45 中都给出了相同的结果。控制台或调试器中没有显示错误。

我在网上找到的每个示例都有类似的代码,但我尝试了各种版本,但它总是拒绝更新。我什至将一些示例复制到 JSBin 中,但它们也不起作用。

有什么问题吗?我知道这是实验性技术,但它不起作用的一致性仍然令人惊讶。这个标准被放弃了吗? (我看到最新的 2016 年 4 月 W3C 自定义元素草案完全改变了它的方法。)

当我定义“attributeChangedCallback”函数时,它没有触发。我可以通过 Javascript 轻松修改属性,这不是问题。

但为什么我不能像我应该的那样在标记中指定属性?

编辑 - 完整代码

请注意,您需要将它们放入单独的文件中以进行 HTML 导入,并且您需要“webcomponents-lite.js”库。

主 HTML 文件

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
test-flag
{
border: 1px solid blue;
}
</style>
</head>
<body>
<script src="lib/webcomponents-lite.min.js"></script>
<link rel="import" href="test-flag.html">

Here is the custom test-flag component:
<p>
<test-flag flagtext="my text"></test-flag>
</body>
</html>

文件:test-flag.html

<template>

<style>
</style>

Content:
<div id="testflagID">
</div>

</template>


<script>

(function() {

var _currentScript = (document._currentScript || document.currentScript);
var importDoc = _currentScript.ownerDocument;
var customPrototype = Object.create(HTMLElement.prototype);
Object.defineProperty(customPrototype, 'flagtext', {value: '(default)', writable: true});
document.registerElement('test-flag', {prototype: customPrototype});


customPrototype.createdCallback = function()
{
var template = importDoc.querySelector('template');
var clone = document.importNode(template.content, true);
var idx = clone.querySelector("#testflagID");
idx.textContent = this.flagtext;
var root = this;
var createdElement = root.appendChild(clone);

};

})();

</script>

最佳答案

有 2 个概念不会自动链接在一起。

在 HTML 代码中:

<test-flag flagtext="my text"></test-flag>

...term flagtext 是一个 HTML 属性(不是属性)。

在 JavaScript 代码中:

Object.defineProperty(customPrototype, 'flagtext', {value: '(default)', writable: true})

...term flagtext 是 JavaScript 属性(不是属性)。

对于标准元素,浏览器会自动将属性 值绑定(bind)到属性 值(反之亦然)。也适用于自定义元素(具有标准属性)。但如果您想添加自定义属性,则必须手动绑定(bind)它。

例如,在createdCallback()方法中,添加:

this.flagtext = this.getAttribute( 'flagtext' ) || '(default)'

现场样本:

document.registerElement( 'test-flag' , {
prototype: Object.create( HTMLElement.prototype, {
flagtext: {
value: '(default)',
writable: true
},
createdCallback: {
value: function()
{
this.flagtext = this.getAttribute( 'flagtext' ) || this.flagtext
this.innerHTML = 'flagtext=' + this.flagtext
}
},
} )
} )
<test-flag flagtext='new content'>Hello</test-flag>

注意:attributeChangedCallback() 方法只有在 元素创建后更改了 attribute 时才会触发(这里不是这种情况) .

关于javascript - 自定义 HTML 元素属性未显示 - Web 组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37253002/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com