前端面试题集锦

1.对WEB标准以及W3C的理解与认识?
WEB标准简而言之就是将页面的结构、表现和行为各自独立实现。
  (1)web标准规范要求,书写标签必须闭合、标签小写、不乱嵌套、提高搜索机器人搜索几率;
  (2)使用外链css和js脚本、结构行为表现的分离、文件下载与页面速度更快;
  (3)样式与标签的分离,更合理的语义化标签,内容能被更多的用户所访问、内容能被更广泛的设备所访问、更少的代码和组件,容易维护、改版方便;
  (4)不需要变动页面内容、提供打印版本而不需要复制内容、提高网站易用性;
W3C:
W3C标准不是一个标准,而是一系列标准的集合,包含三部分的标准:结构标准、表现标准和动作标准。与结构标准对应的代表语言是xHTML,与表现标准对应的代表语言是CSS,与动作标准对应的代表语言是JavaScript。
当我们将一个成品的网页设计制作成一个静态页面的时候,就要符合前面两种标准,结构标准和表现标准,那么制作出来的页面就是标准页面,用他们相对应的语言来描述这种制作标准页面的技术我们就称之为“xHTML+CSS”!

 2.XHTML和HTML有什么区别?
  HTML是一种基本的WEB网页设计语言,XHTML是一个基于XML的置标语言
  最主要的不同:
  XHTML 元素必须被正确地嵌套。
  XHTML 元素必须被关闭。
  标签名必须用小写字母。
  XHTML 文档必须拥有根元素。
  
3.Doctype? 严格模式与混杂模式-如何触发这两种模式,区分它们有何意义?
用于声明文档使用哪种规范(html/Xhtml)一般为严格模式
加入XMl声明可触发,解析方式更改为IE5.5 拥有IE5.5的bug
严格模式:使用此类型的网页,浏览器解析将相对严格,不允许使用任何表现样式的标识和属性,比如在元素中直接使用background-color背景色属性。
混杂模式:浏览器对XHTML的解析较为宽松。允许使用4.01中的标签,但必须符合XHTML的语法。
4.行内元素有哪些?块级元素有哪些?CSS的盒模型?
块级元素:div p h1 h2 h3 h4 form ul,ol,dl,li,dd,dt,table,td,tr,
行内元素: a b br i span input select,,em,input,img,img,textarea,var,em,strong,
Css盒模型:CSS布局中的每一个元素,在浏览器的解析中,都被当做一个盒状物。content,border ,margin,padding

5.CSS引入的方式有哪些? link和@import的区别是?
内联 内嵌 外链 导入
外链:在html文档的head部分加入:
也是将一个.css文件引入到HTML文件中,但它与导入式不同的是链接式使用HTML规则引入外部CSS文件,它在网页的标签对中使用标记来引入外部样式表文件,使用语法如下:

          <link href="mystyle.css" rel="stylesheet" type="text/css"/>

内嵌:在html文档的head部分直接写入css文档。
嵌入式是将CSS样式集中写在网页的标签对的标签对中。格式如下:

        <head>
        <style type="text/css">
               ...此处写CSS样式
       </style>
      </head>

内联(行内):直接在html标签里写入对这个标签的css控制

    <style type="text/css">
                @import"mystyle.css"; 此处要注意.css文件的路径
     </style>

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

6.CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级高?
继承不如指定 I D>class>标签选择
CSS选择符: 类选择器 、 标签名选择器、 ID选择器 、 后代选择器(派生选择器)、 群组选择器
可以继承: 类选择器 、 标签名选择器、 后代选择器(派生选择器)、群组选择器
优先级算法:
标签内直接定义:1000
ID选择器:100
类选择器 :10
标签名选择器:1
内联和important中,important优先级高

7.前端页面有哪三层构成,分别是什么?作用是什么?
结构层;主要指DOM节点;HTML/XHTML
样式层;主要是指页面渲染;CSS
脚本层:主要指页面动画效果;JS/AS

8.css的基本语句构成是?
选择符、属性、值
选择器{属性1:值1;属性2:值2;……}

9.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?
IE6、7、8、FF、Opear、Safari、、Maxthon;
Trident:Windows 下的 IE 浏览器使用的内核代号。除 IE 外,众多的 IE Shell(如 Maxthon )都使用这个内核。
webkit:谷歌(Chrome)内核
Gecko:Mozilla Firefox 浏览器使用的内核代号。
Presto:Opera 浏览器使用的内核代号,这是目前公认网页浏览速度最快的浏览器内核。
KHTML/WebCore: Konqueror/Safari 浏览器使用的内核代号。

