2024年Web前端最新30+ 个工作中常用到的前端小知识,2024年最新《Web前端面试题及解析》分享

结尾

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

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

html5

8.解决ios audio无法自动播放、循环播放的问题


ios手机在使用audio或者video播放的时候,个别机型无法实现自动播放,可使用下面的代码hack

// 解决ios audio无法自动播放、循环播放的问题

var music = document.getElementById(‘video’);

var state = 0;

document.addEventListener(‘touchstart’, function(){

if(state==0){

music.play();

state=1;

}

}, false);

document.addEventListener(“WeixinJSBridgeReady”, function () {

music.play();

}, false);

//循环播放

music.onended = function () {

music.load();

music.play();

}

复制代码

9.隐藏页面元素


display-none: 元素不会占用空间,在页面中不显示,子元素也不会显示。

opacity-0: 元素透明度将为0,但元素仍然存在,绑定的事件仍旧有效仍可触发执行。

visibility-hidden:元素隐藏,但元素仍旧存在,占用空间,页面中无法触发该元素的事件。

10.前端工程化


一提到前端工程化很多人想到的都是webpack,这是不对的,webpack仅仅是前端工程化中的一环。在整个工程化过程中他帮我们解决了绝大多数的问题,但并没有解决所有问题。

前端工程化是通过工具提升效率,降低成本的一种手段。

近些年被广泛的关注和探讨,究其原因主要是因为现代化前端应用功能要求不断提高,业务逻辑日益复杂,作为当下互联网时代唯一不可或缺的技术,前端可以说是占据了整个开发行业的半壁江山。从传统的网站,到现在的H5,移动App,桌面应用,以及小程序。前端技术几乎是无所不能的全面覆盖。

在这些表象的背后呢,实际上是行业对开发人员的要求发生了天翻地覆的变化,以往前端写demo,套模板,调页面这种刀耕火种的方式已经完全不符合当下对开发效率的要求,前端工程化就是在这样一个背景下被提上台面,成为前端工程师必备的手段之一。

一般来说前端工程包含,项目初始化,项目开发,提交,构建,部署,测试,监控等流程。工程化就是以工程的角度来解决这些问题。比如项目初始化我们一般使用npm init, 创建页面模板使用plop,我们喜欢使用ES6+开发,但是需要通过babel编码成ES5,持续集成的时候我们使用git/ci cd,但是为了保持开发规范我们引入了ESLint,部署一般使用git/cd或者jenkins等等。

11.contenteditable


html中大部分标签都是不可以编辑的,但是添加了contenteditable属性之后,标签会变成可编辑状态。

复制代码

不过通过这个属性把标签变为可编辑状态后只有input事件,没有change事件。也不能像表单一样通过maxlength控制最大长度。我也忘记我在什么情况下用到过了,后面想起来再补吧。

12.calc


这是一个css属性,我一般称之为css表达式。可以计算css的值。最有趣的是他可以计算不同单位的差值。很好用的一个功能,缺点是不容易阅读。接盘侠没办法一眼看出20px是啥。

div {

width: calc(25% - 20px);

}

复制代码

13.Date对象


获取当前时间毫秒值

// 方式一

Date.now(); // 1606381881650

// 方式二

new Date() - 0; // 1606381881650

// 方式三

new Date().getTime() // 1606381881650

复制代码

创建Date对象的兼容性问题。

// window和安卓支持,ios和mac不支持

new Date(‘2020-11-26’);

// window和安卓支持,ios和mac支持

new Date(‘2020/11/26’);

复制代码

14.Proxy和Object.defineProperty区别


Proxy的意思是代理,我一般叫他拦截器,可以拦截对象上的一个操作。用法如下,通过new的方式创建对象,第一个参数是被拦截的对象,第二个参数是对象操作的描述。实例化后返回一个新的对象,当我们对这个新的对象进行操作时就会调用我们描述中对应的方法。

new Proxy(target, {

get(target, property) {

},

set(target, property) {

},

deleteProperty(target, property) {

}

})

复制代码

Proxy区别于Object.definedProperty

Object.defineProperty只能监听到属性的读写,而Proxy除读写外还可以监听属性的删除,方法的调用等。

通常情况下我们想要监视数组的变化,基本要依靠重写数组方法的方式实现,这也是Vue的实现方式,而Proxy可以直接监视数组的变化。

const list = [1, 2, 3];

const listproxy = new Proxy(list, {

set(target, property, value) {

target[property] = value;

return true; // 标识设置成功

}

});

list.push(4);

