JS面试题汇总(六),rxjava原理面试

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

参考答案:

1. Array. map()

此方法是将数组中的每个元素调用一个提供的函数,结果作为一个新的数组返回,并没有改变原来的数组

let arr = [1, 2, 3, 4, 5];

let newArr = arr.map(x => x * 2);

//arr= [1, 2, 3, 4, 5] 原数组保持不变

//newArr = [2, 4, 6, 8, 10] 返回新数组

2. Array. forEach()

此方法是将数组中的每个元素执行传进提供的函数,没有返回值,直接改变原数组,注意和 map 方法区分

let arr = [1, 2, 3, 4, 5];

num.forEach(x => x * 2);

// arr = [2, 4, 6, 8, 10] 数组改变,注意和map区分

3. Array. filter()

此方法是将所有元素进行判断,将满足条件的元素作为一个新的数组返回

let arr = [1, 2, 3, 4, 5]

const isBigEnough => value => value >= 3

let newArr = arr.filter(isBigEnough)

//newNum = [3, 4, 5] 满足条件的元素返回为一个新的数组

4. Array. every()

此方法是将所有元素进行判断返回一个布尔值,如果所有元素都满足判断条件,则返回 true,否则为 false:

let arr = [1, 2, 3, 4, 5]

const isLessThan4 => value => value < 4

const isLessThan6 => value => value < 6

arr.every(isLessThan4) //false

arr.every(isLessThan6) //true

5. Array. some()

此方法是将所有元素进行判断返回一个布尔值,如果存在元素都满足判断条件,则返回 true,若所有元素都不满足判断条件,则返回 false:

let arr = [1, 2, 3, 4, 5]

const isLessThan4 => value => value < 4

const isLessThan6 => value => value > 6

arr.some(isLessThan4) //true

arr.some(isLessThan6) //false

6. Array. reduce()

此方法是所有元素调用返回函数,返回值为最后结果, 传入的值必须是函数类型:

let arr = [1, 2, 3, 4, 5];

const add = (a, b) => a + b;

let sum = arr.reduce(add);

//sum = 15 相当于累加的效果

与之相对应的还有一个 Array. reduceRight() 方法,区别是这个是从右向左操作的

7. Array. push()

此方法是在数组的后面添加新加元素,此方法改变了数组的长度:

let arr = [1, 2, 3, 4];

arr.push(5);

console.log(arr); //[1, 2, 3, 4, 5]

console.log(arr.length); //5

8. Array. pop()

此方法在数组后面删除最后一个元素,并返回数组,此方法改变了数组的长度:

let arr = [1, 2, 3, 4, 5];

arr.pop();

console.log(arr); //[1, 2, 3, 4]

console.log(arr.length); //4

9. Array. shift()

此方法在数组后面删除第一个元素,并返回数组,此方法改变了数组的长度:

let arr = [1, 2, 3, 4, 5];

arr.shift();

console.log(arr); //[2, 3, 4, 5]

console.log(arr.length); //4

  1. Array.unshift()

此方法是将一个或多个元素添加到数组的开头,并返回新数组的长度:

let arr = [1, 2, 3, 4, 5];

arr.unshift(6, 7);

console.log(arr); //[6, 7, 2, 3, 4, 5]

console.log(arr.length); //7

  1. Array.isArray()

判断一个对象是不是数组,返回的是布尔值:

Array.isArray([1, 2, 3, 4]); // --> true

var obj = {

a: 1,

b: 2

};

Array.isArray(obj); // --> false

Array.isArray(new Array); // --> true

Array.isArray(“Array”); // --> false

  1. Array.concat()

此方法是一个可以将多个数组拼接成一个数组:

let arr1 = [1, 2, 3]

arr2 = [4, 5]

let arr = arr1.concat(arr2)

console.log(arr) //[1, 2, 3, 4, 5]

  1. Array.toString()

此方法将数组转化为字符串:

let arr = [1, 2, 3, 4, 5];

let str = arr.toString()

console.log(str) // 1,2,3,4,5

  1. Array.join()

此方法也是将数组转化为字符串:

let arr = [1, 2, 3, 4, 5];

let str1 = arr.toString()

let str2 = arr.toString(‘,’)

let str3 = arr.toString(‘##’)

console.log(str1) // 12345

console.log(str2) // 1,2,3,4,5

console.log(str3) // 1##2##3##4##5

通过例子可以看出和 toString 的区别,可以设置元素之间的间隔~

  1. Array.splice(开始位置, 删除的个数,元素)

万能方法,可以实现增删改:

let arr = [1, 2, 3, 4, 5];

let arr1 = arr.splice(2, 0 ‘haha’)

let arr2 = arr.splice(2, 3)

let arr1 = arr.splice(2, 1 ‘haha’)

console.log(arr1) //[1, 2, ‘haha’, 3, 4, 5]新增一个元素

console.log(arr2) //[1, 2] 删除三个元素

console.log(arr3) //[1, 2, ‘haha’, 4, 5] 替换一个元素

59. 字符串常用操作

参考答案:

  • charAt(index): 返回指定索引处的字符串

  • charCodeAt(index): 返回指定索引处的字符的 Unicode 的值

  • concat(str1, str2, … ): 连接多个字符串,返回连接后的字符串的副本

  • fromCharCode(): 将 Unicode 值转换成实际的字符串

  • indexOf(str): 返回 str 在父串中第一次出现的位置,若没有则返回-1

  • lastIndexOf(str): 返回 str 在父串中最后一次出现的位置,若没有则返回-1

  • match(regex): 搜索字符串,并返回正则表达式的所有匹配

ES6

  • 列举常用的ES6特性:

  • 箭头函数需要注意哪些地方?

  • let、const、var

  • 拓展:var方式定义的变量有什么样的bug?

  • Set数据结构

  • 拓展:数组去重的方法

  • 箭头函数this的指向。

  • 手写ES6 class继承。

微信小程序

  • 简单描述一下微信小程序的相关文件类型?

  • 你是怎么封装微信小程序的数据请求?

  • 有哪些参数传值的方法?

  • 你使用过哪些方法,来提高微信小程序的应用速度?

  • 小程序和原生App哪个好?

  • 简述微信小程序原理?

  • 分析微信小程序的优劣势

  • 怎么解决小程序的异步请求问题?

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
你是怎么封装微信小程序的数据请求?

  • 有哪些参数传值的方法?

  • 你使用过哪些方法,来提高微信小程序的应用速度?

  • 小程序和原生App哪个好?

  • 简述微信小程序原理?

  • 分析微信小程序的优劣势

  • 怎么解决小程序的异步请求问题?

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-EpNU8ooS-1713034295510)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值