10.写出几种IE6 BUG的解决方法
1. 双边距BUG float引起的 使用display:inline;
2. 当元素使用float浮动后,元素与相邻的元素之间会产生3px的间隙。诡异的是如果右侧的容器没设置高度时3px的间隙在相邻容器的内部,当设定高度后又跑到容器的相反侧了。使用dislpay:inline -3px解决;right也同样浮动 float:left 或者相对IE6定义.left margin-right:-3px;
3. 超链接hover 点击后失效 使用正确的书写顺序 link visited hover active(LVHA);
4. IE6 z-index问题 给父级添加position:relative;
5. Png 透明 使用js代码 改
6. Min-height 最小高度 !Important 解决;
7. select 在ie6下遮盖 使用iframe嵌套;
8. 为什么没有办法定义1px左右的宽度容器(IE6默认的行高造成的,使用over:hidden,zoom:0.08 line-height:1px);
9. IE6中图片的下方会存在一定的间隙,尤其在图片垂直挨着图片的时候,即可看到这样的间隙。解决这个BUG的方法也有很多,可以是改变html的排版,或者定义img 为display:block或者定义vertical-align属性值为vertical-align:top | bottom |middle |text-bottom还可以设置父容器的字体大小为零,font-size:0
10. 一个空格引发CSS失效。IE有个BUG,在处理伪类时,如果伪 类的名称中带有连字符”-“,伪类名称后面就得跟一个空格,不然样式的定义就无效。而在FF中,加不加空格都可以正常处理。
11. ie6下空标签高度问题 IE6下空元素的高度BUG
如果一个元素中没有任何内容,当在样式中为这个元素设置了0-19px之间的高度时。此元素的高度始终为19px。
解决的方法有四种:
a.在元素的css中加入:overflow:hidden
b.在元素中插入html注释:

#box{ float:left; width:100px; margin:0 0 0 100px; //这种情况之下IE会产生200px的距离,这时需要设置display:inline; //使浮动忽略}

9.如何居中一个浮动元素?
对其设置margin:x auto;
10.有没有关注HTML5和CSS3?如有请简单说一些您对它们的了解情况!
有,HTML5的是目前正在为未来的HTML标准的主要修订的发展。其前任一样,4.01和XHTML 1.1的HTML,HTML5的是一个结构和提交万维网内容的标准。新标准结合了诸如视频播放,拖动和放下以前曾在第三方浏览器插件依赖例如Adobe Flash,微软的Silverlight的功能,和谷歌齿轮。
12:如果让你来制作一个访问量很高的大型网站,你会如何来管理所有CSS文件、JS与图片?
把所有的CSS文件都放入一个样式表中,通过把所有的脚本放到一个文件中来减少HTTP请求的方法。js文件也采用同样的方法。把所有的背景图像都放到一个图片文件中,然后通过CSS的background-image和background-position属性来显示图片的不同部分。
14:你对前端界面工程师这个职位是怎么样理解的?它的前景会怎么样?
前端界面工程师:1. 与交互设计师、视觉设计师协作,根据设计图完成页面制作。 2. 维护及优化网站前端性能。
前景: 长期以来,国内前端开发在整个软件开发行业内占得比重较小,发展较晚。网站也多倾向于赢利最大化而轻视用户体验。前后端比例悬殊大。近几年来,随着 以用户为中心 的思想普及发展。前端开发呈现出强劲的发展态势,前端开发人员在项目中的重要性日益突出。前端开发人员呈现出严重的人员短缺现象。
[Javascript]
1:js是什么,js和html 的开发如何结合?
js是一种基于对象和事件驱动,并具有安全性的脚本语言。
可以html的三个地方编写js脚本语言:一是在网页文件的标签对中直接编写脚本程序代码;二是将脚本程序代码放置在一个单独的文件中,在网页文件中引用这个脚本程序语言;三是将脚本程序代码作为某个元素的事件属性值或超链接的href属性值。

2.怎样添加、移除、移动、复制、创建和查找节点
添加:append
删除:remove
移动:
复制:
创建:create
查找:

(1)创建新节点

 createDocumentFragment()    //创建一个DOM片段
    createElement_x_x()   //创建一个具体的元素
      createTextNode()   //创建一个文本节点

(2)添加、移除、替换、插入

      appendChild()
      removeChild()
      replaceChild()
      insertBefore()

(3)查找

      getElementsByTagName_r()    //通过标签名称
      getElementsByName()    //通过元素的Name属性的值
      getElementById()    //通过元素Id,唯一性

