• 20个实用的 TypeScript 单行代码汇总


    在今天的文章中,我将与你分享20有用的 TypeScript 单行代码,这些单行代码可以快速的帮助我们提升开发效率,希望对你有用。

    那我们现在开始吧。

    01、等待特定的时间量(以毫秒为单位)

    const wait = (ms: number): Promise<void> => new Promise((resolve) => setTimeout(resolve, ms));
    
    • 1

    await wait(1000); // waiting 1 second
    02、检查日期是否为工作日

    const isWeekday = (d: Date): boolean => d.getDay() % 6 !== ;
    
    isWeekday(new Date(2022, 2, 21)); // -> true
    isWeekday(new Date(2021, 2, 20)); // -> false
    
    • 1
    • 2
    • 3
    • 4

    03、反转字符串

    const reverse = (s: string): string => s.split('').reverse().join('');
    
    reverse('elon musk'); // -> 'ksum nole'
    
    • 1
    • 2
    • 3

    04、检查一个数字是否为偶数。

    const isEven = (n: number): boolean => n % 2 === ;
    
    isEven(2); // -> true
    isEven(3); // -> false
    
    • 1
    • 2
    • 3
    • 4

    05、大写字符串

    const capitalize = (s: string): string => s.charAt().toUpperCase() + s.slice(1);
    
    capitalize('lorem ipsum'); // -> Lorem ipsum
    
    • 1
    • 2
    • 3

    06、检查数组是否为空

    const isArrayEmpty = (arr: unknown[]): boolean => Array.isArray(arr) && !arr.length;
    
    isArrayEmpty([]); // -> true
    isArrayEmpty([1, 2, 3]); // -> false
    
    • 1
    • 2
    • 3
    • 4

    07、检查对象/数组是否为空

    const isObjectEmpty = (obj: unknown): boolean => obj && Object.keys(obj).length === ;
    
    isObjectEmpty({}); // -> true
    isObjectEmpty({ foo: 'bar' }); // -> false
    
    • 1
    • 2
    • 3
    • 4

    08、随机生成整数

    基于两个参数生成一个随机整数。

    const randomInteger = (min: number, max: number): number => Math.floor(Math.random() * (max - min + 1)) + min;
    
    randomInteger(1, 10); // -> 7
    
    • 1
    • 2
    • 3

    09、生成随机布尔值

    const randomBoolean = (): boolean => Math.random() >= 0.5;
    
    randomBoolean(); // -> true
    
    • 1
    • 2
    • 3

    10、切换布尔值

    切换布尔值,变假为真,变真为假。

    const toggleBoolean = (val: boolean): boolean => (val = !val);
    
    toggleBoolean(true); // -> false
    
    • 1
    • 2
    • 3

    11、转换

    将字符串转换为带“-”的连字字符串。

    const slugify = (str: string): string => str.toLowerCase().replace(/\s+/g, '-').replace(/[^\w-]+/g, '');
    
    slugify('Hello World'); // -> hello-world
    
    • 1
    • 2
    • 3

    12、生成随数组组合

    随机生成一组任何类型的数组。

    const shuffleArray = <T>(arr: T[]): T[] => arr.sort(() => Math.random() - 0.5);
    
    shuffleArray(<number[]>[1, 2, 3, 4, 5]); // -> [ 4, 5, 2, 1, 3 ]
    
    • 1
    • 2
    • 3

    13、将连字字符串转换为骆峰字符串

    const snakeToCamel = (s: string): string => s.toLowerCase().replace(/(_\w)/g, (w) => w.toUpperCase().substring(1));
    
    snakeToCamel('foo_bar'); // -> fooBar
    
    • 1
    • 2
    • 3

    14、随机整数

    根据当前时间生成一个随机整数。

    const randomInteger = (): number => new Date().getTime();
    
    randomInteger(); // -> 1646617367345
    
    • 1
    • 2
    • 3

    15、随机数字符串

    根据当前时间生成随机数字符串。

    const randomNumberString = (): string => new Date().getTime() + Math.random().toString(36).slice(2);
    
    randomNumberString(); // -> 1646617484381wml196a8iso
    
    • 1
    • 2
    • 3

    16、将数字转换为字符/字母

    const numberToLetter = (value: number): string => String.fromCharCode(94 + value);
    
    numberToLetter(4); // -> b
    
    • 1
    • 2
    • 3

    17、生成随机的十六进制颜色

    const randomHexColor = (): string => `#${Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0')}`;
    
    randomHexColor(); // -> #dc7c40
    
    • 1
    • 2
    • 3

    18、删除字符串的尾部斜杠

    const removeTrailingSlash = (value: string): string => value && value.charAt(value.length - 1) === '/' ? value.slice(, -1) : value;
    
    removeTrailingSlash('foo-bar/'); // -> foo-bar
    
    • 1
    • 2
    • 3

    19、获取数组的随机项

    const randomItem = <T>(arr: T[]): T => arr[(Math.random() * arr.length) | ];
    
    randomItem(<number[]>[1, 2, 3, 4, 5]); // -> 4
    
    • 1
    • 2
    • 3

    20、将大写字符串转换为小写

    const decapitalize = (str: string): string => `${str.charAt(0).toLowerCase()}${str.slice(1)}`;
    
    decapitalize('Hello world'); // -> hello world
    
    • 1
    • 2
    • 3

    源码附件已经打包好上传到百度云了,大家自行下载即可~

    链接: https://pan.baidu.com/s/14G-bpVthImHD4eosZUNSFA?pwd=yu27
    提取码: yu27
    百度云链接不稳定,随时可能会失效,大家抓紧保存哈。

    如果百度云链接失效了的话,请留言告诉我,我看到后会及时更新~

    开源地址
    码云地址:
    http://github.crmeb.net/u/defu

    Github 地址:
    http://github.crmeb.net/u/defu

    来源 | https://blog.bitsrc.io/another-10-quick-typescript-one-liners-9f41713c158a

  • 相关阅读:
    1000+节点的cdh集群主服务迁移全过程
    如何找到适合自己的股票程序化交易接口模式?
    Linux系统LVM逻辑卷
    springboot使用mybatis动态表名添加和删除
    本地jar导入maven
    GTX312L比TSM12更具优势的智能门锁触摸芯片方案
    大模型Tuning分类
    解密Prompt系列23.大模型幻觉分类&归因&检测&缓解方案脑图全梳理
    不使用oh-my-zsh配置轻量级zsh环境
    奇舞周刊第 464 期:我被 pgx 及其背后的 Rust 美学征服
  • 原文地址:https://blog.csdn.net/qq_39221436/article/details/125552959