12 道腾讯前端面试真题及答案整理

本文整理了12道腾讯前端面试真题,涵盖了DNS Prefetching理解、HTTP请求参数、SEO策略、无刷新网站实现、SPA优化、Reflect对象、内部属性[[Class]]、堆栈原理、isNaN与Number.isNaN区别、布尔值转换场景、undefined与undeclared的区分以及JavaScript类型判断函数的封装。

1. 谈谈你对 dns-prefetch 的理解

DNS 是什么-- Domain Name System,域名系统,作为域名和IP地址相互映射的一个分布式数据库。

DNS Prefetching

浏览器根据自定义的规则,提前去解析后面可能用到的域名,来加速网站的访问速度。简单来讲就是提前解析域名,以免延迟。

使用方式

<link rel="dns-prefetch" href="//wq.test.com">

这个功能有个默认加载条件,所有的a标签的href都会自动去启用DNS Prefetching,也就是说,你网页的a标签href带的域名,是不需要在head里面加上link手动设置的。但a标签的默认启动在HTTPS不起作用。

这时要使用 meta里面http-equiv来强制启动功能。

<meta http-equiv="x-dns-prefetch-control" content="on">

总结一下

  1. DNS Prefetching是提前加载域名解析的,省去了解析时间。a标签的href是可以在chrome。firefox包括高版本的IE,但是在HTTPS下面不起作用,需要meta来强制开启功能

  2. 这是DNS的提前解析,并不是css,js之类的文件缓存,大家不要混淆了两个不同的概念。

  3. 如果直接做了js的重定向,或者在服务端做了重定向,没有在link里面手动设置,是不起作用的。

  4. 这个对于什么样的网站更有作用呢,类似taobao这种网站,你的网页引用了大量很多其他域名的资源,如果你的网站,基本所有的资源都在你本域名下,那么这个基本没有什么作用。因为DNS Chrome在访问你的网站就帮你缓存了。

拓展知识学习

  • web下的性能优化1(网络方向)

2. get/post请求传参长度有什么特点

我们经常说get请求参数的大小存在限制,而post请求的参数大小是无限制的。这是一个错误的说法,实际上HTTP 协议从未规定 GET/POST 的请求长度限制是多少。对get请求参数的限制是来源与浏览器或web服务器,浏览器或web服务器限制了url的长度。为了明确这个概念,我们必须再次强调下面几点:

  1. HTTP 协议 未规定 GET 和POST的长度限制

  2. GET的最大长度显示是因为 浏览器和 web服务器限制了 URI的长度

  3. 不同的浏览器和WEB服务器,限制的最大长度不一样

  4. 要支持IE,则最大长度为2083byte,若只支持Chrome,则最大长度 8182byte

3. 前端需要注意哪些 SEO

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值