千锋教育-做有情怀、有良心、有品质的IT职业教育机构

位置:首页 > 职场攻略

HTML5培训:前端开发面试题大全

时间:2017-05-23 09:58:25  |  来源:广州千锋  |  作者:广州千锋

  对于前端开发人员来说,面试中会遇到技术笔试的部分,下面,千锋HTML5培训的老师就跟大家一起分享一些面试题,供大家参考,希望对大家的面试有所帮助!

  HTML+CSS

  1.对WEB标准以及W3C的理解与认识

  标签闭合、标签小写、不乱嵌套、提高搜索机器人搜索几率、使用外链css和js脚本、结构行为表现的分离、文件下载与页面速度快、内容能被多的用户所访 问、内容能被广泛的设备所访问、少的代码和组件,容易维护、改版方便,不需要变动页面内容、提供打印版本而不需要复制内容、提高网站易用性;

  2.xhtml和html有什么区别

  HTML是一种基本的WEB网页设计语言,XHTML是一个基于XML的置标语言

  主要的不同:

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

  XHTML 元素必须被关闭。

  标签名必须用小写字母。

  XHTML 文档必须拥有根元素。

  3.Doctype? 严格模式与混杂模式-如何触发这两种模式,区分它们有何意义?

  用于声明文档使用那种规范(html/Xhtml)一般为 严格 过度 基于框架的html文档

  加入XMl声明可触发,解析方式改为IE5.5 拥有IE5.5的bug

  4.行内元素有哪些?块级元素有哪些?CSS的盒模型?

  块级元素:div p h1 h2 h3 h4 form ul

  行内元素: a b br i span input select

  Css盒模型:内容,border ,margin,padding

  5.CSS引入的方式有哪些? link和@import的区别是?

  内联 内嵌 外链 导入?

  区别 :同时加载

  前者无兼容性,后者CSS2.1以下浏览器不支持

  ?Link 支持使用javascript改变样式,后者不可

  6.CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级高?

  标签选择符??类选择符 id选择符

  继承不如指定? ?Id>class>标签选择

后者优先级高

  7.前端页面有哪三层构成,分别是什么?作用是什么?

  结构层 Html 表示层 CSS 行为层 js

  8.css的基本语句构成是?

  选择器{属性1:值1;属性2:值2;……}

  9.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?

  Ie(Ie内核)??火狐(Gecko) 谷歌(webkit) opear(Presto)

  10.写出几种IE6 BUG的解决方法

  1.双边距BUG float引起的??使用display

  2.3像素问题 使用float引起的 使用dislpay:inline -3px??

  3.超链接hover 点击后失效??使用正确的书写顺序 link visited hover active

  4.Ie 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)

  11.<img>标签上title与alt属性的区别是什么?

  Alt 当图片不显示是 用文字代表。

  Title 为该属性提供信息

  12.描述css reset的作用和用途。

  Reset重置浏览器的css默认属性? ?? ???浏览器的品种不同,样式不同,然后重置,让他们统一

  13.解释css sprites,如何使用。

  Css 精灵 把一堆小的图片整合到一张大的图片上,减轻服务器对图片的请求数量


  14.浏览器标准模式和怪异模式之间的区别是什么?

  盒子模型 渲染模式的不同

  使用 window.top.document.compatMode 可显示为什么模式

  15.你如何对网站的文件和资源进行优化?期待的解决方案包括:

  文件合并

  文件小化/文件压缩

  使用CDN托管

  缓存的使用

