知识点总结

套路

  1. 举例
  2. 将不会的变成会的
  3. 侃侃而谈

HTML面试

  1. (必考)你是如何理解HTML语义化的?
    • 举例:段落用p,边栏用aside,主要内容用main标签
    • 最开始是 PHP 后端写 HTML,不会 CSS,于是就用 table 来布局。table 使用展示表格的。严重违反了 HTML 语义化。后来有了专门的写 CSS 的前端,他们会使用 DIV + CSS 布局,主要是用 float 和绝对定位布局。稍微符合了 HTML 语义化。再后来,前端专业化,知道 HTML 的各个标签的用法,于是会使用恰当的标签来展示内容,而不是傻傻的全用 div,会尽量使用 h1、ul、p、main、header 等标签。语义化的好处是已读、有利于SEO等。
    • 对面试官请看我的博客 https://zhuanlan.zhihu.com/p/32570423
  2. meta viewport 是做什么的,怎么写?
    • 代码:<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    • 控制页面在移动端不要缩小显示。
    • 侃侃而谈:
      一开始,所有页面都是给PC准备的,乔布斯推出 iPhone 3GS,页面是不适应手机屏幕的,所以乔布斯的工程师想了一个办法,默认把手机模拟成 980px,页面缩小。后来,智能手机普及,这个功能在部分网站不需要了,所以我们就用 meta:vp 让手机不要缩小我的网页。
  3. canvas元素是干什么的?
    • 项目:小小画板
    • 记住一些基本的API,查看MDN入门手册。

CSS面试

  1. (必考)盒模型
    • 举例:
      conten-box:width == 内容区宽度
      border-box:width == 内容区宽度 + padding 宽度 + border 宽度
  2. css reset和normalize.css有什么区别?
    • 考英文:
      • reset重置,之前的样式我不要,a{color:red;},抛弃默认样式
      • normalize让所有的浏览器的标签都跟标准规定的默认样式一致,个浏览器上的标签默认样式基本统一。
  3. (必考)如何居中?
    • 平时总结:
      • 水平居中:
        • 内联:父元素上写text-align:center;
        • 块级:margin-left:auto;margin-right:auto;
      • 垂直居中:七种方式实现垂直居中
  4. 选择器优先级如何确定?
    1. 选择器越具体,优先级越高。#xxx大于.yyy
    2. 同样优先级,写在后面的覆盖前面的。
    3. color:red !important;优先级最高
  5. BFC是什么?
  6. 如何清除浮动?
    1. overflow:hidden;(不建议使用)
    2. .clearfix 清楚浮动写在父元素上
      .clearfix::after{
          content:'';
          display:block;
          clear:both;
      }
      .clearfix{
          zoom:1;/*兼容IE*/
      }
      