3.怎样使用事件以及IE和DOM事件模型之间存在哪些主要差别
4.面向对象编程:b怎么继承a
5.看看下面alert的结果是什么
view sourceprint?1.function b(x, y, a) {
.arguments[2] = 10;
.alert(a);
}
b(1, 2, 3);
如果函数体改成下面,结果又会是什么?
a = 10;
alert(arguments[2] );
6.请编写一个JavaScript函数 parseQueryString,它的用途是把URL参数解析为一个对象
var obj = parseQueryString(url);
alert(obj.key0) // 输出0
7.ajax是什么? ajax的交互模型? 同步和异步的区别? 如何解决跨域问题?
8.什么是闭包?下面这个ul,如何点击每一列的时候alert其index?
闭包是可以包含自由(未绑定)变量的代码块;这些变量不是在这个代码块或者任何全局上下文中定义的,而是在定义代码块的环境中定义。
9.最近看的一篇Javascript的文章是?
10.常使用的库有哪些?常用的前端开发工具?开发过什么应用或组件?
最常用的库:jquery-1.4.2.min.js
常用的前端开发工具:firebug、photoshop、editplus、取色器、色板、eclipse
11.说说YSlow(可以详细一点)
yslow是一个工具,也可以理解成是一个插件,是基于Mozilla Firefox上firebug插件的一个插件。它的出现的主要目的就是检测我们的页面性能。它让用户可以就近取得所需的内容,解决网络拥挤的状况,提高用户访问网站的响应速度;其次,yahoo在ETags配置上也有独特之处,声明过期,就是说,用户从服务器取数据的时候,如果文件变化了,给他反馈新的文件,如果文件没有变化,只需告诉客户端没有变化即可,不必再把文件取回来,这样就节省了大量的网络带宽和资源。另外,只要将那些在加载过程中要执行的脚本放到底部,就可以实现最大的下载并行。
小说网对其评价:(a) 从样式表着手,避免CSS表达式。CSS表达式需要很多资源,有时甚至会造成页面假死。(b) 缓存一下不常修改的文件,并开启 GZIP压缩,减少网络传输时间(c) 减少DNS查找。YSlow认为一个页面上2个以内的域名比较合理。有些网站挂了不少统计代码,或者广告代码。统计拖累用户速度、广告影响用户视觉。(d) 避免重定向(跳转),我们在给链接地址的时候,一般会把链接地址写成 http://xxx.cn/xxx 或者 http://xxx.cn/xxx/ ,有区别吗?有!服务器如果接收到的URL是http://xxx.cn/xxx,它会自动重定向到http://xxx.cn/xxx/,虽然进入的都 是同一个页面,但是前者比后者多走了一步,重定向,显然多多少少浪费了一点时间。
Google 对其评价:多数人可能认为GOOGLE没什么值得借鉴的,毕竟整站就那么几行代码。
但是这几行代码,每天要承受过亿的用户访问量,在如此大的压力下,运行流畅,有很大一个因素取决于Minify JS。通过查看它的源代码可以发现,google不仅将JS进行了压缩,连页面代码中也没有不必要的空格和符号,使用了最短最简洁的变量名。联系到开发方 面,建议大家采用yuicompressor,在调试时使用便于开发的模式,调试完成后直接压缩并发布。让用户得到最快捷的用户体验。

百度:
1、JavaScript有哪几种数据类型
Number 数字类型、String 字符串类型、Boolean 布尔类型、Function 函数、Object 对象、 Null、 Undefined 没有定义类型
2、img中alt和tittle的区别
3、下面css标签在JavaScript中调用应如何拼写,border-left-color,-moz-
4、动态打印 yyyy-mm-dd hh:mm:ss
5、如何提高网页的运行速度
6、JavaScript中如何对一个对象进行深度clone
7、flash中ActionScript2.0和ActionScript3.0面向对象的异同
答案见http://www.lihaihong.com/article/86.html
8、编写一个方法 求一个字符串的字节长度
9、如何控制alert中的换行
10、解释document.getElementByIdx_x_x_x(“ElementID”).style.fontSize=”1.5em”
11、将一个类似图中的效果分离成css和html
12、按照格式 xxxx年xx月xx日xx时xx分xx秒动态显示时间 要求不足10的补0
13、编写一个方法 去掉一个数组的重复元素
14、说出3条以上ff和ie的脚本兼容问题
15、按要求写一个简单的ajax示例 简单的没意义 就不写了
腾讯:
1.请实现,鼠标点击页面中的任意标签,alert该标签的名称.(注意兼容性)
HTML && CSS
1.Doctype? 严格模式与混杂模式-如何触发这两种模式,区分它们有何意义? 行内元素有哪些?块级元素有哪些?CSS的盒模型?**
2.CSS引入的方式有哪些? link和@import的区别?
3.CSS选择符有哪些?哪些属性可以继承?优先级?内联和important哪个优先级高?
4.经常遇到的浏览器的兼容性有哪些?怎么会出现?解决方法是什么?
5.如何居中一个浮动元素?
6.HTML5和CSS3的了解情况
7.你怎么来实现下面这个设计图

Javascript
1.怎样添加、移除、移动、复制、创建和查找节点
添加:append
删除:remove
移动:
复制:
创建:create
查找:
(1)创建新节点

 createDocumentFragment()    //创建一个DOM片段
    createElement_x_x()   //创建一个具体的元素
      createTextNode()   //创建一个文本节点

