首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自定义元素和类装饰器

自定义元素和类装饰器
EN

Stack Overflow用户
提问于 2017-03-25 04:13:28
回答 1查看 590关注 0票数 0

自定义元素对类装饰器的作用是不同的?

示例:

index.html

代码语言:javascript
复制
<test-2></test-2>
<script src="test2.js"></script>

=> test2.js (目标:es2017)

代码语言:javascript
复制
function defineClass(tagname: string) {
  return function classDecorator<T extends {new(...args:any[]):{}}>(constructor:T) {
    console.log("Define: " + constructor.name)
    window.customElements.define(tagname, constructor)
    return class extends constructor {
        newProperty = "decorator";
        hello = "decorator";
    }
  }
}

@defineClass('test-2')
class Greeter2 extends HTMLElement{
  property = 'property2'
  hello = 'hello2'
  constructor() {
    super()
    console.log(this.hello)
  }
  connectedCallback() { }
  disconnectedCallback() { }
  attributeChangedCallback(name: string, oldValue: string, newValue: string) { }
  adoptedCallback() { }
}
console.log('test-2: ', document.querySelector('test-2').hello)

@defineClass('test-3')
class Greeter3 {
  property = 'property3'
  hello = 'hello3'
  constructor() {
    console.log(this.hello)
  }
}
console.log('test-3: ', new Greeter3());

输出:

代码语言:javascript
复制
Define: Greeter2
hello2
test-2:  hello2 <= expected "decorator" like Greeter3 does

Define: Greeter3
hello3
test-3: Object {property: "property3", hello: "decorator", newProperty: "decorator"}

应该是这样运作的吗?如果是的话,为什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-30 21:23:22

https://github.com/rictic找到了解决方案,被问到他是否有时间在堆栈上回答这个问题,但不要认为他有账户,所以我就把它粘贴起来。

代码语言:javascript
复制
function defineClass(tagname: string) {
  return function classDecorator<T extends {new(...args:any[]):{}}>(constructor:T) {
    console.log("Define: " + constructor.name)
    const generated = class extends constructor {
        newProperty = "decorator";
        hello = "decorator";
    }
    window.customElements.define(tagname, generated)
    return generated;
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43012436

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档