首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >是否根据值向接口添加键?

是否根据值向接口添加键?
EN

Stack Overflow用户
提问于 2021-01-05 16:16:03
回答 1查看 35关注 0票数 1

场景

我在这里的场景是我有两个类,第一个是一个粗略的ObservableStore类,另一个基类可以传递一些ObservableStore-s的值。

代码语言:javascript
运行
复制
class ObservableStore<T> {
  update(value: (current: T) => T): void;
  subscribe(fn: (current: T) => void): void;
}

class OtherClass<Props extends {} = {}> {
  constructor(private props: Props) {
    for(let [key, value] of Object.entries(props)) {
      if(value instanceof ObservableStore) value.subscribe($data => this[`$${key}`] = $data);
    }
  }
}

const someInstance = new OtherClass({ someStore: new ObservableStore<string[]>([]) });

问题

有没有办法使用类型将$someStore值添加到this.props上,或者这目前还不可能吗?

EN

回答 1

Stack Overflow用户

发布于 2021-01-05 21:32:07

一种方法是

代码语言:javascript
运行
复制
class ObservableStore<T> {
    constructor(arg: T[]) {
        // ...
    }
    update(value: (current: T) => T): void { }
    subscribe(fn: (current: T) => void): void { }
}

type Props<T> = Record<string, ObservableStore<T>>;

class OtherClass<T> {
    constructor(private props: Props<T> = {}) {
        for (let [key, value] of Object.entries(props)) {
            // has to cast `this` for dynamic properties here, perhaps there is another workaround 
            if (value instanceof ObservableStore) value.subscribe($data => (this as unknown as Record<string, T>)[key] = $data);
        }
    }
}

const someInstance = new OtherClass<string[]>({ someStore: new ObservableStore<string[]>([]) });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65575228

复制
相关文章

相似问题

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