100天精通鸿蒙从入门到跳槽——第8天:TypeScript 知识储备:泛型

news/2024/7/21 9:37:29 标签: harmonyos, 跳槽, typescript, 华为, javascript, 安卓, 猫头虎

在这里插入图片描述


博主猫头虎的技术世界

🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能!

专栏链接

🔗 精选专栏

  • 《面试题大全》 — 面试准备的宝典!
  • 《IDEA开发秘籍》 — 提升你的IDEA技能!
  • 《100天精通Golang》 — Go语言学习之旅!
  • 《100天精通鸿蒙》 — 从Web/安卓到鸿蒙大师!

100天精通鸿蒙OS(基础篇)

  • 100天精通鸿蒙从入门到跳槽——第8天:TypeScript 知识储备:泛型
    • 摘要💫
    • 一、引言💥
    • 二、正文🎉
      • 1. 泛型定义🧧
      • 2. 泛型参数
      • 3. 泛型约束🪅
      • 4. 泛型类型保护🧸
      • 5. 泛型与接口结合🛼
    • 三、总结🎢
    • 四、参考资料🏛

100天精通鸿蒙从入门到跳槽——第8天:TypeScript 知识储备:泛型

在这里插入图片描述

摘要💫

TypeScript 中,泛型是一种通用的编程概念,它允许开发者编写可以处理不同类型的代码。泛型允许开发者编写更加灵活和可重用的代码,从而提高代码的可维护性和可扩展性。

本文将介绍 TypeScript 中的泛型类型,包括泛型的定义、泛型参数、泛型约束和泛型类型保护等。通过掌握这些知识,我们可以更好地使用 TypeScript 的功能,创建更加高效、安全和可靠的代码。

一、引言💥

随着 JavaScript 的广泛应用,开发人员越来越关注代码质量、可读性和可维护性。为了解决这些问题,TypeScript 应运而生。它为 JavaScript 添加了更多的类型信息,使得代码更加清晰、简洁和可维护。在 TypeScript 中,泛型是一种通用的编程概念,它允许开发者编写可以处理不同类型的代码。泛型允许开发者编写更加灵活和可重用的代码,从而提高代码的可维护性和可扩展性。

二、正文🎉

1. 泛型定义🧧

使用 <> 符号声明泛型。

typescript">function identity<T>(arg: T): T {
  return arg;
}

const result = identity<string>("World");
console.log(result); // 输出 "World"

2. 泛型参数

泛型参数用 TU 等字母表示,表示泛型类型。

typescript">function identity<T>(arg: T): T {
  return arg;
}

const result = identity<string>("World");
console.log(result); // 输出 "World"

3. 泛型约束🪅

泛型参数可以添加类型约束,以便限制泛型类型。

typescript">function identity<T extends string>(arg: T): T {
  return arg;
}

const result = identity<string>("World");
console.log(result); // 输出 "World"

const error = identity<number>("World"); // 编译错误

4. 泛型类型保护🧸

泛型类型保护允许在运行时检查泛型参数的类型。

typescript">function identity<T>(arg: T): T {
  if (arg instanceof Array) {
    return arg.join(",");
  }
  return arg;
}

const result = identity<string>("World");
console.log(result); // 输出 "World"

const result2 = identity<string[]>("World,Hello");
console.log(result2); // 输出 "World,Hello"

5. 泛型与接口结合🛼

泛型可以与接口结合使用,以提供对象的结构定义。

typescript">interface GenericIdentityFn<T> {
  (arg: T): T;
}

function identity<T>(arg: T): T {
  return arg;
}

const myIdentity: GenericIdentityFn<string> = identity;
const result = myIdentity("World");
console.log(result); // 输出 "World"

三、总结🎢

通过本文,我们了解了 TypeScript 中泛型类型的基本概念,包括泛型的定义、泛型参数、泛型约束和泛型类型保护等。掌握这些知识,我们可以更好地使用 TypeScript 的功能,创建更加高效、安全和可靠的代码。

