Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
152 views
in Technique[技术] by (71.8m points)

angular - Typescript: Get Exclusive Members from Union Interface Type

How do I get the Exclusive Member from a Union Typescript?

selectedQueueItems: Array< TestA | TestB > = [];

TestA has an interface member called Food, that TestB interface does not have. However most of the other interface members are similar between each.

Receiving Error:

Property 'Food' does not exist on type 'TestA | TestB'.

Property 'Food' does not exist on type 'TestB'

Currently working with existing design in our code base.

Reference question:

Typescript: Get Exclusive Members from Union Class Type

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

The easiest way to do this is to have each interface have a common property that has a unique value for each type in the union. This is a discriminated union.

That might look something like:

interface TestA {
  type: 'A'
  Food: string
}

interface TestB {
  type: 'B'
}

With that setup, you can test for item.type === 'A' and then typescript knows that you have object of type TestA.

That might look like this:

for (const item of selectedQueueItems) {
  if (item.type === 'A') {
    // item is known to be a TestA in this scope, since only TestA has: .type === 'A'
    console.log(item.Food) // Works
  }
}

If there is no property like that, you can still check for the properties presence before you access it with a 'key' in object check.

for (const item of selectedQueueItems) {
  if ('Food' in item) {
    // item is known to be a TestA in this scope, since only TestA has .Food
    console.log(item.Food) // Works
  }
}

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...