JS面试

  1. JS有哪些基本数据类型?
    string、number、boolean、null、undefined、symbol、object
    object包含了数组、函数、正则、日期等对象

  2. (必考)Promise怎么使用?

    1. then
      $.ajax(...).then(成功函数,失败函数)
    2. 链式then
      $.ajax(...).then(成功函数,失败函数).then(成功函数,失败函数)
    3. 如何自己生成Promise对象
      function xxx(){
          return new Promise(function(resolve,reject){
              setTimeout(()=>{
                  resolve()或者reject()
              },3000)
          })
      }
      xxx().then(...)
      
  3. (必考)AJAX手写一下?

    let xhr = new XMLHttpRequest();
    
    xhr.open('POST','/xxx')
    
    xhr.onreadystatechange = function(){
       if(xhr.readyState === 4){
           if(xhr.status === 200){
               console.log(xhr.response);
           } else {
               console.log(xhr.status)
           }
       }
    };
    
    xhr.onerror = function(){
       console.error(xhr.status)
    };
    
    xhr.send(null);
    
  4. (必考)闭包是什么?

    function(){
       var n = 0;
       return function(){
           n += 1
       }
    }
    
    let adder = ()
    adder()// n === 1
    adder()// n === 2
    console.log(n)// n is not defined
    

    参考:https://zhuanlan.zhihu.com/p/22486908

  5. (必考)这段代码里的this是什么?

    1. fn()里面的this就是window
    2. fn()是stric mode,this就是undefined
    3. a.b.c.fn()里面的this就是a.b.c
    4. new F()里面的this就是新生成的实例
    5. ()=>console.log(this)里面的this跟外面的this的值一模一样

    参考:https://zhuanlan.zhihu.com/p/23804247

  6. (必考)什么是立即执行函数?使用立即执行函数的目的是什么?

    ;(function(){
        var name
    }())
    
    ;(function(){
        var name
    })()
    
    ~function(){
        var name
    }()
    

    造出一个作用域,防止污染全局变量
    ES6:

    {
        let name
    }
    
  7. async/await 语法了解吗?目的是什么?

    function reutrnPromise(){
        reutrn new Promise( function(resolve,reject){
            setTimeout(()=>{
                resolve('fuck')
            },3000)
        })
    }
    returnPromise().then((result)=>{
        result === 'fuck'
    })
    
    var result = await reuturnPromise()
    result === 'fuck'
    

    主要目的:将异步代码写成同步代码。

  8. 如何实现深拷贝?

    1. JSON来深拷贝
      var a = {...}
      var b = JSON.parse(JSON.stringify(a))
      
      缺点:JSON不支持函数、引用、undefined、RegExp、Date......
    2. 递归拷贝
      function clone(object){
          var object2
          if(! (object instanceof Object) ){
              return object
          }else if(object instanceof Array){
              object2 = []
          }else if(object instanceof Function){
              object2 = eval(object.toString())
          }else if(object instanceof Object){
              object2 = {}
          }
          你也可以把 Array Function Object 都当做 Object 来看待,参考 https://juejin.im/post/587dab348d6d810058d87a0a
          for(let key in object){
          object2[key] = clone(object[key])
          }
          return object2
      }
      
  9. 如何实现数组去重?

    1. 计数排序的逻辑(只能正整数)
      var a = [4,2,5,6,3,4,5]
      var hashTab = {}
      for(let i=0; i<a.length;i++){
          if(a[i] in hashTab){
              // 什么也不做
          }else{
              hashTab[ a[i] ] = true
          }
      }
      //hashTab: {4: true, 2: true, 5: true, 6:true, 3: true}
      console.log(Object.keys(hashTab)) // ['4','2','5','6','3']
      
    2. Set去重
      Array.from(new Set(a))
    3. WeakMap 任意类型去重
  10. 如何用正则实现string.trim()?

    function trim(string){
        return string.replace(/^\s+|\s+$/g, '')
    }
    
  11. JS原型是什么?

    • 举例
      a. var a = [1,2,3]
      b. 只有0、1、2、length 4个key
      c. 为什么可以a.push(4),push是哪里来的?
      d. a.proto === Array.prototype
      e. push 就是沿着 a.prototype找到的,也就是Array.prototype.push
      f. Array.prototype还有很多方法,如join、pop、slice、splice
      g. Array.prototype 就是a的原型(proto)
      参考:https://zhuanlan.zhihu.com/p/23090041
  12. ES6中的class了解吗?

    • 把MND class章节看完
    • 记住一个例子
  13. JS如何实现继承

    • 原型链
      function Animal(){
          this.body = '肉体'
      }
      Animal.prototype.move = function(){
      
      }
      
      function Human(name){
          Animal.apply(this, arguments)
          this.name = name
      }
      // Human.prototype.__proto__ = Animal.prototype // 非法
      
      var f = function(){}
      f.prototype = Animal.prototype
      Human.prototype = new f()
      
      Human.prototype.useTools = function(){}
      
      var frank = new Human()
      
    • extends关键字
      class Animal{
          constructor(){
              this.body = '肉体'
      },
          move(){}
      }
      class Human extends Animal{
          constructor(name){
              super()
              this.name = name
          },
          useTools(){}
      }
      var frank = new Human()
      

