首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Web前端面试敲重点知识,14个TypeScript核心基础面试题和答案

2、TypeScript 中的原始类型有哪些 ? 3、说说数组在 TypeScript 中是如何工作的 ? 4、什么是 any 类型,何时使用 ? 5、什么是void,什么时候使用void类型 ?...6、TypeScript 中声明变量有哪些不同的关键字? 7、如何书写带有类型注释的函数 ? 8、如何在 TypeScript 中创建对象 ? 9、如何在 TypeScript 中指定可选属性 ?...image.png 8、如何在 TypeScript 中创建对象 ? 对象是类似字典的keys和values的集合,key 必须是唯一的。...它们类似于数组,有时也称为关联数组 但是,数组使用数字来索引值,而对象允许使用任何其他类型作为键 image.png 9、如何在 TypeScript 中指定可选属性 ? 通过添加 ?...对象类型可以具有零个或多个可选属性,在属性名称之后 image.png 10、说说枚举在 TypeScript 中是如何工作的 ?

11.5K10

JavaScript 权威指南第七版(GPT 重译)(二)

在 ES6 及更高版本中,函数表达式可以使用紧凑的新“箭头函数”语法。有关函数定义的完整详细信息请参见第八章。 4.4 属性访问表达式 属性访问表达式 评估为对象属性或数组元素的值。...属性访问的第二种风格在第一个表达式(对象或数组)后跟另一个方括号中的表达式。这第二个表达式指定所需属性的名称或所需数组元素的索引。...如果该表达式是一个属性访问表达式,则调用被称为方法调用。在方法调用中,作为属性访问主题的对象或数组在执行函数体时成为this关键字的值。.... = 运算符期望其左侧操作数是一个 lvalue:一个变量或对象属性(或数组元素)。它期望其右侧操作数是任何类型的任意值。赋值表达式的值是右侧操作数的值。...Map 是一个有趣的情况,因为 Map 对象的迭代器不会迭代 Map 键或 Map 值,而是键/值对。在每次迭代中,迭代器返回一个数组,其第一个元素是键,第二个元素是相应的值。