(2)添加、移除、替换、插入

      appendChild()
      removeChild()
      replaceChild()
      insertBefore()

(3)查找

      getElementsByTagName_r()    //通过标签名称
      getElementsByName()    //通过元素的Name属性的值
      getElementById()    //通过元素Id,唯一性

2.怎样使用事件以及IE和DOM事件模型之间存在哪些主要差别
3.面向对象编程:b怎么继承a
4.看看下面alert的结果是什么
function b(x, y, a) {
arguments[2] = 10;
alert(a);
}
b(1, 2, 3);
如果函数体改成下面,结果又会是什么?
a = 10;
alert(arguments[2] );
5.请编写一个JavaScript函数 parseQueryString,它的用途是把URL参数解析为一个对象,如:var url = ”http://www.taobao.com/index.php?key0=0&key1=1& key2=2…..”var obj = parseQueryString(url);
alert(obj.key0) // 输出0
(来自淘宝网校园招聘笔试题)
6.ajax是什么? ajax的交互模型? 同步和异步的区别? 如何解决跨域问题?
7.什么是闭包?下面这个ul,如何点击每一列的时候alert其index?
8.最近看的一篇Javascript的文章
9.你如何去实现这个Tabview
10.常使用的库有哪些?常用的前端开发工具?开发过什么应用或组件?
11.性能-Yslow

[HTML && CSS]
1.Doctype? 严格模式与混杂模式-如何触发这两种模式,区分它们有何意义?
2:行内元素有哪些?块级元素有哪些?CSS的盒模型?
3.CSS引入的方式有哪些? link和@import的区别是?
4.CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级高?
5:前端页面有哪三层构成,分别是什么?作用是什么?
6:css的基本语句构成是?
8:你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?经常遇到的浏览器的兼容性有哪些?怎么会出现?解决方法是什么?
9.如何居中一个浮动元素?
10.有没有关注HTML5和CSS3?如有请简单说一些您对它们的了解情况!
11.你怎么来实现下面这个设计图,主要讲述思路 (效果图省略)
13:如果让你来制作一个访问量很高的大型网站,你会如何来管理所有CSS文件、JS与图片?
14:你对前端界面工程师这个职位是怎么样理解的?它的前景会怎么样?

重申一下,上述这些知识点都应该是你应该“想都不用想”的东西。我一开始问的所有问题都是想摸清你对所有这些领域知识的掌握程度。虽然上面列出的这些知识点并没有面面俱到,但我觉得你至少应该掌握这些,才有可能跟我坐到一间办公室里来。

少量提问
我非常赞同面试者问的问题越少越好。反复问应聘者各种问题既不公平,也很无聊。我在任何一次面试中,通常只问三个大问题,但每个问题又会涉及我所能想到的多个方面。回答每个大问题一般要经过几个步骤,这样我就可以在每个步骤中穿插着问一些小问题。比如说:
现在有一个正显示着Yahoo!股票价格的页面。页面上有一个按钮,你可以单击它来刷新价格,但不会重新加载页面。请你描述一下实现这个功能的过程,假设服务器会负责准备好正确的股票价格数据。
这个问题牵扯到一组我想要考察的基本知识点:DOM结构、DOM操作、事件处理、XHR和JSON。如果我要求你对换一种处理股票价格的方式,或者让你在页面中显示其他信息,就可以把更多的知识点包括进来。对于经验比较丰富应聘者,我也可以自如地扩展要考察的知识范围,最简单像JOSN与XML的区别、安全问题、容量问题,等等。

我还希望应聘者给出的任何解决方案中都不要使用库。我想看到最原生态的代码,你就当页面中没有包含任何库。你说你对哪个库了解多少多少,但我不能把关于库的知识作为评判能力的因素,因为库是会随时间变化的。我需要的是真正理解库背后的机制,特别是能够徒手写出一个自己的库的人。

解决问题
做为一名前端工程师,最值得高兴的事莫过于解决同一个问题会有很多种不同的方法,而你要做的就是找出最合适的方法来。我在提问的时候,经常会在应聘者解释完一种方法后问他们还有没有第二种方法。此时我会跟他们说,假设你的这个方法由于种种原因被否决了,那么你还能不能给出另一种方法。这样做可以达到两个目的。

首先,可以测试出他们是否在毫无意义地复述书本中的东西。不能不承认,某些人确实有过目不忘的天赋,听他们在那里滔滔不绝地讲,你会觉得他们什么都明白。可是,只要一跟这些人谈到怎么查找方案无效的原因,以及能否拿出一个新方案来,他们往往就傻眼了。这时候,如果我听到“我不明白这个方案为什么不够好”之类的反问,心里立刻就明白我的问题已经超出了他们的能力范围,而他们只是想拿自己死记硬背的结论来蒙混过关。
其次,可以测试出他们已经掌握的(还是那句话,“想都不用想”)浏览器技术知识。如果他们对浏览器平台的核心知识有较好的理解,想出解决同一问题的不同方案根本没有那么难。
对一名前端工程师来说,这绝对是最重要的能力。前端工程师在工作中遇到本该如此却并未如此的难题(说你啦,IE6),应该说是一件很平常的事。一个方案无效就无计可施的人,做不了前端工程师。

