前端面试题整合

前端工作面试问题

本文包含了一些用于考查候选者的前端面试问题。不建议对单个候选者问及每个问题 (那需要好几个小时)。只要从列表里挑选一些,就能帮助你考查候选者是否具备所需要的技能。

备注: 这些问题中很多都是开放性的,可以引发有趣的讨论。这比直接的答案更能体现此人的能力。

目录

  1. 常见问题
  2. HTML 相关问题
  3. CSS 相关问题
  4. JS 相关问题
  5. 测试相关问题
  6. 效能相关问题
  7. 网络相关问题
  8. 代码相关问题
  9. 趣味问题
常见问题:
  • 你在昨天/本周学到了什么?

  • 编写代码的哪些方面能够使你兴奋或感兴趣?

  • 你最近遇到过什么技术挑战?你是如何解决的?

  • 在制作一个网页应用或网站的过程中,你是如何考虑其 UI、安全性、高性能、SEO、可维护性以及技术因素的?

  • 请谈谈你喜欢的开发环境。

  • 你最熟悉哪一套版本控制系统?

    git

    代码提交流程:
    git pull -> git checkout -b xxx -> git add . -> git commit -m “info” -> git push -> git merge -(?)> git checkout -b new xxx -> 解决冲突 -> git add . -> git commit -m “info” -> git push

  • 你能描述当你制作一个网页的工作流程吗?

  • 假若你有 5 个不同的样式文件 (stylesheets), 整合进网站的最好方式是?

  • 你能描述渐进增强 (progressive enhancement) 和优雅降级 (graceful degradation) 之间的不同吗?

  • 你如何对网站的文件和资源进行优化?

  • 浏览器同一时间可以从一个域名下载多少资源?

    • 有什么例外吗?
  • 请说出三种减少页面加载时间的方法。(加载时间指感知的时间或者实际加载时间)

  • 如果你参与到一个项目中,发现他们使用 Tab 来缩进代码,但是你喜欢空格,你会怎么做?

  • 请写一个简单的幻灯效果页面。

  • 如果今年你打算熟练掌握一项新技术,那会是什么?

  • 请谈谈你对网页标准和标准制定机构重要性的理解。

  • 什么是 FOUC (无样式内容闪烁)?你如何来避免 FOUC?

  • 请解释什么是 ARIA 和屏幕阅读器 (screenreaders),以及如何使网站实现无障碍访问 (accessible)。

  • 请解释 CSS 动画和 JavaScript 动画的优缺点。

  • 什么是跨域资源共享 (CORS)?它用于解决什么问题?

  • 对WEB标准以及W3C的理解与认识?

    标签要求小写、闭合、不乱嵌套、提高搜索机器人搜索几率、使用外联css与js、便于维护、结构分离。
