【前端面试字节ts的手写题】建议收藏!!!

编程入门 行业动态 更新时间:2024-10-21 12:01:24

【前端面试<a href=https://www.elefans.com/category/jswz/34/1769891.html style=字节ts的手写题】建议收藏!!!"/>

【前端面试字节ts的手写题】建议收藏!!!

文章目录

  • 前言
  • 请实现下面的 myMap 方法
  • 请实现下面的 treePath 方法
  • 请实现下面的 product 方法
  • 请实现下面的 myAll 方法
  • 请实现下面的 sum 方法
  • 请实现下面的 mergeArray 方法
  • 实现下面的 firstSingleChar 方法
  • 实现下面的 reverseWord 方法
  • 请补充 objToArray 函数
  • 使用ts实现一个判断入参是否是数组类型的方法?
  • 如何检查TypeScript中的null和undefined ?
  • TypeScript 中的 getter/setter 是什么?你如何使用它们?
  • 后言

前言

hello world欢迎来到前端的新世界


😜当前文章系列专栏:Typescript
🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错误,感谢大家指出)🌹
💖感谢大家支持!您的观看就是作者创作的动力

请实现下面的 myMap 方法

/*** @file 实现数组 map 方法*/function myMap<T, R>(arr: T[], callbackFn: (v: T) => R): R[] {// 补全此处代码,可以使用除数组 map 以外的其他任何函数throw new Error('功能待实现');
}
// 测试
console.log(myMap([1, 2, 3], v => v * 2)) // [2, 4, 6]export default {};

请实现下面的 treePath 方法

/*** @file 二叉树所有路径*/type Tree = {value: number;left?: Tree;right?: Tree;
}
const tree: Tree = {value: 1,left: {value: 2,right: { value: 5 }},right: { value: 3 }
};
function treePath(root: Tree): string[] {// 补全此处代码throw new Error('功能待实现');
}
console.log(treePath(tree)) // [ '1->2->5', '1->3' ]export default {}

请实现下面的 product 方法

题目

/**@file 计算数组笛卡尔积 */
// 示例 product([1, 2], [3, 4]) // [[1, 3], [1, 4], [2, 3], [2, 4]]function product(xList: number[], yList: number[]): [number, number][] { // 补全内部实现 throw new Error('功能待实现'); }export default {}

实现

/*** @file 计算数组笛卡尔积*/// 示例
console.log(product([1, 2], [3, 4])); // [[1, 3], [1, 4], [2, 3], [2, 4]]function product(xList: number[], yList: number[]): [number, number][] {// 参考答案return xList.reduce((v, t) => {return v.concat(yList.map((item) => [t, item]));}, [] as [number, number][]);
}export default {};

请实现下面的 myAll 方法

/*** @file 实现 PromiseAll 方法*/import { sleep } from "./8.sleep";async function myAll<T extends unknown[] | []>(values: T): Promise<{ [P in keyof T]: Awaited<T[P]> }> {// 补全此处代码,使用 Promise.all 以外的语法完成throw new Error('功能待实现');
}// 一秒钟后返回结果 value
async function request(value: string) {await sleep(1000);return value;
}
async function main() {console.log('start');const res = await myAll([request('a'),request('b'),request('c'),])console.log(res); // 预期输出 start 一秒后输出 ['a', 'b', 'c']
}
main()export default {}

请实现下面的 sum 方法

