美文网首页
前端·每日面经解析

前端·每日面经解析

作者: 某时橙 | 来源:发表于2021-08-29 09:07 被阅读0次

实习·字节·一面
截取自https://www.nowcoder.com/discuss/720364?source_id=discuss_experience_nctrack&channel=-1

预览:

*   自我介绍

*   介绍一个比较有亮点的项目中的难点

*   DNS

*   http和https,详细说一下https

*   0.1+0.2=?

*   ES6箭头函数和普通函数的区别,给代码说明this指向

*   var和let

*   几种异步方法,其区别

*   闭包

*   css中伪类和伪元素的区别

*   css实现垂直居中

*   代码:实现BFS

解析:

DNS

域名系统(英文:Domain Name System,缩写:DNS)是互联网的一项服务。它作为将域名和IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。
特点:

  1. 分布式、层次数据库
  • 根DNS服务器
  • 顶级域DNS服务器
  • 权威DNS服务器
  • 本地DNS服务器(DNS缓存相关)
    作用:如果只有一台DNS服务器,那么就要考虑由于通信量引起的带宽的问题,除此之外,若这台DNS服务器维护或者故障了,那么整个域名解析就瘫痪了,这称为单点故障,且如此庞大的数据库,维护也会异常艰难,分布式能解决这些问题。
  1. DNS缓存
    将过去的DNS记录缓存在本地数据库中,再需要时拦截DNS请求并返回本地中的记录。
    作用:和大多数缓存的意义一致,对用户改善时延效率,对服务器减少访问压力。

http和https,详细说一下https

http超文本传输协议,是一个基于请求与响应,无状态的,应用层的协议,常基于TCP/IP协议传输数据,互联网上应用最为广泛的一种网络协议,所有的WWW文件都必须遵守这个标准。设计HTTP的初衷是为了提供一种发布和接收HTML页面的方法,但现在其实能传任何类型的文件。
https=http+ssl,经由HTTP进行通信,利用SSL/TLS建立全信道,加密数据包。HTTPS使用的主要目的是提供对网站服务器的身份认证,同时保护交换数据的隐私与完整性。

  • 0.1+0.2=?
    反正不是0.3,这和JavaScript的底层浮点数存储机制有关。

  • ES6箭头函数和普通函数的区别,给代码说明this指向
    执行环境不同,箭头函数的执行环境是上下文,普通函数的执行环境是直接调用函数的对象
    上代码:

const obj = {
    num: 10,
   hello: function () {
    console.log(this);    // obj
    setTimeout(function () {
      console.log(this);    // window
    });
   }    
}
obj.hello();

var和let

变量提升:

console.log(a); //undefined
var a=1;

var a被提升到顶端,所以console.log能打印出a,不过此时还没被赋值,所以是undefined

console.log(a); //报错
let a=1;

暂时性死区:

if (true) {
  // TDZ开始
  tmp = 'abc'; // ReferenceError
  console.log(tmp); // ReferenceError

  let tmp; // TDZ结束
  console.log(tmp); // undefined

  tmp = 123;
  console.log(tmp); // 123
}

上面代码中,在let命令声明变量tmp之前,都属于变量tmp的“死区”,且这里的tmp只在块中有效,而var会直接赋值到全局作用域。

几种异步方法,其区别

  • callback
  • Promise
  • async
    本质上都是回调,但是表现形式不同,第一种是嵌套,第二种是链式,第三种和普通函数的写法几乎一样。

闭包

闭包是指那些能够访问自由变量的函数。
从理论角度:所有的函数。因为它们都在创建的时候就将上层上下文的数据保存起来了。哪怕是简单的全局变量也是如此,因为函数中访问全局变量就相当于是在访问自由变量,这个时候使用最外层的作用域。
从实践角度:以下函数才算是闭包:
即使创建它的上下文已经销毁,它仍然存在(比如,内部函数从父函数中返回)
在代码中引用了自由变量
上文出自下,写的挺好的:
https://github.com/mqyqingfeng/Blog/issues/9

css中伪类和伪元素的区别

伪类本质上是为了弥补常规CSS选择器的不足,以便获取到更多信息;
伪元素本质上是创建了一个有内容的虚拟容器;
CSS3中伪类和伪元素的语法不同;
可以同时使用多个伪类,而只能同时使用一个伪元素;

css实现垂直居中

代码:实现BFS

---html
<div class="container">
    <p></p>
</div>
<div class="container">
    <p></p>
</div>

---CSS
.container {
    overflow: hidden;
}
p {
    width: 100px;
    height: 100px;
    background: lightblue;
    margin: 100px;
}

这篇文BFS写的不错→https://zhuanlan.zhihu.com/p/25321647

相关文章

网友评论

      本文标题:前端·每日面经解析

      本文链接:https://www.haomeiwen.com/subject/yaubiltx.html