考核应聘者解决问题能力的另一层原因,与我的个人喜好有关。在搞清楚应聘者知道什么不知道什么之后,我就会想着问一个他们知识领域之外的问题。这样做的目的,就是想看看他们怎样运用已有的知识解决新问题。在解决问题的每一步,我也准备了一些提示,以防有人会卡壳打艮(在我面前15分钟一言不发,对我评价这个人毫无帮助)。我真正感兴趣的,是他们能够从上一步前进到下一步。我希望看到一个人就在我眼前学到新知识。

注意:所有问题都与浏览器技术相关。我不相信出几道抽象的逻辑题,就能够考出某人解决Web技术问题的能力。在我看来,这无异于让素描大师画肖像(或者让刘翔跟博尔特同场竞技),没有意义,也得不到任何有价值的信息。

有激情
要成为一名优秀的前端工程师,最重要的莫过于对自己做的事要有激情。我们技能都不是从学校中或者从研讨会上学来的,因此前端工程师必须具备自学能力。浏览器技术的变化可谓日新月异,所以也只有不断提升自己的技能才做得到与时俱进。我虽然不能强迫谁必须多看博客、不断学习,但想应聘前端工程师的人恐怕还是必须这么做的。

你怎么知道谁对这种工作有没有激情?实际上非常简单。我只问一个简单的问题:“目前你对什么Web技术最感兴趣?”这个问题永远不会过期,而且也几乎不可能出错……除非你答不上来。就眼下来说,我希望你对这个问题给出的技术中包括WebSocket、HTML、WebGL、客户端数据库,等等。只有对Web开发充满激情的人,才会坚持不懈地学习新知识、掌握新技能;这些人才是我真正想要的。当然,我会让他们详细解释自己提到的技术,以保证他们不是随口说了几个时髦的新词汇。

最后一点
计算机科学或者Web设计方面的知识当然也有用,但那都是基本知识之外的东西。只要基本知识在那儿了,一切就都有了基础,想扩充知识面也不难。可是,如果等到正式上班以后,还得从头学习基本技能,那种难度是不可同日而语的。另外,高级前端工程师与一般工程师相比,肯定需要掌握更多的技能。而面试几乎没有经验大学毕业生,同样也会有一套完全不同的程序。我在这篇文章里列出来的都是一些最基本的东西。

对于那些还没有多少面试经验的人,我总是喜欢告诉他们,面试完了只要问自己一个问题就行:你想以后跟这个人在一起共事吗?如果不管为什么,回答是不,那就是不。

面试前端工程师对我来说是一件非常有意思的事,因为面试过程很大程度上也是自我提升的过程。无论大公司还是小公司,之所以在如何招聘到真正有能力的前端工程师方面会遇到同样的问题,就是因为负责招聘的那些人不知道自己公司需要什么样的人,结果问问题时也问不到点子上。经过这几年在行业里的摸索,我总结出了自己的一套很有效的面试前端工程的方法。

有的应聘者说我不好对付,但留给他们这样的印象也并非我所愿。我觉得之所以他们说我不好对付,主要是因为我问他们问题时问得太细了。以前我曾专门写过一些东西,告诉应聘者怎么才能通过我的面试(Surviving an interview with me)以及优秀的前面工程师应该具备什么样的素质(What makes a good front end engineer?),而我的面试可以说完全是按照那两篇文章的标准进行的。我不会问一些特别偏门的问题,也不认为出几道逻辑题就能考出人的真实水平。我唯一的想法就是确定你能否胜任我们要招的这个职位。为此,我需要简单地考察如下几个方面。

基本知识
我们生活在互联网时代,你想知道的任何事情几乎都能在15分钟内找到相关信息。可是,能找到信息并不等于你会使用它。我认为所有前端工程师至少都应该掌握某些基本的知识,才能有效地完成自己的工作。如果一遇到问题,就停下工作上网四处搜索解决方案,怎么可能保证按期完成工作呢?听听,还有谁在说“我不知道,但我可以上网搜到。”请这些同学把手举起来,让大家认识一下(immediately raises a flag for me.)。下面我列出一些基本的知识点,这些都是我认为一名前端工程师(无论工作年头长短)在没有任何外来帮助的情况应该知道的。