HTML 相关问题:
  • 浏览器页面有哪三层构成,分别是什么,作用是什么?

    构成:结构层、表示层、行为层
    分别是:HTML、CSS、JavaScript
    作用:HTML实现页面结构,CSS完成页面的表现与风格,JavaScript实现功能与业务。

  • 谈一谈对HTML5的认识,以及为什么HTML4不再使用了

    HTML5是指以HTML、CSS、JS共同组成的技术组合,它能够减少网页对插件的依赖,比如说Flash和sliverlight,并且提供一些新的标签,还有一些语义化的标签,而HTML4的安全稳定性差,并且不适合在移动端使用

  • HTML5的优点与缺点?

    优点:

      1. 新增标签提高开发效率:header、footer、nav、section、datalist以及一些多媒体标签:audio、vedio、embed
      1. 新增input类型:
      1. 替代了flash和silverlight
      1. 多设备、跨平台
      1. 兼容多个浏览器
      1. 涉及到网站的抓取和索引的时候,对SEO(搜索引擎)友好

    缺点:

      1. 安全性不高: web storage 的内容容易被获取
      1. 完善性有欠缺:许多特性各浏览器的支持程度也不一样。
      1. 不兼容低版本IE
  • doctype(文档类型) 的作用是什么?

    它的目的是告诉浏览器(解析器)应该以什么样(html或xhtml)的文档类型定义(DTD)来解析文档。

  • 浏览器标准模式 (standards mode) 、几乎标准模式(almost standards mode)和怪异模式 (quirks mode) 之间的区别是什么?

    • 怪异模式是为了兼容老页面而设计的:

      • 盒子模型:在IE盒子模型中,height/width是由border+padding+width组成的;在w3c盒子模型下,height/width是指content的height/width

      • 图片元素的对齐方式:对于inline元素和table-cell元素,标准模式下vertical-align属性默认取值为baseline,在怪异模式下,table单元格中的图片的vertical-align属性默认取值为bottom,因此在图片底部会多出几像素的空间

      • 元素中的字体:CSS中,对于font的属性都是可以继承的,怪异模式下,对于table元素,字体的某些元素将不会从body等其他封装元素中继承得到,特别是font-size属性

      • 内联元素的尺寸:标准模式下, inline元素无法自定义大小,怪异模式下,定义这些元素的width,height属性可以影响这些元素显示的尺寸

      • 元素溢出的处理:标准模式下,overflow默认值visible,在怪异模式下,该溢出会被当做扩展box来对待,即元素的大小由其内容决定,溢出不会裁减,元素框自动调整,包含溢出内容

    • 近似标准模式是为了解决table中内联图片而设计的:如果一个块级元素除了空白文本(空格,tab等字符)外再无其它内容,则它的高度按0处理;如果有子元素,则它的高度不能比子元素大,无论它的font-size多大。 (标准模式下vertical-align属性默认取值为baseline,近似标准模式下,table单元格中的图片的vertical-align属性默认取值为bottom)

    • 标准模式就是浏览器按照Web标准来渲染页面

  • 浏览器的内核分别是什么?

      1. IE : trident
      1. Firefox : gecko
      1. Safrai : webkit
      1. Opera : Blink
      1. Chrome : Blink
  • HTML 和 XHTML 有什么区别?

    • XHTML 元素必须被正确地嵌套。

    • XHTML 元素必须被关闭。

    • 标签名必须用小写字母。

    • XHTML 文档必须拥有根元素。

  • 如果页面使用 ‘application/xhtml+xml’ 会有什么问题吗?
    (使用XHTML会有什么问题吗)

    • XHTML 元素必须被正确地嵌套。

    • XHTML 元素必须被关闭。

    • 标签名必须用小写字母。

    • XHTML 文档必须拥有根元素。

  • 如果网页内容需要支持多语言,你会怎么做?

    • 采用统一编码UTF-8方式编码

    • 根据使用不同语言的不同群体的文化更改页面结构;如书写方式等

    • 设定支持不同语言的数据库

    • 静态页面提供同一页面的多个语言版本

    • 动态页面通过变量控制赋值

  • 在设计和开发多语言网站时,有哪些问题你必须要考虑?

    • 采用统一编码UTF-8方式编码

    • 根据使用不同语言的不同群体的文化更改页面结构;如书写方式等

    • 设定支持不同语言的数据库

    • 静态页面提供同一页面的多个语言版本

    • 动态页面通过变量控制赋值

  • 什么是WebGL,它有什么优点?

    WebGL是一种3D绘图标准,它允许将JS和openGL结合,为Canvas提供硬件3D渲染。
    优点:
    1.通过JS完成3D渲染,无需浏览器插件
    2.方便实现数据可视化、3D物理模型
    3.承上启下,上接OpenGL,下接Three.js库

  • 使用 data- 属性的好处是什么?

    • 它赋予我们在所有 HTML 元素上嵌入自定义数据属性的能力
  • 如果把 HTML5 看作做一个开放平台,那它的构建模块有哪些?

    header、footer、nav、article、section

  • 请描述 cookiessessionStoragelocalStorage 的区别。

    • cookies : 存储空间小、有个数限制、会随请求上传服务器
    • localStorage : 存储空间大、本地永久保存、无个数限制
    • sessionStorage : 在独立的浏览器窗口存储,关闭则销毁、存储空间更大
  • link和@import的区别?

    link 是 XHTML 标签,除了加载 CSS 外,还可以定义 RSS 等其他事务; @import 属于 CSS 范畴,只能加载 CSS
    link 引用 CSS 时,在页面载入时同时加载; @import 需要页面网页完全载入以后加载。
    link 是 XHTML 标签,无兼容问题; @import 是在 CSS2.1 提出的,低版本的浏览器不支持。
    link 支持使用 Javascript 控制 DOM 去改变样式;而 @import 不支持

  • HTML全局属性(global attribute)有哪些?

    列举一些常见的全局属性:
    title、style、class
    accesskey :提供快捷键快速访问元素
    以下元素支持 accesskey 属性:<a>, <area>, <button>, <input>, <label>, <legend> 以及 <textarea>
    hidden: 表示一个元素是否与文档相关。样式上会导致元素不显示,但是不能用这个属性实现样式效果
    设置元素拖放类型: copy, move, link
    autocapitalize:控制用户的文本输入是否和如何自动大写

  • 说说超链接target属性的取值和作用?

    _blank :在新窗口中打开被链接文档。
    _parent :在父框架集中打开被链接文档。
    _self :默认。在相同的框架中打开被链接文档。
    _top :在整个窗口中打开被链接文档。

  • 如何实现浏览器内多个标签页之间的通信?

    1. cookies
    2. localStorage
    3. WebSocket
  • 实现不使用 border 画出1px高的线,在不同浏览器的标准模式与怪异模式下都能保持一致的效果?

    hr 要考虑不同浏览器的兼容性
    border在怪异模式中是height的一部分

    <div  style="width:100%;height:1px;background-color:black"></div>
    
  • HTML5标签的作用?(用途)

    1. 使Web页面的内容更加有序和规范
    2. 使搜索引擎更加容易按照HTML5规则识别出有效的内容
    3. 使Web页面更接近于一种数据字段和表
  • 简述一下src与href的区别?

    src用于替换当前元素, href 用于在当前文档和引用资源之间确立联系。
    src 解析到它的时候会中断其他资源的下载和处理,直到将该资源加载、编译、执行完毕
    href 并行下载资源并且不会停止对当前文档的处理

  • 请解释 <script><script async><script defer> 的区别。

  • 为什么通常推荐将 CSS <link> 放置在 <head></head> 之间,而将 JS <script> 放置在 </body> 之前?你知道有哪些例外吗?

  • 什么是渐进式渲染 (progressive rendering)?

  • 你用过哪些不同的 HTML 模板语言?