复制代码

Proxy是以非入侵的方式监管了对象的读写,而defineProperty需要按特定的方式定义对象的属性。

15.Reflect


他是ES2015新增的对象,纯静态对象也就是不能被实例画,只能通过静态方法的方式调用,和Math对象类似,只能类似Math.random()的方式调用。

Reflect内部封装了一系列对对象的底层操作,一共14个,其中1个被废弃,还剩下13个。

Reflect的静态方法和Proxy描述中的方法完全一致。也就是说Reflect成员方法就是Proxy处理对象的默认实现。

Proxy对象默认的方法就是调用了Reflect内部的处理逻辑,也就是如果我们调用get方法,那么在内部,Reflect就是将get原封不动的交给了Reflect,如下。

const proxy = new Proxy(obj, {

get(target, property) {

return Reflect.get(target, property);

}

})

复制代码

ReflectProxy没有绝对的关系,我们一般将他们两个放在一起讲是为了方便对二者的理解。

那为什么会有Reflect对象呢,其实他最大的用处就是提供了一套统一操作ObjectAPI

判断对象是否存在某一个属性,可以使用in操作符,但是不够优雅,还可以使用Reflect.has(obj, name); 删除一个属性可以使用delete,也可以使用Reflect.deleteProperty(obj, name); 获取所有属性名可以使用Object.keys, 也可以使用Reflect.ownKeys(obj); 我们更推荐使用ReflectAPI来操作对象,因为他才是未来。

16.解析get参数


通过replace方法获取url中的参数键值对,可以快速解析get参数。

const q = {};

location.search.replace(/([?&=]+)=([&]+)/g,(_,k,v)=>q[k]=v);

console.log(q);

复制代码

17.解析连接url


可以通过创建a标签,给a标签赋值href属性的方式,获取到协议pathnameoriginlocation对象上的属性。

// 创建a标签

const aEle = document.createElement(‘a’);

// 给a标签赋值href路径

aEle.href = ‘/test.html’;

// 访问aEle中的属性

aEle.protocol; // 获取协议

aEle.pathname; // 获取path

aEle.origin;

aEle.host;

aEle.search;

复制代码

18.localStorage


localStorageH5提供的永久存储空间,一般最大可存储5M数据,并且支持跨域隔离,他的出现极大提高了前端开发的可能性。localStorage的使用很多人都知道setItemgetItem,removeItem, 但他也可以直接以成员的方式操作。

localStorage.name = ‘yd’;

// 获取

localStorage.name; // yd

// 删除

delete localStorage.name;

// 清除全部

localStorage.clear();

// 遍历

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

const key = localStorage.key(i); // 获取本地存储的Key

localStorage[key]; // 获取本地存储的value

}

复制代码

localStorage满了的情况下仍继续存储并不会覆盖其他的值,而是直接报错(QuotaExceededError),并且当前存储的值也会被清空。浏览器支持每个域名下存储5M数据。

19.sessionStorage


sessionStoragelocalStorage的区别是,存在当前会话,很多人理解的是浏览器关闭,这是不对的,假设你在A页面存储了sessionStorage,新开选项卡将A页面的链接粘贴进去打开页面,sessionStorage也是不存在的。

所以sessionStorage存在的条件是页面间的跳转,A页面存储了sessionStorage,他要通过超链接或者location.href或者window.open来打开另一个同域页面才能访问sessionStorage

这一点在混合开发嵌套H5的开发模式中尤为重要,如果以新开webview的方式打开页面,很可能sessionStorage就没有了。

20.会话cookie


cookie在设置的时候如果不设置过期时间,就表示是个会话cookie,以前我以为关闭浏览器会话cookie就消失了,然而…喜提bug一个。

在多数情况下windows系统或者安卓系统确实是这样的。但是在macOS系统或者ios系统中,关闭浏览器并不会清除掉会话cookie,结束浏览器进程才行。

21.标签模板字符串


模板字符串支持在前面添加一个函数,第一个参数是一个有固定内容组成的数组,后面参数依次为传入的变量,函数返回值为模板字符串真正展示的值。不过这个功能个人感觉没啥用。

const tag = (params, …args) => {

return params[0] + args[0]; // 返回值为模板字符串的真实值。

}

const str = taghello ${'world'};

复制代码

22.字符串常用的几个方法


1. includes();

字符串中是否包含某个字符串,这个不说了,其实就是indexOf的替代方案,用起来更优雅,

2. startsWith();

字符串是否为某个字符串开始,我一般用它判断url是否有http

3. endsWith();

