摘要:面试题是招聘公司和开发者都非常关心的话题,公司希望通过它了解开发者的真实水平和细节处理能力,而开发者希望能够最大程度地展示自己的水平(甚至超常发挥)。本文提供了众多前端开发面试题,无论是招聘方还是应聘方都值得一看!
一般问题
--------------------------------------------------------------------------------
你用Twitter吗? (在天朝最好问你用微博吗?)
•如果用,你都关注那些人?
你用Github吗?
•如果用,你关注的项目有什么?
你关注的博客有那些?
你使用那些版本管理系统,比如Git,SVN等?
你常用的开发环境是怎样的?比如操作系统,文本编辑器,浏览器,及其他工具等。
你能描述一下你制作一个网页的工作流程吗?
你能描述一下渐进增强和优雅降级之间的不同吗?
•如果提到了特性检测,可以加分。
请解释一下什么是语义化的HTML。
你更喜欢在哪个浏览器下进行开发?你使用那些开发人员工具?
你如何对网站的文件和资源进行优化?
•期待的解决方案包括:
1.文件合并
2.文件最小化/文件压缩
3.使用CDN托管
4.缓存的使用
5.其他
为什么利用多个域名来存储网站资源会更有效?
•浏览器一次可以从一个域名下做多少资源?
请说出三种减低页面加载时间的方法。(加载时间指感知的时间或者实际加载时间)
如果你接到了一个使用Tab来缩进代码的项目,但是你喜欢空格,你会怎么做?
•建议这个项目使用像EditorConfig(http://editorconfig.org)之类的规范
•为了保持一致性,转换成项目原有的风格
•直接使用VIM的retab命令
请写一个简单的幻灯效果页面
•如果不使用JS来完成,可以加分。
你都使用那些工作来测试代码的性能?
•例如JSPerf (http://jsperf.com/)
•例如Dromaeo (http://dromaeo.com/)
•其它。
如果今年你打算熟练掌握一项新技术,那会是什么?
请谈一下你对网页标准和标准制定机构重要性的理解。
什么是FOUC?你如何来避免FOUC?
HTML相关问题
--------------------------------------------------------------------------------
文档类型的作用是什么?你知道多少种文档类型?
浏览器标准模式和怪异模式之间的区别是什么?
使用XHTML的局限有那些?
•如果页面使用'application/xhtml+xml'会有什么问题吗?
如果网页内容需要支持多语言,你会怎么做?
•在设计和开发多语言网站时,有哪些问题你必须要考虑?
在HTML5的页面中可以使用XHTML的语法吗?
在HTML5中如何使用XML?
'data-'属性的作用是什么?
如果把HTML5看作做一个开放平台,那它的构建模块有那些?
请描述一下cookies,sessionStorage和localStorage的区别?
JS相关问题
--------------------------------------------------------------------------------
你使用过那些Javascript库?
你是否研究过你所使用的JS库或者框架的源代码?
什么是哈希表?
'undefined'变量和'undeclared'变量分别指什么?
闭包是什么,如何使用它,为什么要使用它?
•你喜欢的使用闭包的模式是什么?
请举出一个匿名函数的典型用例?
请解释什么是Javascript的模块模式,并举出实用实例。
•如果有提到无污染的命名空间,可以考虑加分。
•如果你的模块没有自己的命名空间会怎么样?
你如何组织自己的代码?是使用模块模式,还是使用经典继承的方法?
请指出Javascript宿主对象和内置对象的区别?
指出下列代码的区别:
1.function Person(){} var person = Person() var person = new Person() '.call'和'.apply'的区别是什么?
请解释'Funciton.prototype.bind'的作用?
你如何优化自己的代码?
你能解释一下JavaScript中的继承是如何工作的吗?
在什么时候你会使用'document.write()'?
•大多数生成的广告代码依旧使用'document.write()',虽然这种用法会让人很不爽。
请指出浏览器特性检测,特性推断和浏览器UA字符串嗅探的区别?
请尽可能详尽的解释AJAX的工作原理。
请解释JSONP的工作原理,以及它为什么不是真正的AJAX。
你使用过JavaScript的模板系统吗?
•如有使用做,请谈谈你都使用过那些类似库文件。比如Mustache.js,Handlebars等等。
请解释变量声明提升。
请描述下事件冒泡机制。
"attribute"和"property"的区别是什么?
为什么扩展JavaScript内置对象是个坏做法?
为什么扩展JavaScript内置对象是个好做法?
请指出document load和document ready的区别。(这是个问题的问题)
'=='和'==='有什么不同?
你如何获取浏览器URL中查询字符串中的参数。
请解释一下JavaScript的同源策略。
请解释一下事件代理。
请描述一下JavaScript的继承模式。
如何实现下列代码:
1.[1,2,3,4,5].duplicator(); // [1,2,3,4,5,1,2,3,4,5] 描述一种JavaScript memoization(避免重复运算)的策略。
什么是三元条件语句?
函数的参数元是什么?
什么是"use strict"?使用它的好处和坏处分别是什么?
JS代码示例:
1.~~3.14 问题:上面的语句的返回值是什么? 答案:3
1."i'm a lasagna hog".split("").reverse().join(""); 问题:上面的语句的返回值是什么? 答案:"goh angasal a m'i"
1.( window.foo || ( window.foo = "bar" ) ); 问题:window.foo的值是什么? 答案:"bar" 只有window.foo为假时的才是上面答案,否则就是它本身的值。
1.var foo = "Hello"; (function() { var bar = " World"; alert(foo + bar); })(); alert(foo + bar); 问题:上面两个alert的结果是什么? 答案: "Hello World" & ReferenceError: bar is not defined
1.var foo = []; 2.foo.push(1); 3.foo.push(2); 问题:foo.length的值是什么? 答案:'2'
1.var foo = {}; 2.foo.bar = 'hello'; 问题:foo.length的值是什么? **答案: undefined
jQuery相关问题
--------------------------------------------------------------------------------
解释"chaining"。
解释"deferreds"。
你知道那些针对jQuery的优化方法。
请解释'.end()'的用途。
你如何给一个事件处理函数命名空间,为什么要这样做?
请说出你可以传递到jQuery方法的四种不同值。
•选择器(字符串),HTML(字符串),回调函数,HTML元素,对象,数组,元素数组,jQuery对象等。
什么是效果队列?
请指出'.get()','[]','eq()',的区别。
请指出'.bing()','.live()'和'.delegate()'的区别。
请指出'$'和'$.fn'的区别?或者说出'$.fn'的用户。
请优化下列选择器:
1.$(".foo div#bar:eq(0)") CSS相关问题
--------------------------------------------------------------------------------
描述css reset的作用和用途。
描述下浮动和它的工作原理。
清除浮动的方法有那些,分别适用于什么情形。
解释css sprites,如何使用。
你最喜欢的图片替换方法是什么,你如何选择使用。
讨论CSS hacks,条件引用或者其他。
如何为有功能限制的浏览器提供网页。
•你会使用那些技术和处理方法。
如何视觉隐藏网页内容,只让它们在屏幕阅读器中可用。
你使用过网格系统吗?如果使用过,你最喜欢哪种?
你使用过meidia queries(媒体查询)吗,或者移动网站相关的CSS布局。
你熟悉SVG样式的书写吗?
如何优化网页的打印样式。
在书写高效CSS文件时会有哪些问题需要考虑。
你使用CSS预处理器吗?(SASS,Compass,Stylus,LESS)
•如果使用,描述你的喜好。
你是否接触过使用非标准字体的设计?
•字体服务,Google Webfonts, Typekit,等等。
请解释浏览器是如何根据CSS选择器选择对应元素的。
可选的有趣问题
--------------------------------------------------------------------------------
你编写过的最酷的代码是什么?其中你最自豪的是什么?
你知道HTML5的帮派标志吗?
你是否正在或曾经在一艘船上。(不懂这个幽默)
你使用的开发工具中,你最喜欢的部分是什么?
你有什么业余项目吗?是那种类型的?
解释cornify的重要性?(本题完全摸不到头脑)
在一张纸上,垂直写下ABCDE,然后不用任何代码,将他们到序排列。
•静静的看他们是否将纸反转。
海盗还是忍者?
•如果是两者的合体,并有恰当理由,可以加分。如果是僵尸猴子海盗加忍者加两分。(注:此题文化差异过大)
如果没有在Web开发,你会做什么?
卡门圣迭哥的隐藏处在哪里?
•提示:本题的答案永远是错的。
你最爱的IE特性是什么?
完句填空: Brendan Eich和Doug Crockford是JavaScript的________。
讨论:jQuery是牛逼的库还是最牛逼的库。
原文链接:GitHub
感谢这些贡献者:
@bentruyman (http://bentruyman.com/), @roger_raymond (http://twitter.com/iansym), @ajpiano (http://ajpiano.com/), @paul_irish (http://paulirish.com/), @SlexAxton (http://alexsexton.com/), @boazsender (http://boazsender.com/), @miketaylr (http://miketaylr.com/), @vladikoff (http://vladfilippov.com/), @gf3 (http://gf3.ca/), @jon_neal (http://twitter.com/jon_neal), @wookiehangover (http://wookiehangover.com/) and @darcy_clarke (http://darcyclarke.me)
摘自:http://www.csdn.net/article/2012-10-18/2810902-Front-end-Developer-Interview-Questions
分享到:
相关推荐
【前端开发面试题详解】 前端开发面试题涵盖了各种技术领域,包括HTML、CSS、JavaScript、浏览器行为、性能优化以及开发工具的使用。以下是对部分面试题的详细解答: 1. **语义化的HTML**:语义化HTML意味着使用...
### Web前端开发经典面试题详解 #### CSS选择器的理解 1. **问题**: 下面有关CSS选择器的说法错误的是? - **选项**: - A. `.intro`---选择class="intro"的所有元素。 - B. `#firstname`---选择id="firstname...
这份“百度、淘宝、网易、搜狐前端开发面试题集锦”PDF文件很可能包含了这些公司近年来的面试热点问题,旨在测试候选人的技术深度和广度。 首先,前端开发的基础知识通常包括HTML、CSS和JavaScript。面试题可能会...
本文将围绕“前端开发面试题、腾讯华为前端面试题”这一主题,深入探讨前端开发者在面试过程中可能遇到的关键知识点,包括Vue.js、JavaScript(特别是ES6)、React、Redux、正则表达式以及HTML/CSS等方面。...
16.md 2014年最新前端开发面试题 General 17.md 前端面试资源汇总 General 18.md 5个典型的JavaScript面试题(上) JavaScript 19.md 再来5个JavaScript面试题 JavaScript 20.md BAT web前端开发方向校招都考些...
"前端开发校招面试题大全"这个压缩包文件很可能包含了多方面的前端技术题目,旨在帮助求职者准备字节跳动或其他公司的面试。 首先,前端开发涵盖了许多关键知识点,包括但不限于HTML、CSS、JavaScript基础,以及...
### 前端开发面试知识点详解 ... **1....以上内容涵盖了前端开发面试中常见的知识点,对于求职者来说,深入理解这些概念不仅能帮助他们在面试中脱颖而出,更重要的是能够在未来的工作中发挥重要作用。
但考虑到【标题】和【描述】中提到的是“6月最新大厂前端高频面试题”,我们可以推断出文档中将涉及当前大厂在前端开发领域的面试热点问题和技术要求。由此,我可以根据当前大厂前端面试的趋势和要求,详细说明一些...
综上所述,WEB前端开发面试题集锦为应聘者提供了一个了解面试常见问题的方向,并帮助他们巩固和理解前端开发中的关键知识点。通过深入学习这些内容,应聘者不仅能在面试中脱颖而出,还能在实际工作中表现出色,为...
在IT行业中,Web前端开发是不可或缺的一部分,而Vue.js作为一款轻量级的前端JavaScript框架,因其易学易用和强大的功能,深受开发者喜爱。针对Vue面试和笔试,我们需要掌握一系列核心概念和技术。以下是根据提供的...
本资源摘要提供了前端开发工程师高频面试题的整理,涵盖了 JS、框架、面试题等多个方面的知识点。 一、JS 相关 1. 闭包:闭包是指函数内部可以访问其外部函数的变量的函数。闭包可以用来实现模块化、封装私有变量...
3. **JavaScript**:JavaScript是前端开发的灵魂,面试题可能包括变量、数据类型、作用域、闭包、原型链、异步编程(回调、Promise、async/await)、DOM操作等。 4. **浏览器工作原理**:理解浏览器如何解析HTML、...
### 常见Java前端面试题及Java面试问题集 #### 一、HTML/CSS 部分 **1. 什么是盒子模型?** 在网页布局中,元素被视为一个矩形区域,即“盒子”。CSS 的盒子模型由四个部分组成:content(内容)、padding(填充...
以上是针对前端开发面试题的部分解析,涵盖了HTML、CSS的基础知识以及常见的问题处理技巧。这些问题体现了前端开发者应具备的基本技能和理解,对于准备面试或者提升自身技术能力都是很有帮助的。
【Web前端开发面试题及答案】的文档涵盖了前端开发中的多个关键知识点,主要涉及HTML、CSS、JavaScript等方面。以下是对这些知识点的详细说明: 1. **Web标准与W3C理解**:Web标准指的是W3C(World Wide Web ...
这份"前端面试题(react等).rar"的压缩包文件包含了针对这些技术的面试题,旨在帮助求职者准备大厂的前端面试。以下是根据标题和描述所涉及的知识点进行的详细解释: 1. **CSS**: - CSS布局:盒模型、流体布局、...
前端开发面试题含答案.pdf 本资源摘要信息涵盖了前端开发面试题的知识点,大纲包括 HTML&CSS、JavaScript、其他等方面。 HTML&CSS 方面: 1. Web 标准的理解 2. 浏览器内核差异 3. 兼容性 4. hack 5. CSS 基本功...
通过这份2021年腾讯前端面试题真题解析,求职者可以针对性地复习和练习,加深对前端开发核心知识的理解,提升面试表现,争取在激烈的竞争中脱颖而出。记住,面试不仅仅是检验技术能力,更是展现个人解决问题、学习新...