Rumah  >  Soal Jawab  >  teks badan

Kaedah keluaran untuk mentakrifkan fungsi jenis berdasarkan syarat dalam TypeScript

<p>Saya cuba mentakrifkan jenis output untuk fungsi saya dan saya mahu menggunakan bendera <kod>kepadaNumberIfNeeded</code> /code> jenis Tetapkan syarat antara, dengan mengandaikan bahawa jika <code>toNumberIfNeeded</code> fungsi ini akan mengembalikan jenis angka, jika tidak, ia akan mengembalikan jenis rentetan. Apa patut saya buat? </p> <pre class="brush:php;toolbar:false;">Pilihan antara muka { huruf besar?: boolean; filterSpecialChars?: boolean; toNumberIfNeeded?: boolean; } eksport const textTransformer = (teks: rentetan, pilihan?: Pilihan) => const { huruf besar, filterSpecialChars, toNumberIfNeeded} = pilihan ||. //Kod logik pemprosesan saya kembali keNumberIfNeeded ? parseInt(text) : text; }</pre> <p>Contoh yang dijangkakan:</p> <pre class="brush:php;toolbar:false;">textTransformer('hello'); // Kembalikan jenis rentetan textTransformer('123', { toNumberIfNeeded: true }); // Kembalikan jenis angka</pre>
P粉764836448P粉764836448456 hari yang lalu532

membalas semua(1)saya akan balas

  • P粉878542459

    P粉8785424592023-08-15 13:04:14

    Anda boleh refactor textTransformer() 方法,接受一个泛型参数,并使用条件类型来检查 toNumberIfNeeded 是否为 truefalse。我认为 TypeScript 无法自动缩小返回值的类型。你必须使用类型断言,否则返回类型将被推断为 string | number.

    interface Options {
      uppercase: boolean;
      filterSpecialChars: boolean;
      toNumberIfNeeded: boolean;
    }
    
    export const textTransformer = <T extends Options>(
      text: string,
      options?: T
    ): T["toNumberIfNeeded"] extends true ? number : string => {
      const {uppercase, filterSpecialChars, toNumberIfNeeded} =
        options || {};
      // 我的处理逻辑代码
    
      return (toNumberIfNeeded ? parseInt(text) : text) as ReturnType<
        typeof textTransformer
      >;
    };
    
    textTransformer("hello"); // 推断为 string
    textTransformer("123", {
      toNumberIfNeeded: true,
      uppercase: false,
      filterSpecialChars: false
    }); // 推断为 number

    balas
    0
  • Batalbalas