字符串是否为某个字符串结尾。判断后缀名的时候尤其有效。

4. repeat(number);

得到一个重复number次的字符串。额…我也不知道什么时候有用,一般我用它造测试数据。

5. ‘abc’.padEnd(5, ‘1’); // abc11;

用给定的字符串在尾部拼接到指定长度,第一个参数为长度,第二个参数为用于拼接的值。

6. ‘abc’.padStart(5, ‘1’); // 11abc;

用给定的字符串在首部拼接到指定长度第一个参数为长度,第二个参数为用于拼接的值。首部补0?

23.数组快速去重


应该很多人都知道这个,数组转换成Set, 再转换为数组,不过这种去重方式只能去除基本数据类型组成的数组。

const arr = [1, 2, 3, 4, 5, 6];

const arr2 = new Set(arr);

const arr3 = […arr2];

复制代码

24.Object.keys, values, entries


一般我们常用Object.keys,返回一个对象的键组成的数组,其实还有Object.values,返回对象值组成的数组,Object.entries将对象转成数组,每个元素是键值对组成的数组,可以使用此功能快速将对象转为Map

const obj = {name: ‘yd’, age: 18};

Object.keys(obj); // [‘name’, ‘age’];

Object.values(obj); // [‘yd’, 18];

const l = Object.entries(obj); // [[‘name’, ‘yd’], [‘age’: 18]];

const m = new Map(l);

复制代码

25.Object.getOwnPropertyDescriptors


获取对象的描述信息

Object.assign复制时,将对象的属性和方法当做普通属性来复制,并不会复制完整的描述信息,比如this

const p1 = {

a: ‘y’,

b: ‘d’,

get name() {

return ${this.a} ${this.b};

}

}

const p2 = Object.assign({}, p1);

p2.a = ‘z’;

p2.name; // y d; 发现并没有修改p2.a的值,是因为this仍旧指向p1

复制代码

使用Object.getOwnPropertyDescriptors获取完整描述信息

const description = Object.getOwnPropertyDescriptors(p1);

const p2 = Object.defineProperty({}, description);

p2.a = ‘z’;

p2.name; // z d

复制代码

26.BigInt


JavaScript可以处理的最大数字是253次方 - 1,这一点我们可以在Number.MAX_SAFE_INTEGER中看到。

consoel.log(Number.MAX_SAFE_INTEGER); //9007199254740991

复制代码

更大的数字则无法处理,ECMAScript2020引入BigInt数据类型来解决这个问题。通过把字母n放在末尾, 可以运算大数据。

BigInt可以使用算数运算符进行加、减、乘、除、余数及幂等运算。它可以由数字和十六进制或二进制字符串构造。此外它还支持ANDORNOTXOR之类的按位运算。唯一无效的位运算是零填充右移运算符。

const bigNum = 100000000000000000000000000000n;

console.log(bigNum * 2n); // 200000000000000000000000000000n

const bigInt = BigInt(1);

console.log(bigInt); // 1n;

const bigInt2 = BigInt(‘2222222222222222222’);

console.log(bigInt2); // 2222222222222222222n;

最后

一个好的心态和一个坚持的心很重要,很多冲着高薪的人想学习前端,但是能学到最后的没有几个,遇到困难就放弃了,这种人到处都是,就是因为有的东西难,所以他的回报才很大,我们评判一个前端开发者是什么水平,就是他解决问题的能力有多强。

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

分享一些前端面试题以及学习路线给大家

BigInt可以使用算数运算符进行加、减、乘、除、余数及幂等运算。它可以由数字和十六进制或二进制字符串构造。此外它还支持ANDORNOTXOR之类的按位运算。唯一无效的位运算是零填充右移运算符。

const bigNum = 100000000000000000000000000000n;

console.log(bigNum * 2n); // 200000000000000000000000000000n

const bigInt = BigInt(1);

console.log(bigInt); // 1n;

const bigInt2 = BigInt(‘2222222222222222222’);

console.log(bigInt2); // 2222222222222222222n;

最后

一个好的心态和一个坚持的心很重要,很多冲着高薪的人想学习前端,但是能学到最后的没有几个,遇到困难就放弃了,这种人到处都是,就是因为有的东西难,所以他的回报才很大,我们评判一个前端开发者是什么水平,就是他解决问题的能力有多强。

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

分享一些前端面试题以及学习路线给大家

[外链图片转存中…(img-rExv69fJ-1715417936542)]

[外链图片转存中…(img-WdTfWBNx-1715417936543)]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值