CSS 相关问题:
  • CSS 中类 (classes) 和 ID 的区别。
  • 请问 “resetting” 和 “normalizing” CSS 之间的区别?你会如何选择,为什么?
  • 请解释浮动 (Floats) 及其工作原理。
  • 描述z-index和叠加上下文是如何形成的。
  • 请描述 BFC(Block Formatting Context) 及其如何工作。
  • 列举不同的清除浮动的技巧,并指出它们各自适用的使用场景。
  • 请解释 CSS sprites,以及你要如何在页面或网站中实现它。
  • 你最喜欢的图片替换方法是什么,你如何选择使用。
  • 你会如何解决特定浏览器的样式问题?
  • 如何为有功能限制的浏览器提供网页?
    • 你会使用哪些技术和处理方法?
  • 有哪些的隐藏内容的方法 (如果同时还要保证屏幕阅读器可用呢)?
  • 你用过栅格系统 (grid system) 吗?如果使用过,你最喜欢哪种?
  • 你用过媒体查询,或针对移动端的布局/CSS 吗?
  • 你熟悉 SVG 样式的书写吗?
  • 如何优化网页的打印样式?
  • 在书写高效 CSS 时会有哪些问题需要考虑?
  • 使用 CSS 预处理器的优缺点有哪些?
    • 请描述你曾经使用过的 CSS 预处理器的优缺点。
  • 如果设计中使用了非标准的字体,你该如何去实现?
  • 请解释浏览器是如何判断元素是否匹配某个 CSS 选择器?
  • 请描述伪元素 (pseudo-elements) 及其用途。
  • 请解释你对盒模型的理解,以及如何在 CSS 中告诉浏览器使用不同的盒模型来渲染你的布局。
  • 请解释 * { box-sizing: border-box; }的作用, 并且说明使用它有什么好处?
  • 请罗列出你所知道的 display 属性的全部值
  • 请解释 inline 和 inline-block 的区别?
  • 请解释 relative、fixed、absolute 和 static 元素的区别
  • CSS 中字母 ‘C’ 的意思是叠层 (Cascading)。请问在确定样式的过程中优先级是如何决定的 (请举例)?如何有效使用此系统?
  • 你在开发或生产环境中使用过哪些 CSS 框架?你觉得应该如何改善他们?
  • 请问你有尝试过 CSS Flexbox 或者 Grid 标准规格吗?
  • 为什么响应式设计 (responsive design) 和自适应设计 (adaptive design) 不同?
  • 你有兼容 retina 屏幕的经历吗?如果有,在什么地方使用了何种技术?
  • 请问为何要使用 translate() 而非 absolute positioning,或反之的理由?为什么?
