最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - React Typescript type a void function - Stack Overflow

programmeradmin0浏览0评论

Why don't get an error after typing a function that should return nothing and then access props.onClick inside Message ponent that returns something value?

type MessageProps = {
  onClick: () => void,
  value?: string
}

const Message: React.FunctionComponent<MessageProps> = (props: any) => {
  return (
    <>
      <h1>Example message</h1>
      <button onClick={props.onClick}>click</button>
    </>
  )
}

const App = (props: any) => {
  return (
    <div className="App">
      <Message onClick={() => 2} />
    </div>
  );
}

export default App;

Why don't get an error after typing a function that should return nothing and then access props.onClick inside Message ponent that returns something value?

type MessageProps = {
  onClick: () => void,
  value?: string
}

const Message: React.FunctionComponent<MessageProps> = (props: any) => {
  return (
    <>
      <h1>Example message</h1>
      <button onClick={props.onClick}>click</button>
    </>
  )
}

const App = (props: any) => {
  return (
    <div className="App">
      <Message onClick={() => 2} />
    </div>
  );
}

export default App;
Share Improve this question asked Apr 4, 2022 at 8:14 TelirwTelirw 4431 gold badge8 silver badges16 bronze badges 2
  • Returning void is not the same as doing nothing. onClick expects a function, and you're giving it one – Tom Commented Apr 4, 2022 at 8:16
  • github./microsoft/TypeScript/issues/… – Jayce444 Commented Apr 4, 2022 at 8:19
Add a ment  | 

1 Answer 1

Reset to default 9

Fundamentally what you're asking is why this assignment doesn't result in an error:

type VF = () => void;

const f: VF = () => 2;

(playground)

It's because a function type with a void return type doesn't require that the function assigned doesn't return anything. From the documentation:

Return type void

The void return type for functions can produce some unusual, but expected behavior.

Contextual typing with a return type of void does not force functions to not return something. Another way to say this is a contextual function type with a void return type (type vf = () => void), when implemented, can return any other value, but it will be ignored.

(their emphasis)

If you think about it, that makes sense, since all JavaScript functions return something — if there's no explicit return, or there's a return; with no value, the return value is undefined.

function a() { }
function b() { return; }
console.log("a", a());
console.log("b", b());

(I think that's covered here [for a] and here [for b] in the JavaScript spec, just for what it's worth.)

发布评论

评论列表(0)

  1. 暂无评论