2024年前端最新2024前端面试之JavaScript手写题(三)(1),2024年最新面试相关书籍

最后前端到底应该怎么学才好?

如果你打算靠自己摸索自学,那么你首先要了解学习前端的基本大纲,这是你将要学习的主要内容,理解以及掌握好这些内容,便可以找到一份初级的前端开发工作。你还需要有一套完整的前端学习教程,作为初学者最好的方式就是看视频教程学习,初学者容易理解接受。

不要选择买书学习,这样的方式没有几个人能学会,基本都是看不下去书,也看不懂书。如果喜欢看书的学弟,可以买一些经典的书籍作为辅助即可,主要还是以看教程为主。每天抽出固定几个小时学习,做好长期学习的准备。学习编程并不是每天光看视频,你学习编程最重要的目的是为了编写软件产品,提供给大众使用,所以用手写出代码实现功能才是我们要做的事情。

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

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

} 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.查找字符串中出现最多的字符和个数


例: abbcccddddd -> 字符最多的是d,出现了5次

let str = “abcabcabcbbccccc”;

let num = 0;

let char = ‘’;

跳槽是每个人的职业生涯中都要经历的过程,不论你是搜索到的这篇文章还是无意中浏览到的这篇文章,希望你没有白白浪费停留在这里的时间,能给你接下来或者以后的笔试面试带来一些帮助。

也许是互联网未来10年中最好的一年。WINTER IS COMING。但是如果你不真正的自己去尝试尝试,你永远不知道市面上的行情如何。这次找工作下来,我自身感觉市场并没有那么可怕,也拿到了几个大厂的offer。在此进行一个总结,给自己,也希望能帮助到需要的同学。

面试准备

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

面试准备根据每个人掌握的知识不同,准备的时间也不一样。现在对于前端岗位,以前也许不是很重视算法这块,但是现在很多公司也都会考。建议大家平时有空的时候多刷刷leetcode。算法的准备时间比较长,是一个长期的过程。需要在掌握了大部分前端基础知识的情况下,再有针对性的去复习算法。面试的时候算法能做出来肯定加分,但做不出来也不会一票否决,面试官也会给你提供一些思路。

  • 16
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2024前端面试可能会涉及以下几个方面的内容: 1. HTML/CSS基础知识:包括HTML标签的使用、CSS选择器、盒模型、浮动、定位等基本概念和常见问。 2. JavaScript基础知识:包括数据类型、变量、运算符、流程控制语句、函数、作用域、闭包等基本概念和常见问。 3. 前端框架和库:例如React、Vue等,可能会涉及到它们的基本原理、生命周期、组件通信等方面的问。 4. 前端性能优化:包括减少HTTP请求、压缩和合并文件、使用CDN加速、懒加载、缓存等方面的知识。 5. 前端工程化:包括模块化开发、构建工具(如Webpack)、版本控制(如Git)、自动化测试等方面的知识。 6. 前端安全:包括XSS攻击、CSRF攻击、点击劫持等常见安全问及其防范措施。 7. 前端跨域问:包括同源策略、跨域请求的方法(如JSONP、CORS等)以及解决跨域问的方案。 8. 移动端开发:包括响应式设计、移动端适配、触摸事件、移动端性能优化等方面的知识。 9. Web标准和浏览器兼容性:包括HTML5、CSS3的新特性以及不同浏览器之间的差异和兼容性问。 10. 数据可视化:包括使用图表库(如Echarts、D3.js)进行数据可视化的基本原理和常见问。 以上只是一些可能涉及到的内容,具体的面试目还会根据面试官的要求和公司的需求而有所不同。在准备面试时,建议多做一些实际项目练习,加深对前端知识的理解和应用能力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值