DOM结构——两个节点之间可能存在哪些关系以及如何在节点之间任意移动。
DOM操作——怎样添加、移除、移动、复制、创建和查找节点。
事件——怎样使用事件以及IE和DOM事件模型之间存在哪些主要差别。
XMLHttpRequest——这是什么、怎样完整地执行一次GET请求、怎样检测错误。
严格模式与混杂模式——如何触发这两种模式,区分它们有何意义。
盒模型——外边距、内边距和边框之间的关系,IE 8以下版本的浏览器中的盒模型有什么不同。
块级元素与行内元素——怎么用CSS控制它们、它们怎样影响周围的元素以及你觉得应该如何定义它们的样式。
浮动元素——怎么使用它们、它们有什么问题以及怎么解决这些问题。
HTML与XHTML——二者有什么区别,你觉得应该使用哪一个并说出理由。
JSON——它是什么、为什么应该使用它、到底该怎么使用它,说出实现细节来。

前端开发工程师面试题 Javascript
1. 要动态改变层中内容可以使用的方法有(AB )
a)innerHTML
b)innerText
c)通过设置层的隐藏和显示来实现
d)通过设置层的样式属性的display属性

  1. 当按键盘A时,使用onKeyDown事件打印event.keyCode的结果是(A )
    a)65
    b)13
    c)97
    d)37

  2. 在javascript里,下列选项中不属于数组方法的是(B);
    a)sort()
    b)length()
    c)concat()
    d)reverse()

  3. 下列哪一个选项可以用来检索被选定的选项的索引号?(B)
    a)disabled
    b)selectedIndex
    c)option
    d)multiple

  4. 希望图片具有”提交”按钮同样的功能,该如何编写表单提交?(A )
    a)在图片的onClick事件中手动提交
    b)在图片上添加onSubmit事件
    c)在图片的onSubmit事件中手动提交
    d)在表单中自动提交

  5. 使div层和文本框处在同一行的代码正确的是(D );
    a)
    b)
    c)
    d)

  6. 下列选项中,描述正确的是(选择两项) 。( AD )
    a)options.add(new Option(‘a’,’A’))可以动态添加一个下拉列表选项
    b)option.add(new Option(‘a’,’A’))可以动态添加一个下拉列表选项
    c)new Option(‘a’,’A’)中’a’表示列表选项的值,’A’用于在页面中显示
    d)new Option(‘a’,’A’)中’A’表示列表选项的值,’a’用于在页面中显示

  7. 、 var emp = new Array(3);
    for(var i in emp)
    以下答案中能与for循环代码互换的是: (选择一项)。(D )
    A for(var i =0; i
    B for(var i =0; i
    C for(var i =0; i
    D for(var i =0; i

  8. 制作级联菜单功能时调用的是下拉列表框的(A )事件。
    a)onChange
    b)onFocus
    c)selected
    d)onClick

  9. 下列声明数组的语句中,错误的选项是( C )。
    a)Var arry= new Array()
    b)Var arry=new Array(3)
    c)Var arry[]=new Array(3)(4)
    d)Var arry=new Array(‘3’,’4’)

  10. 下列属性哪一个能够实现层的隐藏?(C )
    a)display:fals
    b)display:hidden
    c)display:none
    d)display:” ”

  11. 下列哪一个选项不属于document对象的方法?(D )
    a)focus()
    b)getElementById()
    c)getElementsByName()
    d)bgColor()

  12. 下列哪项是按下键盘事件(AB )
    a)onKeyDown
    b)onKeyPress
    c)keyCode
    d)onMouseOver

  13. javascript进行表单验证的目的是(B )
    a)把用户的正确信息提交给服务器
    b)检查提交的数据必须符合实际
    c)使得页面变得美观、大方
    d)减轻服务器端的压力
  14. 、 display属性值的常用取值不包括(C )
    a)inline
    b)block
    c)hidden
    d)none

  15. 以下有关pixelTop属性与top属性的说法正确的是。(D )
    a)都是Location对象的属性
    b)使用时返回值都是字符串
    c)都是返回以像素为单位的数值
    d)以上都不对

  16. 使用open方法打开具有浏览器工具条,地址栏,菜单栏的窗口,下列选项正确的是D
    a)open(“x.html”,”HI”,”toolbas=1,scrollbars=1,status=1”);
    b)open(“HI”,”scrollbars=1,location=1,status=1”);
    c)open(“x.html”,”status=yes,menubar=1,location=1”);
    d)open(“x.html”,”HI”,”toolbas=yes,menubar=1,location=1”);

  17. 下面关闭名为mydiv的层的代码正确的是(C )
    a)document.getElementByIdx_x_x_x(mydiv).style.display=”none”;
    b)document.getElementByIdx_x_x_x(“mydiv”).style.display=none;
    c)document.getElementByIdx_x_x_x(“mydiv”).style.display=”none”;
    d)document.getElementByIdx_x_x_x(“mydiv”).style.display==”none”;

  18. 为什么要使用Div+CSS布局
    形式与内容分离
    大大减少页面代码,提高页面浏览速度
    结构清晰,有利于SEO
    缩短改版时间, 布局更方便
    一次设计,多次使用

  19. Block元素的特点是什么?哪些元素默认为Block元素
    总是在新行上开始;
    高度,行高以及顶和底边距都可控制;
    宽度缺省是它的容器的100%,除非设定一个宽度
    是块元素的有:div,p,img

  20. 、 inline元素的特点是什么?哪些元素属于inline元素?
    和其他元素都在一行上;
    高,行高及顶和底边距不可改变;
    宽度就是它的文字或图片的宽度,不可改变。
    是inline元素的有:a、span、input
  21. 、 javascript中表达式parseInt(“X8X8”)+paseFloat(‘8’)的结果是什么?( C)
    a)8+8
    b)88
    c)16
    d)“8”+’8

  22. String对象的方法不包括(C )
    a)charAt();
    b)substring()
    c)length
    d)toUpperCase()

  23. 关于setTimeout(“check”,10)中说法正确的是( D)
    a)程序循环执行10次
    b)Check函数每10秒执行一次
    c)10做为参数传给函数check
    d)Check函数每10毫秒执行一次

  24. 以下哪个单词不属于javascript关键字:(C)
    a)with
    b)parent
    c)class
    d)void