JS 相关问题:
  • 请解释事件代理 (event delegation)。
  • 请解释 JavaScript 中 this 是如何工作的。
  • 请解释原型继承 (prototypal inheritance) 的原理。
  • 你怎么看 AMD vs. CommonJS?
  • 请解释为什么接下来这段代码不是 IIFE (立即调用的函数表达式):function foo(){ }();.
    • 要做哪些改动使它变成 IIFE?
  • 描述以下变量的区别:nullundefinedundeclared
    • 该如何检测它们?
  • 什么是闭包 (closure),如何使用它,为什么要使用它?
  • 请举出一个匿名函数的典型用例?
  • 你是如何组织自己的代码?是使用模块模式,还是使用经典继承的方法?
  • 请指出 JavaScript 宿主对象 (host objects) 和原生对象 (native objects) 的区别?
  • 请指出以下代码的区别:function Person(){}var person = Person()var person = new Person()
  • .call.apply 的区别是什么?
  • 请解释 Function.prototype.bind
  • 在什么时候你会使用 document.write()
  • 请指出浏览器特性检测,特性推断和浏览器 UA 字符串嗅探的区别?
  • 请尽可能详尽的解释 Ajax 的工作原理。
  • 使用 Ajax 都有哪些优劣?
  • 请解释 JSONP 的工作原理,以及它为什么不是真正的 Ajax。
  • 你使用过 JavaScript 模板系统吗?
    • 如有使用过,请谈谈你都使用过哪些库?
  • 请解释变量声明提升 (hoisting)。
  • 请描述事件冒泡机制 (event bubbling)。
  • “attribute” 和 “property” 的区别是什么?
  • 为什么扩展 JavaScript 内置对象不是好的做法?
  • 请指出 document load 和 document DOMContentLoaded 两个事件的区别。
  • ===== 有什么不同?
  • 请解释 JavaScript 的同源策略 (same-origin policy)。
  • 如何实现下列代码:
[1,2,3,4,5].duplicator(); // [1,2,3,4,5,1,2,3,4,5]
  • 什么是三元表达式 (Ternary expression)?“三元 (Ternary)” 表示什么意思?
  • 什么是 "use strict"; ? 使用它的好处和坏处分别是什么?
  • 请实现一个遍历至 100 的 for loop 循环,在能被 3 整除时输出 “fizz”,在能被 5 整除时输出 “buzz”,在能同时被 35 整除时输出 “fizzbuzz”
  • 为何通常会认为保留网站现有的全局作用域 (global scope) 不去改变它,是较好的选择?
  • 为何你会使用 load 之类的事件 (event)?此事件有缺点吗?你是否知道其他替代品,以及为何使用它们?
  • 请解释什么是单页应用 (single page app), 以及如何使其对搜索引擎友好 (SEO-friendly)。
  • 你使用过 Promises 及其 polyfills 吗? 请写出 Promise 的基本用法(ES6)。
  • 使用 Promises 而非回调 (callbacks) 优缺点是什么?
  • 使用一种可以编译成 JavaScript 的语言来写 JavaScript 代码有哪些优缺点?
  • 你使用哪些工具和技术来调试 JavaScript 代码?
  • 你会使用怎样的语言结构来遍历对象属性 (object properties) 和数组内容?
  • 请解释可变 (mutable) 和不变 (immutable) 对象的区别。
    • 请举出 JavaScript 中一个不变性对象 (immutable object) 的例子?
    • 不变性 (immutability) 有哪些优缺点?
    • 如何用你自己的代码来实现不变性 (immutability)?
  • 请解释同步 (synchronous) 和异步 (asynchronous) 函数的区别。
  • 什么是事件循环 (event loop)?
    • 请问调用栈 (call stack) 和任务队列 (task queue) 的区别是什么?
  • 解释 function foo() {}var foo = function() {} 用法的区别
测试相关问题:
  • 对代码进行测试的有什么优缺点?
  • 你会用什么工具测试你的代码功能?
  • 单元测试与功能/集成测试的区别是什么?
  • 代码风格 linting 工具的作用是什么?
效能相关问题:
  • 你会用什么工具来查找代码中的性能问题?
  • 你会用什么方式来增强网站的页面滚动效能?
  • 请解释 layout、painting 和 compositing 的区别。
网络相关问题:
  • 为什么传统上利用多个域名来提供网站资源会更有效?
  • 请尽可能完整得描述从输入 URL 到整个网页加载完毕及显示在屏幕上的整个流程。
  • Long-Polling、Websockets 和 Server-Sent Event 之间有什么区别?
  • 请描述以下 request 和 response headers:
    • Diff. between Expires, Date, Age and If-Modified-…
    • Do Not Track
    • Cache-Control
    • Transfer-Encoding
    • ETag
    • X-Frame-Options
  • 什么是 HTTP method?请罗列出你所知道的所有 HTTP method,并给出解释。
  • 请解释 HTTP status 301 与 302 的区别?
代码相关的问题:

问题:foo的值是什么?

var foo = 10 + '20';  //1020  (string)

问题:如何实现以下函数?

add(2, 5); // 7
add(2)(5); // 7

问题:下面的语句的返回值是什么?

"i'm a lasagna hog".split("").reverse().join("");

问题:window.foo的值是什么?

"||"左为假,看右,右为真,输出右;左为真,输出左
"&&"在这里起到了短路操作的作用。所谓短路操作,即&&左边若为假值(undefined也为假值),则不会执行&&右边的语句,这是因为&&其中一个为假即为假值,右边就没有运算的必要了。所以window.foo = 'bar’这个语句并没有执行,window.foo的值还是undefined

( window.foo || ( window.foo = "bar" ) ); //bar
( window.foo && ( window.foo = "bar" ) ); //undefined

问题:下面两个 alert 的结果是什么?

var foo = "Hello";
(function() {
  var bar = " World";
  alert(foo + bar);   // Hello World
})();
alert(foo + bar);   // bar is not defined

问题:foo.length的值是什么?

var foo = [];
foo.push(1);
foo.push(2);

问题:foo.x的值是什么?

var foo = {n: 1};
var bar = foo;
foo.x = foo = {n: 2};

问题:下面代码的输出是什么?

console.log('one');
setTimeout(function() {
  console.log('two');
}, 0);
console.log('three');
趣味问题:
  • 你最近写过什么的很酷的项目吗?
  • 在你使用的开发工具中,最喜欢哪些方面?
  • 谁使你踏足了前端开发领域?
  • 你有什么业余项目吗?是哪种类型的?
  • 你最爱的 IE 特性是什么?
  • 你对咖啡有没有什么喜好?
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值