16.什么是语义化的HTML?

  直观的认识标签??对于搜索引擎的抓取有好处

  17.清除浮动的几种方式,各自的优缺点

  1.使用空标签清除浮动 clear:both(理论上能清楚任何标签,,,增加无意义的标签)

  2.使用overflow:auto(空标签元素清除浮动而不得不增加无意代码的弊端,,使用zoom:1用于兼容IE)

  3.是用afert伪元素清除浮动(用于非IE浏览器)

  Javascript

  1.javascript的typeof返回哪些数据类型

  Object number function boolean underfind

  2.例举3种强制类型转换和2种隐式类型转换?

  强制(parseInt,parseFloat,number)

  隐式(== - ===)

  3.split() join() 的区别

  前者是切割成数组的形式,后者是将数组转换成字符串

  4.数组方法pop() push() unshift() shift()

  Push()尾部添加 pop()尾部删除

  Unshift()头部添加??shift()头部删除

  5.事件绑定和普通事件有什么区别

  6.IE和DOM事件流的区别

  1.执行顺序不一样、

  2.参数不一样

  3.事件加不加on

  4.this指向问题

  7.IE和标准下有哪些兼容性的写法

  Var ev = ev || window.event

  document.documentElement.clientWidth || document.body.clientWidth

  Var target = ev.srcElement||ev.target

  8.ajax请求的时候get 和post方式的区别

  一个在url后面 一个放在虚拟载体里面

  有大小限制

  安全问题

  应用不同 一个是论坛等只需要请求的,一个是类似修改密码的

  9.call和apply的区别

  Object.call(this,obj1,obj2,obj3)

  Object.apply(this,arguments)

  10.ajax请求时,如何解释json数据

  使用eval parse 鉴于安全性考虑 使用parse靠谱

  11.b继承a的方法

  12.写一个获取非行间样式的函数

  1.function getStyle(obj,attr,value)
  2.
  3.{
  4.
  5.if(!value)
  6.
  7.{
  8.
  9.if(obj.currentStyle)
  10.
  11. {
  12.
  13.return obj.currentStyle(attr)
  14.
  15.}
  16.
  17. else
  18.
  19.{
  20.
  21.obj.getComputedStyle(attr,false)
  22.
  23.}
  24.
  25.}
  26.
  27.else
  28.

  29.{
  30.
  31.obj.style[attr]=value
  32.
  33.}
  34.
  35.}

  复制代码

  13.事件委托是什么

  让利用事件冒泡的原理,让自己的所触发的事件,让他的父元素代替执行!

  14.闭包是什么,有什么特性,对页面有什么影响

  闭包就是能够读取其他函数内部变量的函数。

  15.如何阻止事件冒泡和默认事件

  canceBubble? ?return false

  16.添加 删除 替换 插入到某个接点的方法

  obj.appendChidl()

  obj.innersetBefore

  obj.replaceChild

  obj.removeChild

  17.解释jsonp的原理,以及为什么不是真正的ajax

  动态创建script标签,回调函数

  Ajax是页面无刷新请求数据操作


  18.javascript的本地对象,内置对象和宿主对象

  本地对象为array obj regexp等可以new实例化

  内置对象为gload Math 等不可以实例化的

  宿主为浏览器自带的document,window 等

  19.document load 和document ready的区别

  Document.onload 是在结构和样式加载完才执行js

  Document.ready原生种没有这个方法,jquery中有 $().ready(function)

  20.”==”和“===”的不同

  前者会自动转换类型

  后者不会

  21.javascript的同源策略

  一段脚本只能读取来自于同一来源的窗口和文档的属性,这里的同一来源指的是主机名、协议和端口号的组合

  22.编写一个数组去重的方法

  1.function oSort(arr)
  2.
  3.{
  4.
  5.var result ={};
  6.
  7.var newArr=[];
  8.
  9.for(var i=0;i<arr.length;i++)
  10.
  11.{
  12.
  13. if(!result[arr[i]])
  14.
  15. {
  16.
  17.newArr.push(arr[i])
  18.
  19.result[arr[i]]=1
  20.
  21. }
  22.
  23.}
  24.
  25.return newArr
  26.
  27.}

  复制代码

  23.排序算法
  1.快速排序function oSort(arr)

  2.
  3.{
  4.
  5.if(arr.length<=1)
  6.
  7.{
  8.
  9. return arr
  10.
  11.}
  12.
  13.var left=[];
  14.
  15.var right=[];
  16.
  17.var oNum = Math.floor(arr.length/2);
  18.
  19.var oNumVode = arr.splice(oNum,1);
  20.
  21.for(var i=0;i<arr.length;i++)
  22.
  23.{
  24.
  25.if(arr[i]<oNumVode)
  26.
  27. {
  28.
  29.left.push(arr[i])
  30.
  31.}
  32.
  33.else
  34.
  35. {
  36.
  37.right.push(arr[i])
  38.
  39.}
  40.
  41.}
  42.
  43.return oSort(left).concat([oNumVode],oSort(right))
  44.
  45.}
  46.
  47.冒泡排序 var array = [5, 4, 3, 2, 1];
  48.
  49.var temp = 0;
  50.
  51.for (var i = 0; i < array.length; i++)
  52.
  53.{
  54.
  55.for (var j = 0; j < array.length - i; j++)
  56.
  57.{
  58.
  59.if (array[j] > array[j + 1])
  60.
  61.{
  62.
  63.temp = array[j + 1];
  64.
  65.array[j + 1] = array[j];
  66.
  67.array[j] = temp;

  68.
  69.}
  70.
  71.}
  72.
  73.}