前言
  本文总结了一些优质的前端面试题(多数源于网络),初学者阅后也要用心钻研其中的原理,重要知识需要系统学习,透彻学习,形成自己的知识链。万不可投机取巧,只求面试过关是错误的!
面试有几点需注意:(来源程劭非老师 github:@wintercn)
面试题目: 根据你的等级和职位变化,入门级到专家级:范围↑、深度↑、方向↑。
题目类型: 技术视野、项目细节、理论知识题,算法题,开放性题,案例题。
进行追问: 可以确保问到你开始不懂或面试官开始不懂为止,这样可以大大延展题目的区分度和深度,知道你的实际能力。因为这种关联知识是长时期的学习,绝对不是临时记得住的。
回答问题再棒,面试官(可能是你的直接领导面试),会考虑我要不要这个人做我的同事?所以态度很重要。(感觉更像是相亲)
资深的工程师能把 absolute 和 relative 弄混,这样的人不要也罢,因为团队需要的你这个人具有可以依靠的才能(靠谱)。
前端开发面试知识点大纲:
HTML&CSS:
对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功:布局、盒子模型、选择器优先级及使用、HTML5、CSS3、移动端适应
JavaScript:
数据类型、面向对象、继承、闭包、插件、作用域、跨域、原型链、模块化、自定义事件、内存泄漏、事件机制、异步装载回调、模板引擎、Nodejs、JSON、ajax等。
其他:
HTTP、安全、正则、优化、重构、响应式、移动端、团队协作、可维护、SEO、UED、架构、职业生涯

网易2015校招-前端工程师(笔试题)
1.对于多关键字而言,那种文件组织方便而又高效()
A、顺序文件 B、倒排文件 C、散列文件 D、B+树索引文件

2.以下哪些算法可用于遍历网络图()
A、广度优先搜索 B、深度优先搜索 C、线性规划策略 D、决策树

3.我们使用一个6元组来表示6个节点的无向图的顶点数,请问以下哪些6元组是可能的组合()
A、<1,2,3,4,5,6> B、<2,4,4,2,3,5> C、<1,3,4,2,2,1> D、<1,2,2,4,5,2>

4.以下关于可计算性的说法正确的是()
A、所有问题最终都可以抽象为一个计算模型,图灵机可以在一个有限的时间(虽然可能会占用非常久的时间)内完成计算:现代计算机的设计正是基于该理论。
B、存在部分问题,我们无法在有限时间内,给出解答:但是,所有问题都可以在有限时间内验证其解答的正确性。
C、 Godel(哥德尔)第一定律指明不存在完备且相容的公理系统。
D、以上说法都不正确。

  1. 16进制数值C396和8进制数值64474的异或结果值(10进制)为()
    A、43690 B、16660 C、60350 D、20375

6.以下经典的问题哪些属于NP问题()
A、图灵停机问题 B、排序 C、0,1背包问题 D、枚举有限集合的所有子集

7.存在以下字母串:AGDCCDDDGFBBFFGGDDDGGGEFFDDCCCDDDFGAAA现在需要对该串进行Huffman编码,那么字母F对应bit值(二进制格式为)()
A、10 B、11 C、110 D、101

8.进程管理如果设计不当将会导致“死锁”的产生,对待死锁,典型的银行家算法属于(1),而剥夺资源属于(2)的方法。
A、(1)=死锁预防,(2)=死锁避免
B、(1)=死锁预防,(2)=死锁解除
C、(1)=死锁避免,(2)=死锁预防
D、(1)=死锁避免,(2)=死锁解除

