美文网首页前端秃头党
前端面试(知识积累)

前端面试(知识积累)

作者: flyinskybiu | 来源:发表于2021-08-18 16:55 被阅读0次
    最近试着提升自己的前端技术,发现其实从面试题去学习和吸收知识也是非常不错的选择!不仅能快速的抓住知识点,而且还能应对以后的面试。简直是一举两得(哈哈哈哈)。

    目前只从三元大神那里获取的面试内容(有兴趣可以看一下):
    阿里云前端实习生面试 | 三元博客
    =。= 目前还没更新完(哭唧唧)

    浏览器缓存机制

    一,浏览器缓存类型

    1. 强缓存:不会向服务器发送请求,直接从缓存中读取资源,在chrome控制台的network选项中可以看到该请求返回200的状态码,并且size显示from disk cache或from memory cache;
    2. 协商缓存:向服务器发送请求,服务器会根据这个请求的request header的一些参数来判断是否命中协商缓存,如果命中,测返回304状态码并带上新的response header通知浏览器从缓存中读取资源;

    两者的共同点是,都是从客户端缓存中读取资源;区别是强缓存不会发请求,协商缓存会发请求。


    二、缓存有关的header

    强缓存

    Expires:response header里的过期时间,浏览器再次加载资源时,如果在这个过期时间内,则命中强缓存。
    Cache-Control:当值设为max-age=300时,则代表在这个请求正确返回时间(浏览器也会记录下来)的5分钟内再次加载资源,就会命中强缓存。

    Expires和Cache-Control:max-age=*** 的作用是差不多的,区别就在于 Expires 是http1.0的产物,Cache-Control是http1.1的产物,两者同时存在的话,Cache-Control优先级高于Expires;在某些不支持HTTP1.1的环境下,Expires就会发挥用处。所以Expires其实是过时的产物,现阶段它的存在只是一种兼容性的写法

    (编辑补充:Expires和Cache-Control的区别还有一个:Expires是一个具体的服务器时间,这就导致一个问题,如果客户端时间和服务器时间相差较大,缓存命中与否就不是开发者所期望的。Cache-Control是一个时间段,控制就比较容易。)

    协商缓存

    ETag和If-None-Match:这两个要一起说。Etag是上一次加载资源时,服务器返回的response header,是对该资源的一种唯一标识,只要资源有变化,Etag就会重新生成。浏览器在下一次加载资源向服务器发送请求时,会将上一次返回的Etag值放到request header里的If-None-Match里,服务器接受到If-None-Match的值后,会拿来跟该资源文件的Etag值做比较,如果相同,则表示资源文件没有发生改变,命中协商缓存

    Last-Modified和If-Modified-Since:这两个也要一起说。Last-Modified是该资源文件最后一次更改时间,服务器会在response header里返回,同时浏览器会将这个值保存起来,在下一次发送请求时,放到request header里的If-Modified-Since里,服务器在接收到后也会做比对,如果相同则命中协商缓存。

    ETag和Last-Modified的作用和用法也是差不多,说一说他们的区别。
    首先在精确度上,Etag要优于Last-Modified。Last-Modified的时间单位是秒,如果某个文件在1秒内改变了多次,那么他们的Last-Modified其实并没有体现出来修改,但是Etag每次都会改变确保了精度;如果是负载均衡的服务器,各个服务器生成的Last-Modified也有可能不一致。

    第二在性能上,Etag要逊于Last-Modified,毕竟Last-Modified只需要记录时间,而Etag需要服务器通过算法来计算出一个hash值。
    第三在优先级上,服务器校验优先考虑Etag。


    三、浏览器缓存过程

    1. 浏览器第一次加载资源,服务器返回200,浏览器将资源文件从服务器上请求下载下来,并把response header及该请求的返回时间一并缓存;
    2. 下一次加载资源时,先比较当前时间和上一次返回200时的时间差,如果没有超过cache-control设置的max-age,则没有过期,命中强缓存,不发请求直接从本地缓存读取该文件(如果浏览器不支持HTTP1.1,则用expires判断是否过期);如果时间过期,则向服务器发送header带有If-None-Match和If-Modified-Since的请求;
    3. 服务器收到请求后,优先根据Etag的值判断被请求的文件有没有做修改,Etag值一致则没有修改,命中协商缓存,返回304;如果不一致则有改动,直接返回新的资源文件带上新的Etag值并返回200;
    4. 如果服务器收到的请求没有Etag值,则将If-Modified-Since和被请求文件的最后修改时间做比对,一致则命中协商缓存,返回304;不一致则返回新的last-modified和文件并返回200;

    三、用户行为对浏览器缓存的控制

    1. 地址栏访问,链接跳转是正常用户行为,将会触发浏览器缓存机制;
    2. F5刷新,浏览器会设置max-age=0,跳过强缓存判断,会进行协商缓存判断;
    3. ctrl+F5刷新,跳过强缓存和协商缓存,直接从服务器拉取资源。

    四、实际应用

    当在实际应用中时,对于所有可缓存资源,一般需要指定一个 Expires 或 Cache-Control max-age以及一个Last-Modified或ETag。这样既能控制强缓存,也能控制协商缓存。但是由于 Cache-Control 只支持 http 1.1,如果需要兼容老设备,还是需要 Expires,它既支持 http1.0 也支持 http 1.1。

    但是如果对于一个不是经常改变的静态资源来说,我们可以通过服务器来告诉浏览器是否需要重新请求,这样就避免了很多 304。

    比如我们可以通过在 url 后面加上 md5 参数或者将 md5 参数写成文件名的一部分来实现。

    当资源没有变动的时候直接使用缓存,不用发起请求,当资源发生变化时,其 url 就会发生变化。网址一经更改,系统就会强制浏览器重新抓取资源。

    https://www.cnblogs.com/vajoy/p/5341664.html

    cookie属性详解

    1. name: 字段为一个cookie的名称
    2. value: 字段为一个cookie的值
    3. domain: 字段为可以访问此cookie的域名
    4. path: 字段为可以访问此cookie的页面路径。 比如domain是abc.com,path是/test,那么只有/test路径下的页面可以读取此cookie。
    5. expires/Max-Age:字段为此cookie超时时间。若设置其值为一个时间,那么当到达此时间后,此cookie失效。不设置的话默认值是Session,意思是cookie会和session一起失效。当浏览器关闭(不是浏览器标签页,而是整个浏览器) 后,此cookie失效。
    6. Size :字段 此cookie大小
    7. http:字段 cookie的httponly属性。若此属性为true,则只有在http请求头中会带有此cookie的信息,而不能通过document.cookie来访问此cookie。
    8. secure 字段 设置是否只能通过https来传递此条cookie
    9. Session 意思是cookie会和session一起失效。当浏览器关闭(不是浏览器标签页,而是整个浏览器) 后,此cookie失效。

    箭头函数和普通函数的区别

    箭头函数不绑定this,会捕获其所在的上下文的this值,作为自己的this值
    var obj = {
      a: 10,
      b: () => {
        console.log(this.a); // undefined
        console.log(this); // Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, frames: Window, …}
      },
      c: function() {
        console.log(this.a); // 10
        console.log(this); // {a: 10, b: ƒ, c: ƒ}
      }
    }
    obj.b(); 
    obj.c();
    
    箭头函数不绑定arguments,取而代之用rest参数...解决
    
    function A(a){ console.log(arguments)}
    A(2,'sdas','asda')
    Arguments(3) [2, "sdas", "asda", callee: ƒ, Symbol(Symbol.iterator): ƒ]
    
    
    let B = (b)=>{
      console.log(arguments);
    }
    B(2,92,32,32);   // Uncaught ReferenceError: arguments is not defined
    
    
    let C = (...c) => {
      console.log(c);
    }
    C(3,82,32,11323);  // [3, 82, 32, 11323]
    
    箭头函数是匿名函数不能作为构造函数使用,不能使用new
    let a = () => { console.log(111)} 
    a()
    
    let fn = new a()
    VM325:1 Uncaught TypeError: a is not a constructor
        at <anonymous>:1:10
    
    箭头函数没有原型属性
    var a = ()=>{
      return 1;
    }
    
    function b(){
      return 2;
    }
    
    console.log(a.prototype);  // undefined
    console.log(b.prototype);   // {constructor: ƒ}
    
    
    箭头函数不能当做Generator函数,不能使用yield关键字
    // 普通函数的this指向调用他的对象
    // 箭头函数的this指向调用父级的对象,如果父级作用于还是箭头函数,就继续向上找,直到window
    
    

    (补充)箭头函数体内的this对象,就是 定义时所在的对象,而不是使用时所在的对象。而普通函数中this指向是可变的,普通函数的this指向调用它的那个对象

    持续更新...

    相关文章

      网友评论

        本文标题:前端面试(知识积累)

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