上一篇:HTML5工程师如何提高面试成功率
下一篇:HTML5前端培训:怎样跳槽才能跳得“高”

新开班New

  • 广州地址:广州市天河区元岗路310号智汇park创意园E座5层
    咨询电话:020-22119207 400-654-7778
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训
  • 北京天丰利校区:北京市海淀区宝盛北里西区28号天丰利商城4层
    北京沙河校区:北京市昌平区沙阳路18号北京科技职业技术广场服务楼2层、南区服务楼2层
    咨询电话:400-654-7778 010-82790226-801
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训、UI课程培训、好程序员特训营
  • 深圳西部硅谷校区:深圳市宝安区宝安大道5010号西部硅谷B座A605-619
    深圳科技园校区:广东省深圳市南山区高新技术产业园R3栋B5楼
    深圳大学城校区:深圳市南山区留仙大道1201号大学城创客小镇16栋2楼、3楼
    咨询电话:0755-86681178/9-801
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训、UI课程培训、PHP培训、JavaEE培训、好程序员特训营
  • 上海地址:上海市宝山区同济支路199号智慧七立方3号楼2-4层
    咨询电话:400-627-7899 021-65025129-602
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训、UI课程培训、好程序员特训营
  • 郑州地址:郑州市金水区纬五路21号河南教育综合楼(经纬中学楼)6/7/8层
    咨询电话:0371-55911950 400-654-7778
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训、UI课程培训
  • 大连地址:大连市高新园区软件园路2号B8座
    咨询电话:0411-39026086 400-654-7778
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训
  • 武汉地址:武汉市东新区光谷大道77号金融港B26栋9楼
    咨询电话:027-59905902 027-59905908 027-59905909
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训
  • 成都旅游校区:成都市一环路西二段17号四川旅游青羊校区内
    成都华立校区:成都一环路西二段17号华立大厦3楼
    咨询电话:028-83178771 028-61967740
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训、UI课程培训
  • 西安地址:西安市二环南路西段60号永安大厦4层
    西安科技园校区:西安市雁塔区高新六路52号立人科技园C座西区4层
    咨询电话:029-85260160 029-85261030 029-85260960
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训
  • 杭州地址:浙江省杭州市江干区九堡旺田书画城A座4层
    咨询电话:0571-86893632 010-82790226/7-801
    面授课程:iOS课程培训、Android课程培训
  • 青岛校区地址:青岛市市南区金坛路17号青岛职业技术南校区实训楼A4层
    咨询电话:0532-80910752/3 010-82790226/7-801
    面授课程:iOS课程培训、Android课程培训、HTML5课程培训、UI课程培训
  • 了解千锋动态
    关注千锋教育服务号

  • 扫码匿名提建议
    直达CEO信箱