简单整理了一下最近遇到的一些面试题-面试进行中

整理了一下最近面试遇到的题

CSS

1、div 水平垂直居中
  /* 定位 */
  position: absolute;
  top: 50%;
  left: 50;
  transform: translate(-50%, 50%);
  /* flex 布局 */
  display: flex;
  justify-content: center;
  align-items: center;
复制代码
2、css 盒模型
  • box-sizing: content-box; (标准模型)

width = content

  • box-sizing: border-box; (IE盒模型)

width = content + padding + border

3、inline 和 inline-block 的区别
  • inline 只能设置左右 margin、padding, 不能设置 width 和 height
  • inline-block 生成一个块级别框,但是框的行为跟内联元素一样
4、css 中使用过哪些图片替换方法,如何选择使用
5、link 跟 @import 的区别
  • link 是 HTML 提供的标签
  • link 引用的 css 会同时被加载,而 import 引用的 css 会等到页面全部被下载完后再加载
  • import 老版本浏览器不支持
  • DOM可控性区别:无法使用 dom 方法插入样式

JS

1、async/await 跟 promise 的区别
  • Promise 代码完全都是 Promise 的 API (then、catch 等)
  • async/await 是 Generator 函数的语法糖
2、闭包的特性合优缺点
  • 什么是闭包?

闭包就是能够读取其他函数内部变量的函数 (来源: blog.csdn.net/yingziziziz…)

  • 优点

读取函数内部的变量 让局部变量保存在内存中,实现变量数据共享

  • 缺点
  • 由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除
  • 闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。
  • 来源: www.jianshu.com/p/8376170fb…
3、原型、原型链,有什么特点

关于原型其实文章还是蛮多的,看着也有点迷糊 segmentfault.com/a/119000000…

4、如何判断对象类型

typeof、 instanceof 看 www.jianshu.com/p/5be700ee6…

5、宿主对象和原生对象的区别
  • 原生对象: Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError、Global
  • 宿主对象: 有宿主提供的对象,在浏览器中window对象以及其下边所有的子对象(如bom、dom等等),在node中是globla及其子对象,也包含自定义的类对象。【何为“宿主对象”? 在web中,ECMAScript中的“宿主”当然就是我们网页的运行环境,即“操作系统”和“浏览器”。所有非本地对象都是宿主对象(host object),即由 ECMAScript 实现的宿主环境提供的对象。】
6、call 和 apply 的区别
  • .call(this, arg1, arg2, arg3)
  • .apply(this, arguments)
7、什么是闭包
8、解释 js 的 同源策略, 如何实现跨域访问
  • 同源:

如果两个页面拥有 相同 的 协议(protocol),端口(如果指定),和 主机,那么这两个页面就属于同一个源(origin)。 (协议、域名、端口)

  • 跨域
  • jsonp
  • iframe
  • 跨域资源共享(CORS)
  • nginx 代理跨域
9、== 和 === 的区别

看: blog.csdn.net/chenchunlin…

10、数组方法 pop, push, unshift, shift
  • pop: 删除数组最后一个元素,返回删除的那个元素
  • push: 往数组结尾添加元素
  • shift: 删除数组第一个元素,返回该元素
  • unshift: 往数组前添加元素
11、事件委托是什么

事件委托就是利用冒泡的原理,把事件加到父元素或祖先元素上,触发执行效果。

优点: 提高性能,显著提高事件处理速度,减少内存占用

var btn6 = document.getElementById("btn6");
document.onclick = function(event){
  event = event || window.event;
  var target = event.target || event.srcElement;
  if(target == btn6){
    alert(btn5.value);
  }
}
复制代码
12、split()、join() 的区别
13、例举 3 种强制类型转换和 2 种隐式类型转换

VUE

1、vue 常见报错
2、父组件通过 props 给子组件传值,子组件能否修改该值,会有什么影响

做了个小测试,看: note.youdao.com/noteshare?i…

3、vue 双向数据绑定原理

juejin.im/entry/59239…

4、v-if 和 v-show 指令有什么相同和不同

v-if 直接从 dom 树上删除或重建元素节点, v-show 只是修改 display 的值 v-if 高消耗,不适合做频繁切换

5、 有什么作用

keep-alive 是 Vue 内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染

算法

假设你正在爬楼梯,需要 n 步你才能到达顶部,但每次你只能爬一步或者两步,你能有多少种不同的方法爬到楼顶?

其它

项目部署流程
服务器部署项目常见错误,一般根据什么来判断
git 不常用的命令
什么情况下会遇到跨域,怎么解决
webpack 的作用

看这篇吧 (什么是WebPack,为什么要使用它) www.jianshu.com/p/d745b94ae…


后面陆续补充

感谢预览,欢迎提意见、建议,谢谢!

猜你喜欢

转载自juejin.im/post/5c9669b7e51d4558255b5146