/*** @file 假设加法是一个异步过程,如何计算多个数组之和?*/
function sleep(ms: number) {return new Promise(r => {setTimeout(() => {r(undefined)}, ms);})
}async function asyncAdd(a: number, b: number) {await sleep(1000);return a + b;
}function sum(arr: number[]): Promise<number> {// 补全这里代码,涉及 arr 中两数求和只能使用 asyncAdd,禁止使用加号throw new Error('功能待实现');
}console.time('a')
sum([1, 2, 3, 4, 5, 6, 7, 8]).then(v => {console.log(v) // 36console.timeEnd('a') // a: <耗时>})export default {}

请实现下面的 mergeArray 方法

/*** @file 合并两个有序数组*/function merge(arr: number[], arr2: number[]): number[] {// 补全此处代码throw new Error('功能待实现');
}// 参数数组从小到大排列
console.log(merge([1, 2, 3], [2, 5, 6])) // [ 1, 2, 2, 3, 5, 6 ]export default {}

实现下面的 firstSingleChar 方法

/*** @file 找出字符串中第一个只出现一次的字符*/function firstSingleChar(str: string) {// 补全此处代码throw new Error('功能待实现');
}// a 和 b 都出现了两次,只有 c 出现了一次,返回 c
console.log(firstSingleChar('abcba')) // c
// b c d 都出现了一次,返回第一个
console.log(firstSingleChar('aabcdee')) // b
// a 和 b 都出现了多次,没有只出现一次的元素,返回 undefined
console.log(firstSingleChar('aaaabbbb')) // undefinedexport default {}

实现下面的 reverseWord 方法

/*** @file 反转句子* * 同时满足以下条件:1、去除首尾空格,2、单词间隔中多个空格变成一个;* 注意console示例运行结果*/function reverseWord(str: string) {// 补全此处代码throw new Error('功能待实现');
}console.log(reverseWord('the sky is blue')); // blue is sky the
// 去除首尾空格
console.log(reverseWord("  hello world  ")); // world hello
// 单词间隔中多个空格变成一个
console.log(reverseWord("a good   example")); // example good aexport default {}

请补充 objToArray 函数

题目

/*** @file objToArray** 将对象按照要求转为数组* 注意console示例运行结果*/
type Obj = Record<string, string>;
interface FormatItem {key: string;op: string;value: string;
}function objToArray(obj: Record<string, Obj>): FormatItem[] {// 补全此处代码throw new Error("功能待实现");
}console.log(objToArray({key1: {op1: "value1",},key2: {op2: "value2",},})
);
// result示例
// [
//     {key: 'key1', op: 'op1', value: 'value1'},
//     {key: 'key2', op: 'op2', value: 'value2'}
// ]export default {};

实现

/*** @file objToArray** 将对象按照要求转为数组* 注意console示例运行结果*/
type Obj = Record<string, string>;
interface FormatItem {key: string;op: string;value: string;
}function objToArray(obj: Record<string, Obj>): FormatItem[] {return Object.keys(obj).reduce((value: Array<FormatItem>, key: string) => {var op: string = Object.keys(obj[key])[0];value.push({ key: key, op: op, value: obj[key][op] });return value;}, []);
}console.log(objToArray({key1: {op1: "value1",},key2: {op2: "value2",},})
);
// result示例
// [
//     {key: 'key1', op: 'op1', value: 'value1'},
//     {key: 'key2', op: 'op2', value: 'value2'}
// ]export default {};

使用ts实现一个判断入参是否是数组类型的方法?

function isArray(x: unknown): boolean {if (Array.isArray(x)) {return true;}return false;
}

unknown 用于变量类型不确定,但肯定可以确定的情形下,比如下面这个示例中,入参总归会有个值,根据这个值的类型进行不同的处理,这里使用 unknown 替代 any 则会更加类型安全。

如何检查TypeScript中的null和undefined ?

通过使用一个缓冲检查,我们可以检查空和未定义:

if (x == null) {  
}  

如果我们使用严格的检查,它将总是对设置为null的值为真,而对未定义的变量不为真。

例子

var a: number;  
var b: number = null;  
function check(x, name) {  if (x == null) {  console.log(name + ' == null');  }  if (x === null) {  console.log(name + ' === null');  }  if (typeof x === 'undefined') {  console.log(name + ' is undefined');  }  
}  
check(a, 'a');  
check(b, 'b');  

输出

"a == null"  
"a is undefined"  
"b == null"  
"b === null"  

TypeScript 中的 getter/setter 是什么?你如何使用它们?

Getter 和 setter 是特殊类型的方法,可帮助你根据程序的需要委派对私有变量的不同级别的访问。

Getters 允许你引用一个值但不能编辑它。Setter 允许你更改变量的值,但不能查看其当前值。这些对于实现封装是必不可少的。

  • 例如,新雇主可能能够了解get公司的员工人数,但无权set了解员工人数。
const fullNameMaxLength = 10;
class Employee {private _fullName: string = "";get fullName(): string {return this._fullName;}set fullName(newName: string) {if (newName && newName.length > fullNameMaxLength) {throw new Error("fullName has a max length of " + fullNameMaxLength);}this._fullName = newName;}
}
let employee = new Employee();
employee.fullName = "Bob Smith";
if (employee.fullName) {console.log(employee.fullName);
}

后言

创作不易,要是本文章对广大读者有那么一点点帮助 不妨三连支持一下,您的鼓励就是博主创作的动力

更多推荐

【前端面试字节ts的手写题】建议收藏!!!

本文发布于:2023-11-14 14:30:17,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1587742.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:字节   建议   收藏   ts

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!