史上最全前端⾯试题(含答案)-A篇
HTML+CSS
1.对WEB标准以及W3C的理解与认识
spring中的注解标签闭合、标签⼩写、不乱嵌套、提⾼搜索机器⼈搜索⼏率、使⽤外链css和js脚本、结构⾏为表现的分离、⽂件下载与页⾯速度更快、内容能被更多的⽤户所访问、内容能被更⼴泛的设备所访问、更少的代码和组件,容易维护、改版⽅便,不需要变动页⾯内容、提供打印版本⽽不需要复制内容、提⾼⽹站易⽤性;
shell是什么在哪里用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;……}
amaze ui 模板
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.标签上title与alt属性的区别是什么?
Alt 当图⽚不显⽰是⽤⽂字代表。
Title 为该属性提供信息
12.描述css reset的作⽤和⽤途。
Reset重置浏览器的css默认属性浏览器的品种不同,样式不同,然后重置,让他们统⼀
13.解释css sprites,如何使⽤。
Css 精灵把⼀堆⼩的图⽚整合到⼀张⼤的图⽚上,减轻服务器对图⽚的请求数量
14.浏览器标准模式和怪异模式之间的区别是什么?
盒⼦模型渲染模式的不同
使⽤ p.documentpatMode 可显⽰为什么模式
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.写⼀个获取⾮⾏间样式的函数
function getStyle(obj,attr,value)
{
if(!value)
{
if(obj.currentStyle)
{
return obj.currentStyle(attr)
}
else
{
}
web前端基础面试题}
else
{
obj.style[attr]=value
}
}
13.事件委托是什么
让利⽤事件冒泡的原理,让⾃⼰的所触发的事件,让他的⽗元素代替执⾏!
www.webasily/?p=78 例⼦可见此链接
14.闭包是什么,有什么特性,对页⾯有什么影响
闭包就是能够读取其他函数内部变量的函数。
blog.csdn/gaoshanwudi/article/details/7355794 此链接可查看(问这个问题的不是⼀个公司)15.如何阻⽌事件冒泡和默认事件
canceBubble return false
16.添加删除替换插⼊到某个接点的⽅法
obj.appendChidl()
obj.innersetBefore
17.解释jsonp的原理,以及为什么不是真正的ajax
动态创建script标签,回调函数
Ajax是页⾯⽆刷新请求数据操作
素数python编程18.javascript的本地对象,内置对象和宿主对象
本地对象为array obj regexp等可以new实例化
内置对象为gload Math 等不可以实例化的
宿主为浏览器⾃带的document,window 等
19.document load 和document ready的区别
20.”==”和“===”的不同
前者会⾃动转换类型
simulink和matlab什么关系后者不会
21.javascript的同源策略
⼀段脚本只能读取来⾃于同⼀来源的窗⼝和⽂档的属性,这⾥的同⼀来源指的是主机名、协议和端⼝号的组合22.编写⼀个数组去重的⽅法
function oSort(arr)
{
var result ={};
var newArr=[];
for(var i=0;i
{
if(!result[arr])
{
newArr.push(arr)
result[arr]=1
}
}
return newArr
}
来⾃IT公司⾯试⼿册
[HTML && CSS]1.Doctype严格模式与混杂模式-如何触发这两种模式,区分它们有何意义?
严格模式:使⽤此类型的⽹页,浏览器解析将相对严格,不允许使⽤任何表现样式的标识和属性,⽐如在元素中直接使⽤background-color 背景⾊属性。
混杂模式:浏览器对XHTML的解析较为宽松。允许使⽤4.01中的标签,但必须符合XHTML的语法。
2:⾏内元素有哪些?块级元素有哪些?CSS的盒模型?
⾏内元素:span,a,var ,em,input,img,img,textarea,var,em,strong,select,
块级标签:div,p,h1-h3,ul,ol,dl,li,dd,dt,table,td,tr,
CSS的盒模型:CSS布局中的每⼀个元素,在浏览器的解析中,都被当做⼀个盒状物。
3.CSS引⼊的⽅式有哪些? link和@import的区别是?
CSS引⼊的⽅式
在html⽂档的head部分加⼊:
在html⽂档的head部分直接写⼊css⽂档。
直接在html标签⾥写⼊对这个标签的css控制
测试信息
link和@import的区别是link写在html页⾯中,@import写在CSS页⾯中
4.CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级⾼?
CSS选择符: 类选择器、标签名选择器、 ID选择器、后代选择器(派⽣选择器)、组选择器
可以继承:类选择器、标签名选择器、后代选择器(派⽣选择器)、组选择器
优先级算法:
标签内直接定义:1000
ID选择器:100
类选择器:10
标签名选择器:1
内联和important中,important优先级⾼
5:前端页⾯有哪三层构成,分别是什么?作⽤是什么?
结构层;主要指DOM节点;HTML/XHTML
样式层;主要是指页⾯渲染;CSS
脚本层:主要指页⾯动画效果;JS/AS
6:css的基本语句构成是?
选择符、属性、值
8:你做的页⾯在哪些流览器测试过?这些浏览器的内核分别是什么?经常遇到的浏览器的兼容性有哪些?怎么会出现?解决⽅法是什么?
IE6、7、8、FF、Opear、Safari、Chrome、Maxthon
Trident:Windows 下的 IE 浏览器使⽤的内核代号。除 IE 外,众多的 IE Shell(如 Maxthon )都使⽤这个内核。
Gecko:Mozilla Firefox 浏览器使⽤的内核代号。
Presto:Opera 浏览器使⽤的内核代号,这是⽬前公认⽹页浏览速度最快的浏览器内核。
KHTML/WebCore: Konqueror/Safari 浏览器使⽤的内核代号。
经常遇到的浏览器兼容问题:
1.在有的浏览器中,默认字体⼤⼩为12px,所以在设字体⼤⼩的时候,最⼩设为12px,如果在做的过程中,发现字体⼩于12,可直接作为图⽚使⽤
2.a标签对⾥不能嵌套a标签对
3.若给a标签内的内容样式加上样式,需要设置display:block;(在IE中如果设置宽⾼会⾃动变成块,在FF中则不会),但如果设置了float属性,就不需要设置display:block。
4.ul,ol在FF默认情况下,有list-style-type样式和padding值,dl在IE和FF默认情况下,有padding值,所以应该事先声明
ul,li,ol,dl,dd,dd{margin:0;padding:0}。
5.作为外部 wrapper 的 div 不要定死⾼度, 最好还加上 overflow: hidden.以达到⾼度⾃适应
6.关于⼿形光标. cursor: pointer. ⽽hand 只适⽤于 IE.
7.css布局中的居中问题:在⽗级元素定义TEXT-ALIGN: center;这个的意思就是在⽗级元素内的内容居中;对于IE这样设定就已经可以了。但在mozilla中不能居中。解决办法就是在⼦元素定义时候设定时再加上“margin-right: auto;margin-left: auto; ”需要说明的是,如果你想⽤这个⽅法使整个页⾯要居中,建议不要套在⼀个DIV⾥,你可以依次拆出多个div,只要在每个拆出的div⾥定义margin-right: auto;margin-left: auto; 就可以了。
8.浮动ie产⽣的双倍距离
#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属性值。
div{margin: 0;padding: 0;border:1px red solid;}
2.怎样添加、移除、移动、复制、创建和查节点
添加:append
删除:remove
移动:
复制:
创建:create
查:
(1)创建新节点
createDocumentFragment() //创建⼀个DOM⽚段
createElement_x_x() //创建⼀个具体的元素
createTextNode() //创建⼀个⽂本节点
(2)添加、移除、替换、插⼊
a()
removeChild()
replaceChild()
insertBefore()
(3)查
getElementsByTagName_r() //通过标签名称
getElementsByName() //通过元素的Name属性的值
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论