2024年最全【值得收藏】面试会用到的十个常用的数组方法JS实现(一)(1),web页面渲染过程

结尾

学习html5、css、javascript这些基础知识,学习的渠道很多,就不多说了,例如,一些其他的优秀博客。但是本人觉得看书也很必要,可以节省很多时间,常见的javascript的书,例如:javascript的高级程序设计,是每位前端工程师必不可少的一本书,边看边用,了解js的一些基本知识,基本上很全面了,如果有时间可以读一些,js性能相关的书籍,以及设计者模式,在实践中都会用的到。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

html5

1.3 实现

const _chunk = function (array, size = 1) {

const length = array == null ? 0 : array.length;

if (!length || size < 1) return [];

const len = Math.ceil(length / size);

const result = new Array(len);

let index = -1;

while (++index < len) {

const start = size * index;

result[index] = array.slice(start, size + start)

}

return result;

}

1.4 测试

const arr = [‘a’, ‘b’, ‘c’, ‘d’]

_chunk(arr, 2);

// => [[‘a’, ‘b’], [‘c’, ‘d’]]

_chunk(arr, 3);

// => [[‘a’, ‘b’, ‘c’], [‘d’]]

二、concat


创建一个新数组,将array与任何数组值连接在一起。

2.1 参数

  • array (Array): 被连接的数组。

  • values: 连接的值。

2.2 返回值

  • (Array): 返回连接后的新数组。

2.3 实现

const _concat = function (array, …values) {

const result = […array];

values.forEach(val => {

if (Array.isArray(val)) {

result.push(…val);

} else {

result.push(val);

}

})

return result;

}

2.4 测试

var array = [1];

var other = _concat(array, 2, [3], [[4]]);

console.log(other);

// => [1, 2, 3, [4]]

console.log(array);

// => [1]

三、difference


创建一个具有唯一array值的数组,每个值不包含在其他给定的数组中。返回过滤的新数组

3.1 参数

  • array (Array): 被过滤的数组。。

  • [values] (…Array): 排除的值。

3.2 返回值

  • (Array): 返回一个过滤值后的新数组。

3.3 实现

const _difference = (array, diff = []) => {

if (!diff.length || !array.length) return […array];

return array.filter((val) => !diff.includes(val));

};

3.4 测试

_difference([3, 2, 1], [4, 2]);

// => [3, 1]

四、fill


使用 value 值来填充(替换) array,从start位置开始, 到end位置结束(但不包含end位置)。

注意: 这个方法会改变 array

4.1 参数

  • array (Array): 要填充改变的数组。

  • value (*): 填充给 array 的值。

  • [start=0] (number): 开始位置(默认0)。

  • [end=array.length] (number):结束位置(默认array.length)。

4.2 返回值

  • (Array): 返回 array。

4.3 实现

const _fill = (array = [], value, start = 0, end = array.length) => {

const { length } = array;

// 空数组

if (!length) return array;

// 边界

const ends = end > length ? length : end;

if (start > end) return array;

for (let i = start; i < ends; i++) {

array[i] = value;

}

return array;

};

4.4 测试

const array = [1, 2, 3];

_fill(array, “a”);

// => [‘a’, ‘a’, ‘a’]

_fill(Array(3), 2);

// => [2, 2, 2]

_fill([4, 6, 8, 10], “*”, 1, 3);

// => [4, ‘', '’, 10]

五、flattenDepth


按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。

5.1 参数

  • depth(Number): 指定要提取嵌套数组的结构深度,默认值为 1。

5.2 返回值

  • (Any): 返回通过测试(函数内判断)的数组的第一个元素的值。

5.3 实现

// 余光

Array.prototype._flattenDepth = function (depth = 1) {

// 获取调用者

let arr = this;

// 拍平层数校验

if (depth < 1) return arr;

return arr.reduce(

(prev, next, i, n) => [

…prev,

…(Array.isArray(next) ? next._flattenDepth(depth - 1) : [next]),

],

[]

);

};

5.4 测试

const res = [[1], [[2]]];

console.log(res.flat(1))

// => [1, [2]]

console.log(res.flat(2))

// => [1, 2]

六、join


将 array 中的所有元素转换为由 separator 分隔的字符串。

6.1 参数

  • array (Array): 要转换的数组。

  • [separator=’,’] (string): 分隔元素。

6.2 返回值

  • (string): 返回连接字符串。

6.3 实现

const _join = (array, separator = “,”) => {

return array.reduce((prev, next) => {

return prev ? prev + separator + next : prev + next;

}, “”);

};

6.4 测试

_join([‘a’, ‘b’, ‘c’], ‘~’);

// => ‘abc’

七、pop


删除数组的最后一个元素并返回删除的元素。

注意: 此方法改变数组的长度!

7.1 返回值

  • (any): 返回删除的元素。

7.2 实现

const _pop = function (array) {

const result = array[array.length - 1];

array.length - 1;

return result;

}

7.3 测试

const sites = [‘Google’, ‘Runoob’, ‘Taobao’, ‘Zhihu’, ‘Baidu’];

读者福利

========

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

由于篇幅过长,就不展示所有面试题了,想要完整面试题目的朋友(另有小编自己整理的2024大厂高频面试题及答案附赠)


ng?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NpbmF0XzM3OTAzNDY4,size_16,color_FFFFFF,t_70)


  • 23
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值