四、参考资料🏛

TypeScript 官方文档:https://www.typescriptlang.org/docs/handbook/2/generics.html

在这里插入图片描述

👉 更多信息:对《100天精通鸿蒙》专栏感兴趣吗?别忘了点击文末名片或者下方链接加入我们的学习群。我是猫头虎博主,期待与您的交流! 🦉💬
领域矩阵

🌐 猫头虎技术领域矩阵
深入探索各技术领域,发现知识的交汇点。了解更多,请访问:

🚀 技术栈推荐
JS, TS,ArkTS 等前端技术

💡 联系与版权声明

📩 联系方式

  • 微信: Libin9iOak
  • 公众号: 猫头虎技术团队

⚠️ 版权声明
本文为原创文章,版权归作者所有。未经许可,禁止转载。更多内容请联系作者猫头虎@阿珊和她的猫

点击下方名片,加入猫头虎技术社群矩阵。与我们一起在《100天精通鸿蒙》的旅程中,探索HarmonyOS的奥秘,共同成长。



http://www.niftyadmin.cn/n/5335664.html

相关文章

[AutoSar]BSW_OS 05 Autosar OS_Alarms

目录 关键词平台说明一、Timer1.1 配置 关键词 嵌入式、C语言、autosar、OS、BSW 平台说明 项目ValueOSautosar OSautosar厂商vector &#xff0c;芯片厂商TI 英飞凌编程语言C&#xff0c;C编译器HighTec (GCC) >>>>>回到总目录<<<<<< 一…

爬虫入门,爬取豆瓣top250电影信息

import requests import csv import parsel import time f open(豆瓣top250.csv,modea,encodingutf-8,newline) csv_writer csv.writer(f) csv_writer.writerow([电影名,导演,主演,年份,国家,类型,简介,评分,评分人数]) for page in range(0,250,25):time.sleep(2)page_new …

unzip解压大文件失败提示End-of-central-directory signature not found

unzip解压大文件(>5G)报错 unzip file.zip End-of-central-directory signature not found. Either this file is not a zipfile, or it constitutes one disk of a multi-part archive. In the latter case the central directory and zipfile comment will be found o…

Redis高级系列-缓存双写一致性

Redis高级系列-缓存双写一致性 文章目录 Redis高级系列-缓存双写一致性1. 什么叫做缓存双写一致性&#xff1f;2. 缓存双写一致性有那些解决方案&#xff1f;2.1 Cache Aside Pattern(旁路缓存模式)延迟双删重试删除binlog订阅异步删除 2.2 Read Through/Write Through(读写穿透…

Ubuntu系统Git的安装配置及使用笔记(更新中)

Ubuntu下Git的下载及配置 (1)、下载git 打开终端命令窗口,输入&#xff1a;sudo apt-get install git 提示&#xff1a;sudo命令是用来以其他身份来执行命令&#xff0c;预设的身份为root,使用sudo时必须先输入密码 (2)、可以使用命令git --version查看git的版本号 (3)、设置…

【温故而知新】HTML5 应用程序缓存

文章目录 一、HTML5二、应用程序缓存三、浏览器支持四、案例代码五、更新缓存六、热门文章 一、HTML5 HTML5是HTML的最新版本&#xff0c;它引入了许多新的元素和功能&#xff0c;以适应现代网页开发的需求。以下是HTML5的一些主要特点&#xff1a; 新增语义元素&#xff1a;…

【RabbitMQ】RabbitMQ安装与使用详解以及Spring集成

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《RabbitMQ实战》。&#x1f3af;&#x1f3af; &am…

【Python 千题 —— 基础篇】姓名与性别

题目描述 题目描述 姓名与学号。班级中有 Tom、Alan、Bob、Candy、Sandy 五个人,他们的性别分别是男、男、男、女、女;请将他们的姓名与性别关联成字典,转换成字符串并输出。 输入描述 无 输出描述 输出字典转换成的字符串。 示例 示例 ① 输出: {Tom: 男, Alan:…