Does Typescript support extracted interface by excluding another interface's properties?
I wonder if it has any of the following features. I tried Google but I couldn't find it out. Thanks!
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Numbers - { number3 } = {
number: 1,
number2: 2
};
typescript
add a comment |
I wonder if it has any of the following features. I tried Google but I couldn't find it out. Thanks!
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Numbers - { number3 } = {
number: 1,
number2: 2
};
typescript
Have you read the documentation of TypeScript? It explains (with examples) what one can and cannot do with interfaces.
– axiac
Apr 1 at 8:04
@axiac Thanks! I've already read it before, but not entirely. and I've read the interface section once more according to your advice. :)
– left click
Apr 1 at 8:30
1
Based on the answer you get, it seems reading the release notes of each version is required to be up to date with the language: typescriptlang.org/docs/handbook/release-notes/…. I started reading them too.
– axiac
Apr 1 at 8:40
@axiac I appreciate your kindness.
– left click
Apr 1 at 8:55
add a comment |
I wonder if it has any of the following features. I tried Google but I couldn't find it out. Thanks!
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Numbers - { number3 } = {
number: 1,
number2: 2
};
typescript
I wonder if it has any of the following features. I tried Google but I couldn't find it out. Thanks!
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Numbers - { number3 } = {
number: 1,
number2: 2
};
typescript
typescript
asked Apr 1 at 8:00
left click
26829
26829
Have you read the documentation of TypeScript? It explains (with examples) what one can and cannot do with interfaces.
– axiac
Apr 1 at 8:04
@axiac Thanks! I've already read it before, but not entirely. and I've read the interface section once more according to your advice. :)
– left click
Apr 1 at 8:30
1
Based on the answer you get, it seems reading the release notes of each version is required to be up to date with the language: typescriptlang.org/docs/handbook/release-notes/…. I started reading them too.
– axiac
Apr 1 at 8:40
@axiac I appreciate your kindness.
– left click
Apr 1 at 8:55
add a comment |
Have you read the documentation of TypeScript? It explains (with examples) what one can and cannot do with interfaces.
– axiac
Apr 1 at 8:04
@axiac Thanks! I've already read it before, but not entirely. and I've read the interface section once more according to your advice. :)
– left click
Apr 1 at 8:30
1
Based on the answer you get, it seems reading the release notes of each version is required to be up to date with the language: typescriptlang.org/docs/handbook/release-notes/…. I started reading them too.
– axiac
Apr 1 at 8:40
@axiac I appreciate your kindness.
– left click
Apr 1 at 8:55
Have you read the documentation of TypeScript? It explains (with examples) what one can and cannot do with interfaces.
– axiac
Apr 1 at 8:04
Have you read the documentation of TypeScript? It explains (with examples) what one can and cannot do with interfaces.
– axiac
Apr 1 at 8:04
@axiac Thanks! I've already read it before, but not entirely. and I've read the interface section once more according to your advice. :)
– left click
Apr 1 at 8:30
@axiac Thanks! I've already read it before, but not entirely. and I've read the interface section once more according to your advice. :)
– left click
Apr 1 at 8:30
1
1
Based on the answer you get, it seems reading the release notes of each version is required to be up to date with the language: typescriptlang.org/docs/handbook/release-notes/…. I started reading them too.
– axiac
Apr 1 at 8:40
Based on the answer you get, it seems reading the release notes of each version is required to be up to date with the language: typescriptlang.org/docs/handbook/release-notes/…. I started reading them too.
– axiac
Apr 1 at 8:40
@axiac I appreciate your kindness.
– left click
Apr 1 at 8:55
@axiac I appreciate your kindness.
– left click
Apr 1 at 8:55
add a comment |
1 Answer
1
active
oldest
votes
You can do this in 2.8 using the new Exclude
conditional type and the Pick
mapped type
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Omit<Numbers, 'number3'> = {
number: 1,
number2: 2
};
Before 2.8 Omit
could be defined like this:
type Diff<T extends string, U extends string> = ({[P in T]: P } & {[P in U]: never } & { [x: string]: never })[T];
type Omit<T, K extends keyof T> = Pick<T, Diff<keyof T, K>>;
1
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f49596047%2fdoes-typescript-support-extracted-interface-by-excluding-another-interfaces-pro%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
You can do this in 2.8 using the new Exclude
conditional type and the Pick
mapped type
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Omit<Numbers, 'number3'> = {
number: 1,
number2: 2
};
Before 2.8 Omit
could be defined like this:
type Diff<T extends string, U extends string> = ({[P in T]: P } & {[P in U]: never } & { [x: string]: never })[T];
type Omit<T, K extends keyof T> = Pick<T, Diff<keyof T, K>>;
1
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
add a comment |
You can do this in 2.8 using the new Exclude
conditional type and the Pick
mapped type
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Omit<Numbers, 'number3'> = {
number: 1,
number2: 2
};
Before 2.8 Omit
could be defined like this:
type Diff<T extends string, U extends string> = ({[P in T]: P } & {[P in U]: never } & { [x: string]: never })[T];
type Omit<T, K extends keyof T> = Pick<T, Diff<keyof T, K>>;
1
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
add a comment |
You can do this in 2.8 using the new Exclude
conditional type and the Pick
mapped type
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Omit<Numbers, 'number3'> = {
number: 1,
number2: 2
};
Before 2.8 Omit
could be defined like this:
type Diff<T extends string, U extends string> = ({[P in T]: P } & {[P in U]: never } & { [x: string]: never })[T];
type Omit<T, K extends keyof T> = Pick<T, Diff<keyof T, K>>;
You can do this in 2.8 using the new Exclude
conditional type and the Pick
mapped type
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;
interface Numbers {
number: number;
number2: number;
number3: number;
}
const numbers:Omit<Numbers, 'number3'> = {
number: 1,
number2: 2
};
Before 2.8 Omit
could be defined like this:
type Diff<T extends string, U extends string> = ({[P in T]: P } & {[P in U]: never } & { [x: string]: never })[T];
type Omit<T, K extends keyof T> = Pick<T, Diff<keyof T, K>>;
answered Apr 1 at 8:25
Titian Cernicova-Dragomir
56.2k33452
56.2k33452
1
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
add a comment |
1
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
1
1
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
I was trying to figure out by Exclude was introduced in 2.8, but it did not work to me. Good solution. Thank you for teaching me. :)
– left click
Apr 1 at 8:37
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f49596047%2fdoes-typescript-support-extracted-interface-by-excluding-another-interfaces-pro%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Have you read the documentation of TypeScript? It explains (with examples) what one can and cannot do with interfaces.
– axiac
Apr 1 at 8:04
@axiac Thanks! I've already read it before, but not entirely. and I've read the interface section once more according to your advice. :)
– left click
Apr 1 at 8:30
1
Based on the answer you get, it seems reading the release notes of each version is required to be up to date with the language: typescriptlang.org/docs/handbook/release-notes/…. I started reading them too.
– axiac
Apr 1 at 8:40
@axiac I appreciate your kindness.
– left click
Apr 1 at 8:55