9.关于数据库索引,以下说法正确的是()
A、针对某些字段建立索引,能够有小减少相关数据库表的磁盘空间占用;
B、针对某些字段建立索引,能够有效的提升相关字段的读与写的效率;
C、常见数据库管理系统,通常使用hash表来存储索引;
D、数据库索引的存在,可能导致相关字段删除的效率降低;
简答题:
1、什么是闭包,闭包有什么用?请举例说明。
2.apply 和 call 的用法和区别。

3.bind 函数的兼容性

4.参考给出的原型图和要求,手写 html,css和 js。

5.飞机起飞时,人会感觉到有一股力压在身上,为什么?施力者是谁?

6.飞机平稳飞行后,你在过道跳起来,会不会撞到飞机尾部?

7.n是一个奇数,求证n(n^2-1)能被24整除

8.两个r进制的数,N和N’,它们的位数相同,数字也都相同,只是排序不一样(比如12345和25413)求证N-N’能被r-1整除。

9.关于session的。 为什么使用session?使用session的根本原因是?假如你使用的编程语言没有提供对session的支持,请你使用伪代码实现session机制。 请说明在你实现的机制中的安全因素。

10.假如要让你的机制实现多个web服务器前端(几多个机器),你要怎样实现?假如要让你的机制实现勿单点故障点(即一台机器当掉,不影响整个系统的运行),你要怎样实现?
2015腾讯WEB前端开发笔试题:

  1 请实现,鼠标点击页面中的任意标签,alert该标签的名称.(注意兼容性)

  2 请指出一下代码的性能问题,并经行优化。

  var info=”腾讯拍拍网(www.paipai.com)是腾讯旗下知名电子商务网站。”;

  info +=”拍拍网于2005年9月12日上线发布,”;

  info +=”2006年3月13日宣布正式运营,”;

  info +=”是目前国内第二大电子商务平台。”;

  info=info.split(“,”);

  for(var i=0; i{

  alert(info[i]);

  }

  3 请给出异步加载js方案,不少于两种。

  4 请写出jQuery绑定事件的方法,不少于两种。

  5 请设计一套方案,用于确保页面中JS加载完全。

  6 请优化某网页的加载速度。

  7 对string对象经行扩展,使其具有删除前后空格的方法。

  8 完成一个正则表达式,验证用户输入是否身份证号码。

  意志是每一个人的精神力量,是要创造或是破坏某种东西的自由的憧憬,是能从无中创造奇迹的创造力。――莱蒙托夫

  Web前端开发笔试题集锦:

  1,截取字符串abcdefg的efg

  var str = “abcdefg”;

  if (/efg/.test(str)) {

  var efg = str.substr(str.indexOf(“efg”), 3);

  alert(efg);

  }

  2, 判断字符串是否是这样组成的,第一个必须是字母,后面可以是字母、数字、下划线,总长度为5-20

  var reg = /^[a-zA-Z][a-zA-Z_0-9]{4,19}$/;

  reg.test(“a1a__a1a__a1a__a1a__”);

  3,判断一个字符串中出现次数最多的字符,统计这个次数

  //将字符串的字符保存在一个hash table中,key是字符,value是这个字符出现的次数

  var str = “abcdefgaddda”;

  var obj = {};

  for (var i = 0, l = str.length; i < l; i++) {

  var key = str[i];

  if (!obj[key]) {

  obj[key] = 1;

  } else {

  obj[key]++;

  }

  }

  /遍历这个hash table,获取value最大的key和value/

  var max = -1;

  var max_key = “”;

  var key;

  for (key in obj) {

  if (max < obj[key]) {

  max = obj[key];

  max_key = key;

  }

  }

  alert(“max:”+max+” max_key:”+max_key);

  4,IE与FF脚本兼容性问题

  (1) window.event:

  表示当前的事件对象,IE有这个对象,FF没有,FF通过给事件处理函数传递事件对象

  (2) 获取事件源

  IE用srcElement获取事件源,而FF用target获取事件源

  (3) 添加,去除事件

  IE:element.attachEvent(“onclick”, function) element.detachEvent(“onclick”, function)

  FF:element.addEventListener(“click”, function, true) element.removeEventListener(“click”, function, true)

  (4) 获取标签的自定义属性

  IE:div1.value或div1[“value”]

  FF:可用div1.getAttribute(“value”)

  (5) document.getElementByName()和document.all[name]

  IE;document.getElementByName()和document.all[name]均不能获取div元素

  FF:可以

  (6) input.type的属性

  IE:input.type只读

  FF:input.type可读写

  (7) 是否可用id代替HTML元素

  IE:可以用id来代替HTML元素

  FF:不可以

  (8) innerText textContent outerHTML

  IE:支持innerText, outerHTML

  FF:支持textContent

你可能感兴趣的:(css,前端,面试题,w3c,html-js)