DOM面试

  1. DOM事件模型是什么?
    1. 冒泡
    2. 捕获
    3. 如果这个元素是被点击的元素,那么捕获不一定在冒泡之前,顺序室友监听顺序决定的。
  2. 移动段的触摸事件了解吗?
    1. touchstart、touchmove、touchend、touchcancel
    2. 模拟swipe事件:记录两次touchmove的位置差,如果最后一次在前一次的右边,说明右滑了。
  3. 事件委托是什么?有什么好处?
    1. 假设父元素有4个儿子,我不监听4个儿子,而是监听父元素,看触发事件的元素是哪个儿子,这就是事件委托。
    2. 可以监听还没有出生的儿子(动态生成的元素)。省监听器。
      function listen(element, eventType, selector, fn){
      element.addEventListener(eventType, e=>{
          if(e.target.matches(selector)){
              fn.call(el, e, el)
          }
      })
      }// 有 bug 但是可以应付面试官的事件委托
      function listen(element, eventType, selector, fn) {
      element.addEventListener(eventType, e => {
          let el = e.target
          while (!el.matches(selector)) {
              if (element === el) {
                  el = null
                  break
              }
              el = el.parentNode
          }
          el && fn.call(el, e, el)
      })
      return element
      } // 工资 12k+ 的前端写的事件委托
      listen(ul, 'click', 'li', ()=>{})
      
      ul>li*5>span
      

HTTP面试

  1. HTTP 状态码知道哪些?
  2. 301 和 302 的区别是什么?
    1. 301 永久重定向,浏览器会记住
    2. 302 临时重定向
  3. HTTP 缓存怎么做?
    1. Cache-Control: max-age=300
    2. http://cdn.com/1.js?v=1 避开缓存
  4. Cache-Control 和 Etag 的区别是什么?
  5. Cookie 是什么?Session 是什么?
    • Cookie
      • HTTP响应通过 Set-Cookie 设置 Cookie
      • 浏览器访问指定域名是必须带上 Cookie 作为 Request Header
      • Cookie 一般用来记录用户信息
    • Session
      • Session 是服务器端的内存(数据)
      • Session 一般通过在 Cookie 里记录 SessionID 实现
      • SessionID 一般是随机数
  6. LocalStorage 和 Cookie 的区别是什么?
    • Cookie 会随请求被发到服务器上,而 LocalStorage 不会
    • Cookie 大小一般4k以下,LocalStorage 一般5Mb 左右
  7. (必考)GET 和 POST 的区别是什么?
    1. 参数。GET 的参数放在 url 的查询参数里,POST 的参数(数据)放在请求消息体里。
    2. 安全(扯淡)。GET 没有 POST 安全(都不安全)
    3. GET 的参数(url查询参数)有长度限制,一般是 1024 个字符。POST 的参数(数据)没有长度限制(扯淡,4~10Mb 限制)
    4. 包。GET 请求只需要发一个包,POST 请求需要发两个以上包(因为 POST 有消息体)(扯淡,GET 也可以用消息体)
      5.GET 用来读数据,POST 用来写数据,POST 不幂等(幂等的意思就是不管发多少次请求,结果都一样。)
  8. (必考)怎么跨域?JSONP 是什么?CORS 是什么?postMessage 是什么?
    1. JSONP
      2.CORS
      3.postMessage 看一下 MDN

vue面试

  1. (必考)Vue 有哪些生命周期钩子函数?
  2. (必考)Vue 如何实现组件通信?
    1. 父子通信(使用 Prop 传递数据、使用 v-on 绑定自定义事件)
    2. 爷孙通信(通过两对父子通信,爷爸之间父子通信,爸儿之间父子通信)
    3. 兄弟通信(new Vue() 作为 eventBus)
  3. Vuex 的作用是什么?
  4. VueRouter 路由是什么?
    • 看文档、博客
  5. Vue 的双向绑定是如何实现的?有什么缺点?
  6. Computed 计算属性的用法?跟 Methods 的区别。

算法面试

  1. 排序算法(背诵冒泡排序、选择排序、计数排序、快速排序、插入排序、归并排序)
  2. 二分查找法
  3. 翻转二叉树
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • 响应式布局的理解 响应式开发目的是一套代码可以在多种终端运行,适应不同屏幕的大小,其原理是运用媒体查询,在不同屏幕...
    懒猫_6500阅读 782评论 0 0
  • 本文转发自github, 原文地址 <a name='js'>JavaScript</a> 介绍js的基本数据类型...
    XDUZ阅读 1,037评论 1 11
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,028评论 0 2
  • 结合网上和个人总结,仅供参考。 1、HTML&CSS: 1、DOM结构 —— 两个节点之间可能存在哪些关系以及如何...
    FredericaJ阅读 3,928评论 3 7
  • HTML 对html5的理解,web语义话,SEO 页面加载过程 新增API,本地存储,Canvas CSS 经典...
    linwalker阅读 644评论 0 3