53210
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    3小时Scala入门

    以及 Unit(表示无值与C语言void等同,用作无返回值的方法的返回类型), Null(AnyRef的子类,null是它的唯一对象), Nothing(所有类型的子类,它没有对象), Any(所有其他类的超类...注意当使用第(3)种方法scalac把代码编译时,脚本中必须要定义object单例对象。并且在object对象中实现main方法作为程序入口。 ?...类的定义中可以用private声明为私有属性和私有方法,只允许在类的作用域访问,不允许在类的外部访问。 可以用protected声明为受保护的属性和方法,只允许在类作用域及其子类作用域中访问。...其余属性和方法默认为公有属性和公有方法,可以在类的作用域外访问。 此外还可以在private或protected后面用方括号加上作用域保护,表示方括号中的类和对象不受访问限制。...实践中我们一般用apply方法来构造对象,而无需用new声明一个对象,从而相当于一个语法糖。 unapply方法是apply方法的逆方法,我们一般用它来从对象中反推得到其构造参数。

    3.5K20

    分享 30 道 TypeScript 相关面的面试题

    这可以减少错误,提高代码可读性,并通过增强的工具(例如自动完成和代码导航)提供更高效的开发体验。 02、TypeScript 中的any类型和unknown类型有何不同?...答案:可区分联合(也称为标记联合)是一种结合了联合类型、文字类型和类型保护的模式。 当一个对象可以有多个形状但共享一个公共属性(通常是文字类型)时,可以使用它们,该属性可用于缩小其确切形状。...另一方面, === 是一个严格的相等运算符,它检查值和类型,使其在类型敏感的上下文中更安全、更可预测。 15、如何在 TypeScript 中声明只读数组,以及为什么要使用它?...是一个逻辑运算符,当其左侧操作数为空或未定义时返回其右侧操作数,否则返回其左侧操作数。这在您想要回退到默认值的情况下非常有用。 22、什么是映射类型,以及如何在 TypeScript 中使用它们?...答案:映射类型允许通过转换属性在现有类型的基础上创建新类型。它们遵循一种模式,您可以在其中迭代对象类型的属性并生成新类型。

    1K30

    3小时Scala入门

    以及 Unit(表示无值与C语言void等同,用作无返回值的方法的返回类型), Null(AnyRef的子类,null是它的唯一对象), Nothing(所有类型的子类,它没有对象), Any(所有其他类的超类...注意当使用第(3)种方法scalac把代码编译时,脚本中必须要定义object单例对象。并且在object对象中实现main方法作为程序入口。 ?...类的定义中可以用private声明为私有属性和私有方法,只允许在类的作用域访问,不允许在类的外部访问。 可以用protected声明为受保护的属性和方法,只允许在类作用域及其子类作用域中访问。...其余属性和方法默认为公有属性和公有方法,可以在类的作用域外访问。 此外还可以在private或protected后面用方括号加上作用域保护,表示方括号中的类和对象不受访问限制。...实践中我们一般用apply方法来构造对象,而无需用new声明一个对象,从而相当于一个语法糖。 unapply方法是apply方法的逆方法,我们一般用它来从对象中反推得到其构造参数。

    1.6K30

    3小时Scala入门

    以及 Unit(表示无值与C语言void等同,用作无返回值的方法的返回类型), Null(AnyRef的子类,null是它的唯一对象), Nothing(所有类型的子类,它没有对象), Any(所有其他类的超类...注意当使用第(3)种方法scalac把代码编译时,脚本中必须要定义object单例对象。并且在object对象中实现main方法作为程序入口。 ?...类的定义中可以用private声明为私有属性和私有方法,只允许在类的作用域访问,不允许在类的外部访问。 可以用protected声明为受保护的属性和方法,只允许在类作用域及其子类作用域中访问。...其余属性和方法默认为公有属性和公有方法,可以在类的作用域外访问。 此外还可以在private或protected后面用方括号加上作用域保护,表示方括号中的类和对象不受访问限制。...实践中我们一般用apply方法来构造对象,而无需用new声明一个对象,从而相当于一个语法糖。 unapply方法是apply方法的逆方法,我们一般用它来从对象中反推得到其构造参数。

    1.6K30

    HarmonyOS开发学习(1)–目录认识与基本开发

    abilities 是一个数组,存放当前模块中所有的ability元能力的配置信息,其中可以有多个ability。 对于abilities中每一个ability的属性项,其描述信息如下表2。...基本语法 Harmony使用的ArkTS语言,其作为TS的超集,兼容TypeScript的语法,因此基本语法也与此相同: 基本数据类型: TypeScript支持一些基础的数据类型,如布尔型、数组、字符串等...,而for..of则迭代的是对象的值。...,ArkTS就提供了forEach组件: ForEach( arr: any[], // 用于迭代的数组 itemGenerator: (item: any, index?...100 : 200) 内置枚举类型 除此之外,ArkTS中还提供了内置枚举类型,如Color,FontWeight等,例如设置fontColor改变字体颜色为红色,并私有fontWeight为加粗。

    32610

    MVEL 2.x语法指南

    :当一个对象中的字段的作用域是public时,MVEL仍然倾向于通过get方法来访问其属性。...List的访问 List可以像访问数组一样访问,如: user[5] 这等价与java中的代码: user.get(5); (2)....Map的访问 Map的访问和访问数组也非常相似,不同的是,在访问Map时索引值可以是任意对象,如: user["foobar"] 这等价与java中的代码: user.get("foobar"); 当Map...字符串作数组 为了能使用属性的索引(迭代也是如此),所有的字符串都可以看成是一个数组,在MVEL中你可以用下面的方式来获取一个字符串变量的第一个字符: foo = "My String"; foo[0]...Foreach MVEL的强大特性之一就是其Foreach操作符,在功能和语法上,他都类似于java1.5中的for each操作符,它接收用冒号隔开的两个参数,第一个是当前元素的一个域变量,而第二个是要迭代的集合或数组

    2.6K20

    14万字 | 400多道JavaScript 面试题及详细答案(建议收藏)

    您可以使用 size 属性轻松获取 Map 的大小,而 Object 中的属性数量必须手动确定。 Map 是可迭代的,因此可以直接迭代,而迭代 Object 需要以某种方式获取其键并对其进行迭代。...迭代器:它是通过调用[Symbol.iterator]()可迭代对象返回的对象。这个迭代器对象将每个迭代的元素包装在一个对象中,并通过next()方法一一返回。...逗号运算符用于从左到右评估其每个操作数并返回最后一个操作数的值。这与数组、对象和函数参数和参数中的逗号用法完全不同。...for…of 语句创建一个循环迭代可迭代对象或元素,例如内置字符串、数组、类数组对象(如参数或 NodeList)、TypedArray、Map、Set 和用户定义的可迭代对象。...下面是 javascript 中内置的可迭代对象列表, 1.数组和类型数组 2.字符串:迭代每个字符或 Unicode 代码点 3.Maps:迭代其键值对 4.集合:迭代它们的元素 5.参数:函数中类似数组的特殊变量

    12.7K20

    TypeScript基础常用知识点总结

    ]: any; length: number; callee: Function; } any 在数组中的应用 一个比较常见的做法是,用 any 表示数组中允许出现任意类型: let...shift() 删除并返回数组的第一个元素。 slice() 选取数组的的一部分,并返回一个新数组。 some() 检测数组元素中是否有元素符合指定条件。 sort() 对数组的元素进行排序。...length属性 上例中,第二行的 myFavoriteNumber 被推断成了 string,访问它的 length 属性不会报错。...创建 Map对象并对其进行操作 TypeScript 使用 Map 类型和 new 关键字来创建 Map: //创建 Map对象 let myMap = new Map(); // 设置 Map 对象用...需要注意的是,一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它的类型的子集 接口的只读属性 有时候我们希望对象中的一些字段只能在创建的时候被赋值,那么可以用 readonly 定义只读属性:

    4.9K30

    【TypeScript 演化史 — 第八章】字面量类型扩展 和 无类型导入

    现在来看看非扩展字面量类型,如名所示,它们不会自动地扩展。...其他类可以包含 mixin 并访问它的方法和属性。这样,mixin 提供了一种基于组合行为的代码重用形式。 混合类指一个extends(扩展)了类型参数类型的表达式的类声明或表达式....[]) => T; type Constructor 是构造签名的别名,该签名描述了可以构造通用类型T的对象的类型,并且其构造函数接受任意数量的任何类型的参数。...// 也可以从 Timestamped 类中访问属性 console.log(user.name); console.log(user.timestamp); TypeScript 编译器知道我们在这里创建并使用了一个...在咱们的例子中,它初始化 tag 属性。 混合构造函数类型指仅有单个构造函数签名,且该签名仅有一个类型为 any[] 的变长参数,返回值为对象类型.

    4.6K10

    2024年3月份最新大厂运维面试题集锦(运维15-20k)

    它们用于创建具有特定特性的类,例如注册子类或修改类属性。 45. Python中的深拷贝与浅拷贝区别是什么? 浅拷贝创建一个新对象,但不递归地复制对象中的内部引用对象。...生成器是一种特殊类型的迭代器,使用yield语句返回数据。它们允许延迟操作的执行,适用于处理大数据集或复杂计算,因为它们不需要一次性加载所有数据到内存中。 48. 如何在Python中实现多态?...解释Python中的闭包。 闭包是一个函数,它记住了其外部作用域中被引用的变量,即使在其外部作用域不再存在时仍然可以访问这些变量。 50. Python中的迭代器和可迭代对象有什么区别?...解释Shell脚本中的数组和如何使用它们。 答案: Shell脚本支持一维数组。可以使用括号()声明数组,使用空格分隔元素。访问数组元素时,使用${array_name[index]}语法。...在脚本中检查并使用可用的命令和工具的版本。 使用条件语句处理不同环境中可能的差异。 72. 解释什么是子Shell以及如何在Shell脚本中创建它。

    3K10

    100 个常见的 PHP 面试题

    13) PHP中如何比较两个对象? 在PHP中,我们可以使用运算符==来比较两个对象是否为同一个类的实例,并且拥有相同的属性和属性值。...imagetypes()给出当前版本的GD-PHP支持的图像格式和类型。 19)获取图片属性(size, width, 和 height)的函数是什么?...“13” 和 12 可以在 PHP 中进行比较,因为它将所有内容都强制转换为整数类型。 54) 如何在PHP中强制转换类型?...59) 通过::访问类意味着什么? ::用于访问不需要对象初始化的静态方法。 60) 在 PHP 中,对象是按值传递还是按引用传递? 对象按值传递。...在每次迭代中,expr2 都会被评估。 如果评估结果是 TRUE, 循环继续, 并执行 for 中的语句。 如果评估结果是 FALSE, 循环结束。expr3 在每次迭代结束时进行测试。

    21K50

    吐血总结!50道Python面试题集锦(附答案)「建议收藏」

    Python没有访问说明(如C ++的public,private)。 在Python中,函数是第一类对象。它们可以分配给变量。类也是第一类对象 编写Python代码很快,但运行比较慢。...Q6、如何在Python中管理内存? python中的内存管理由Python私有堆空间管理。所有Python对象和数据结构都位于私有堆中。程序员无权访问此私有堆。python解释器负责处理这个问题。...然后转到高级系统设置并添加新变量并将其命名为PYTHON_NAME并粘贴复制的路径。 查找路径变量,选择其值并选择“编辑”。...Q19、Python中的self是什么? self是类的实例或对象。在Python中,self包含在第一个参数中。但是,Java中的情况并非如此,它是可选的。它有助于区分具有局部变量的类的方法和属性。...举例如下: 代码输出为: Q23、什么是python迭代器? 迭代器是可以遍历或迭代的对象。 Q24、如何在Python中生成随机数? random模块是用于生成随机数的标准模块。

    10.6K10

    python面试题目及答案(数据库常见面试题及答案)

    Python没有访问说明(如C ++的public,private)。 在Python中,函数是第一类对象。它们可以分配给变量。类也是第一类对象 编写Python代码很快,但运行比较慢。...Q6、如何在Python中管理内存? python中的内存管理由Python私有堆空间管理。所有Python对象和数据结构都位于私有堆中。程序员无权访问此私有堆。python解释器负责处理这个问题。...然后转到高级系统设置并添加新变量并将其命名为PYTHON_NAME并粘贴复制的路径。 查找路径变量,选择其值并选择“编辑”。...Q19、Python中的self是什么? self是类的实例或对象。在Python中,self包含在第一个参数中。但是,Java中的情况并非如此,它是可选的。它有助于区分具有局部变量的类的方法和属性。...举例如下: 代码输出为: Q23、什么是python迭代器? 迭代器是可以遍历或迭代的对象。 Q24、如何在Python中生成随机数? random模块是用于生成随机数的标准模块。

    11.3K20

    JS与ES6高级编程学习笔记(五)——ECMAScript6 代码组织

    这里使用数组初始了一个新的Set对象,也可以是实现了iterable 接口的其他数据结构,当然如果不指定此参数或其值为null,则新的Set为空。...(2)、Map对象的遍历 keys()方法:获取迭代(Iterator)对象,含每个元素的key的数组。 values()方法:获取迭代(Iterator)对象,含每个元素的value的数组。...在我们的开发过程中,如果我们想要让垃圾回收器回收某一对象,就将对象的引用直接设置为 null var a = {}; // {} 可访问,a 是其引用 a = null; // 引用设置为 null /...使用继承不仅可以扩展自定的类,也可以扩展系统中内置的类型,如:Boolean、Number、String、Array、Date、Function、RegExp、Error、Object等。...推荐实现步骤 步骤1:创建模块与页面,按要求定义好三个类并export,并实现其继承关系,测试效果。 步骤2:学会HTML5中使用Canvas绘画的基本技巧后,重写draw方法。

    1.7K20

    python面试题--1

    5)如何在Python中内存管理? Python内存由Python私有堆空间管理。所有Python对象和数据结构都位于私有堆中。程序员无权访问此私有堆,解释器负责处理此私有堆。...创建后可以对其进行修改。 元组是不可变的。元组一旦创建,就不能对其进行更改。 列表表示的是顺序。它们是有序序列,通常是同一类型的对象。...16)什么是Python中的迭代器? 在Python中,迭代器用于迭代一组元素,如列表之类的容器。 17)什么是Python中的单元测试? Python中的单元测试框架称为unittest。...从序列类型(如列表,元组,字符串等)中选择一系列项目的机制称为切片。 19)Python中的生成器是什么? 实现迭代器的方法称为生成器。这是一个正常的函数,除了它在函数中产生表达式。...Flask脚本工作的常用方法是: 应用程序的导入路径 或者是Python文件的路径 39)解释如何在Flask中访问会话? 会话基本上允许您记住从一个请求到另一个请求的信息。

    6010

    吐血总结!100个Python面试问题集锦

    Python没有访问说明(如C ++的public,private)。 在Python中,函数是第一类对象。它们可以分配给变量。类也是第一类对象 编写Python代码很快,但运行比较慢。...Q6、如何在Python中管理内存? python中的内存管理由Python私有堆空间管理。所有Python对象和数据结构都位于私有堆中。程序员无权访问此私有堆。python解释器负责处理这个问题。...然后转到高级系统设置并添加新变量并将其命名为PYTHON_NAME并粘贴复制的路径。 查找路径变量,选择其值并选择“编辑”。...Q19、Python中的self是什么? self是类的实例或对象。在Python中,self包含在第一个参数中。但是,Java中的情况并非如此,它是可选的。它有助于区分具有局部变量的类的方法和属性。...迭代器是可以遍历或迭代的对象。 Q24、如何在Python中生成随机数? random模块是用于生成随机数的标准模块。

    9.9K20

    53 道 Python 面试题,帮你成为大数据工程师

    一旦创建了元组,就不能对其进行更改 · 列表有顺序。它们是有序序列,通常是相同类型的对象。即:按创建日期排序的所有用户名,[" Seth"," Ema"," Eli"] · 元组具有结构。...如果您对这个问题进行了搜索并阅读了前几页,请准备好深入了解语义。您最好仅了解其工作原理。 不变的对象(如字符串,数字和元组)是按值调用的。...请注意如何在列表上调用reverse()并对其进行突变。它不会返回变异列表本身。...注意:Python的标准库有一个数组对象,但在这里我专门指的是常用的Numpy数组。 列表存在于python的标准库中。数组由Numpy定义。 列表可以在每个索引处填充不同类型的数据。...数组需要齐次元素。 列表上的算术从列表中添加或删除元素。每个线性代数的数组函数的算术运算。 阵列还使用更少的内存,并具有更多的功能。 我写了另一篇有关数组的文章。 20.如何连接两个数组?

    10.5K41

    深入学习下 TypeScript 中的泛型

    在今天的内容中,我们将尝试 TypeScript 泛型的真实示例,并探索它们如何在函数、类型、类和接口中使用。...但由于数据类型未知,这段代码将无法访问对象的属性。 如果您不打算将特定类型添加到泛型函数的每次调用中,则可以将默认类型添加到泛型类型参数中。...这意味着 TypeScript 会将数据识别为具有字符串类型的键和任意类型的值的对象,从而允许您访问其属性。 类型参数约束 在某些情况下,泛型类型参数需要只允许将某些形状传递给泛型。...stringifyObjectKeyValues 使用 reduce 数组方法迭代原始键数组,将值字符串化并将它们添加到新数组中。...这将创建一个名为 K 的新类型,它绑定到当前属性的名称。这可用于使用语法 T[K] 访问原始类型中此属性的类型。在这种情况下,您将属性的类型设置为布尔值。

    39K30
    领券