2024前端面试之JavaScript手写题(三)

return event || window.event;

},

// 阻止事件(主要是事件冒泡,因为 IE 不支持事件捕获)

stopPropagation: function(event) {

if (event.stopPropagation) {

event.stopPropagation();

} else {

event.cancelBubble = true;

}

},

// 取消事件的默认行为

preventDefault: function(event) {

if (event.preventDefault) {

event.preventDefault();

} else {

event.returnValue = false;

}

}

};

3.使用迭代的方式实现 flatten 函数。


var arr = [1, 2, 3, [4, 5], [6, [7, [8]]]]

/** * 使用递归的方式处理 * wrap 内保

存结果 ret * 返回一个递归函数 **/

function wrap() {

var ret = [];

return function flat(a) {

for (var item of

a) {

if (item.constructor === Array) {

ret.concat(flat(item))

} else {

ret.push(item)

}

}

return ret

}

}

console.log(wrap()(arr));

4.怎么实现一个sleep


sleep函数作用是让线程休眠,等到指定时间在重新唤起。

function sleep(delay) {

var start = (new Date()).getTime();

while ((new Date()).getTime() - start < delay) {

continue;

}

}

function test() {

console.log(‘111’);

sleep(2000);

console.log(‘222’);

}

test()

5.实现正则切分千分位(10000 => 10,000)


//无小数点

let num1 = ‘1321434322222’

num1.replace(/(\d)(?=(\d{3})+$)/g,‘$1,’)

//有小数点

let num2 = ‘342243242322.3432423’

num2.replace(/(\d)(?=(\d{3})+.)/g,‘$1,’)

复制代码

27.对象数组去重

输入:

[{a:1,b:2,c:3},{b:2,c:3,a:1},{d:2,c:2}]

输出:

[{a:1,b:2,c:3},{d:2,c:2}]

首先写一个函数把对象中的key排序,然后再转成字符串

遍历数组利用Set将转为字符串后的对象去重

function objSort(obj){

let newObj = {}

//遍历对象,并将key进行排序

Object.keys(obj).sort().map(key => {

newObj[key] = obj[key]

})

//将排序好的数组转成字符串

return JSON.stringify(newObj)

}

function unique(arr){

let set = new Set();

for(let i=0;i<arr.length;i++){

let str = objSort(arr[i])

set.add(str)

}

//将数组中的字符串转回对象

arr = […set].map(item => {

return JSON.parse(item)

})

return arr

}

6.解析 URL Params 为对象


let url = ‘http://www.domain.com/?user=anonymous&id=123&id=456&city=%E5%8C%97%E4%BA%AC&enabled’;

parseParam(url)

/* 结果

{ user: ‘anonymous’,

id: [ 123, 456 ], // 重复出现的 key 要组装成数组,能被转成数字的就转成数字类型

city: ‘北京’, // 中文需解码

enabled: true, // 未指定值得 key 约定为 true

}

*/

function parseParam(url) {

const paramsStr = /.+?(.+)$/.exec(url)[1]; // 将 ? 后面的字符串取出来

const paramsArr = paramsStr.split(‘&’); // 将字符串以 & 分割后存到数组中

let paramsObj = {};

// 将 params 存到对象中

paramsArr.forEach(param => {

if (/=/.test(param)) { // 处理有 value 的参数

let [key, val] = param.split(‘=’); // 分割 key 和 value

val = decodeURIComponent(val); // 解码

val = /^\d+$/.test(val) ? parseFloat(val) : val; // 判断是否转为数字

if (paramsObj.hasOwnProperty(key)) { // 如果对象有 key,则添加一个值

paramsObj[key] = [].concat(paramsObj[key], val);

} else { // 如果对象没有这个 key,创建 key 并设置值

paramsObj[key] = val;

}

} else { // 处理没有 value 的参数

paramsObj[param] = true;

}

})

return paramsObj;

}

7.模板引擎实现


let template = ‘我是{{name}},年龄{{age}},性别{{sex}}’;

let data = {

name: ‘姓名’,

age: 18

}

render(template, data); // 我是姓名,年龄18,性别undefined

复制代码

function render(template, data) {

const reg = /{{(\w+)}}/; // 模板字符串正则

if (reg.test(template)) { // 判断模板里是否有模板字符串

const name = reg.exec(template)[1]; // 查找当前模板里第一个模板字符串的字段

template = template.replace(reg, data[name]); // 将第一个模板字符串渲染

return render(template, data); // 递归的渲染并返回渲染后的结构

}

return template; // 如果模板没有模板字符串直接返回

}

8.转化为驼峰命名


var s1 = “get-element-by-id”

// 转化为 getElementById

复制代码

var f = function(s) {

return s.replace(/-\w/g, function(x) {

return x.slice(1).toUpperCase();

})

}

9.查找字符串中出现最多的字符和个数


ES6

  • 列举常用的ES6特性:

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

  • let、const、var

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

  • Set数据结构

  • 拓展:数组去重的方法

  • 箭头函数this的指向。

  • 手写ES6 class继承。

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

微信小程序

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

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

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

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

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

  • 简述微信小程序原理?

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

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

其他知识点面试

  • webpack的原理

  • webpack的loader和plugin的区别?

  • 怎么使用webpack对项目进行优化?

  • 防抖、节流

  • 浏览器的缓存机制

  • 描述一下二叉树, 并说明二叉树的几种遍历方式?

  • 项目类问题

  • 笔试编程题:

最后

技术栈比较搭,基本用过的东西都是一模一样的。快手终面喜欢问智力题,校招也是终面问智力题,大家要准备一下一些经典智力题。如果排列组合、概率论这些基础忘了,建议回去补一下。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值