Typoskript, wie die restlichen Parameter in das Objekt eingegeben werden

Nov 26 2020
  function test(data){
      console.log(data)
  }

  test({comments: 'hi', eat: true, sleep: true})

Ich bin mir sicher, dass in der Testfunktion das Kommentarargument angezeigt wird, wobei wie bei anderen Argumenten die Eigenschaften möglicherweise dynamisch sind, der Wert jedoch vom booleschen Typ.

  test({comments: 'hi', drink: true, sleep: true})

Wie sollte ich in dieser Situation die Daten korrekt eingeben? Ich habe so etwas versucht, aber es scheint falsch

function(data: {data: {comments: string, [key: string]: boolean})

Antworten

1 НиколайГольцев Nov 26 2020 at 17:55

Ich kann Ihnen eine Art Problemumgehung vorschlagen:

function test<T extends {
  [key: string]: any;
}>(data: { comments: unknown } & { [key in keyof T]: key extends "comments" ? string : boolean }) {
  const comments = data.comments as string;
  console.log(comments);
  console.log(data.eat);
  console.log(data.sleep);
}

test({comments: "hi"}); // works
test({comments: "hi", eat: true}); // works
test({comments: true}); // doesn't works
test({comments: 5}); // doesn't works
test({comments: "hi", eat: "true"}); // doesn't works
test({comments: "hi", eat: 5}); // doesn't works

Es wurde gut außerhalb des Funktionskörpers eingegeben, aber um im Funktionskörper data.commentsrichtig zu tippen , sollten Sie eine Verengung hinzufügen.