web前端开发面试题汇总

web前端开发面试题汇总

2023年6月28日发(作者:)

web前端开发面试题汇总

web前端开发面试题汇总

1天前653浏览2评论

前端面试题汇总

HTML&CSS

1. 常用那几种浏览器测试?有哪些核(Layout Engine)?

(Q1) 浏览器:IE,Chrome,FireFox,Safari,Opera。

(Q2) 核:Trident,Gecko,Presto,Webkit。

2. 说下行元素和块级元素的区别?行块元素的兼容性使用?

(IE8 以下)

行元素:会在水平方向排列,不能包含块级元素,设置width无效,height无效(可以设置line-height),margin上下无效,padding上下无效。

块级元素:各占据一行,垂直方向排列。从新行开始结束接着一个断行。

兼容性:display:inline-block;display:inline;zoom:1;

3. 清除浮动有哪些方式?比较好的方式是哪一种?

(1)父级div定义height。

(2)结尾处加空div标签clear:both。

(3)父级div定义伪类:after和zoom。

(4)父级div定义overflow:hidden。

(5)父级div定义overflow:auto。

(6)父级div也浮动,需要定义宽度。

(7)父级div定义display:table。

(8)结尾处加br标签clear:both。

总结:比较好的是第3种方式,简洁方便。

4. box-sizing常用的属性有哪些?分别有什么作用?

常用的属性:box-sizing: content-box border-box inherit;

作用:content-box:宽度和高度分别应用到元素的容框。在宽度和高度之外绘制元素的边距和边框(元素默认效果)。

border-box:元素指定的任何边距和边框都将在已设定的宽度和高度进行绘制。通过从已设定的宽度和高度分别减去边框和边距才能得到容的宽度和高度。

5. Doctype作用?标准模式与兼容模式各有什么区别?

(Q1) 告知浏览器的解析器用什么文档标准解析这个文档。DOCTYPE不存在或格式不正确会导致文档以兼容模式呈现。

(Q2) 标准模式的排版和JS运作模式都是以该浏览器支持的最高标准运行。在兼容模式中,页面以宽松的向后兼容的方式显示,模拟老式浏览器的行为以防止站点无法工作。

6. HTML5 为什么只需要写< Doctype html>?

HTML5不基于 SGML,因此不需要对DTD进行引用;但是需要doctype来规浏览器的行为(让浏览器按照它们应该的方式来运行)。而HTML4.01基于SGML,所以需要对DTD进行引用,才能告知浏览器文档所使用的文档类型。

7. 页面导入样式时,使用link和import有什么区别?

(1)link属于XHTML标签,除了加载CSS外,还能用于定义RSS, 定义rel 连接属性等作用;而import是CSS提供的,只能用于加载CSS;

(2)页面被加载的时,link会同时被加载,而import引用的CSS会等到页面被加载完再加载;

(3)import是CSS2.1 提出的,只在IE5以上才能被识别,而link是XHTML 标签,无兼容问题。

总之,link要优于import。

8. 介绍一下你对浏览器核的理解?

IE浏览器的核Trident、Mozilla的Gecko、Chrome的Blink(WebKit的分支)、Opera核原为Presto

,现为Blink;

核主要分成两部分:

渲染引擎(layout engineer或Rendering Engine)和JS引擎 渲染引擎:负责取得网页的容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,然后会输出至显示器或打印机。浏览器的核的不同对于网页的语法解释会有不同,所以渲染的效果也不相同。

所有网页浏览器、电子客户端以及其它需要编辑、显示网络容的应用程序都需要核。

JS引擎则:解析和执行javascript来实现网页的动态效果。最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独立,核就倾向于只指渲染引擎。

9. html5有哪些新特性?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?

(Q1) HTML5 现在已经不是 SGML 的子集,主要是关于图像,位置,存储,多任务等功能的增加。

(1)绘画 canvas;

(2)用于媒介回放的 video 和 audio 元素;

(3)本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失;

(4)sessionStorage 的数据在浏览器关闭后自动删除;

(5)语意化更好的容元素,比如 article、footer、header、nav、section; (6)表单控件,calendar、date、time、email、url、search;

(7)新的技术webworker, websocket, Geolocation;

(Q2) IE8/IE7/IE6支持通过Element方法产生的标签,可以利用这一特性让这些浏览器支持HTML5新标签,浏览器支持新标签后,还需要添加标签默认的样式。也可以直接使用成熟的框架、比如html5shim,

10. 简述一下你对HTML语义化的理解?

用正确的标签做正确的事情。

语义化让页面的容结构化,结构更清晰,便于对浏览器、搜索引擎

解析; 2.即使在没有样式CSS情况下也以一种文档格式显示,并且是容易阅读的;

搜索引擎的爬虫也依赖于HTML标记来确定上下文和各个关键字的权重,利于SEO;

3.使阅读源代码的人对更容易将分块,便于阅读维护理解。

11 ##常见兼容性问题?

png24位的图片在iE6浏览器上出现背景,解决方案是做成PNG8.

浏览器默认的margin和padding不同。解决方案是加一个全局的

{margin:0;padding:0;}来统一。IE6双边距bug:块属性标签float后,又有横行的margin情况下,在ie6显示margin比设置的大。浮动ie产生的双倍距

离#box{ float:left; width:10px; margin:0 0 0 100px;}

这种情况之下IE会产生20px的距离,解决方案是在float的标签样式控制中加入——_display:inline;将其转化为行属性。(_这个符号只有ie6会识

别) 渐进识别的方式,从总体中逐渐排除局部。

首先,巧妙的使用“9”这一标记,将IE游览器从所有情况中分离出来。接着,再次使用“+”将IE8和IE7、IE6分离开来,这样IE8已经独立识

别。css .bb{

background-color:#f1ee18;/所有识别

/ .background-color:#00deff9; /IE6、7、8识别

/ +background-color:#a200ff;/IE6、7识别

/ _background-color:#1e0bd1;/IE6识别

/ }

IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义属性;Firefox下,只能使用getAttribute()获取自

定义属性. 解决方法:统一通过getAttribute()获取自定义属性. IE 下,even对象有x,y属性,但是没有pageX,pageY属性; Firefox下,event对象有pageX,pageY属性,但是没有x,y属性.

解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。Chrome 中文界面下默认会将小于12px 的文本强制按照12px 显

示, 可通过加入CSS 属性-webkit-text-size-adjust: none; 解决.

超访问过后hover样式就不出现了被点击访问过的超样式不在具有hover和active了解决方法是改变CSS属性的排列顺

序:L-V-H-A : a:link {} a:visited {} a:hover {} a:active {}

5的离线储存,描述一下 cookies,sessionStorage 和

localStorage 的区别?

cookie在浏览器和服务器间来回传递。 sessionStorage和localStorage 不会

sessionStorage和localStorage的存储空间更大;

sessionStorage和localStorage有更多丰富易用的接口;

sessionStorage和localStorage各自独立的存储空间;

CSS一、介绍一下CSS的盒子模型?

(1)有两种, IE 盒子模型、标准 W3C 盒子模型;IE的content部分包含了 border 和 pading;

(2)盒模型:容(content)、填充(padding)、边界(margin)、边框(border).

二、 CSS 选择符有哪些?哪些属性可以继承?优先级算法如何计算?

新增伪类有那些?

选择器( # myid)

2.类选择器(.myclassname)

3.标签选择器(div, h1, p)

4.相邻选择器(h1 + p)

5.子选择器(ul > li)

6.后代选择器(li a) 7.通配符选择器( * )

8.属性选择器(a[rel = "external"])

9.伪类选择器(a: hover, li: nth - child)

可继承的样式:

font-size font-family color, UL LI DL DD DT;

不可继承的样式:

border padding margin width height

优先级就近原则,同权重情况下样式定义最近者为准;

载入样式以最后载入的定位为准;

优先级为: !important > id > class > tag ,important 比联优先级高

三、 CSS3新增伪类举例

p:first-of-type 选择属于其父元素的首个

元素的每个

元素。p:last-of-type 选择属于其父元素的最后

元素的每个

元素。

p:only-of-type 选择属于其父元素唯一的

元素的每个

元素。

p:only-child 选择属于其父元素的唯一子元素的每个

元素。

p:nth-child(2) 选择属于其父元素的第二个子元素的每个

元素。

:enabled :disabled 控制表单控件的禁用状态。

:checked 单选框或复选框被选中。

四、如何居中div?如何居中一个浮动元素?

水平居中:

给div设置一个宽度,然后添加margin:0 auto属性

div{width:200px; margin:0 auto; } 垂直居中:

确定容器的宽高:如宽500 高 300 的层

设置层的外边距

.div { Width:500px height:300px;//高度可以不设

Margin: -150px 0 0 -250px; position:relative;相对定位background-color:pink;//方便看效果

left:50%; top:50%;}

五、列出display的值,说明他们的作用。position

的值, relative和absolute定位原点是

象块类型元素一样显示。

none 缺省值。象行元素类型一样显示。

inline-block 象行元素一样显示,但其容象块类型元素一样显示。

list-item 象块类型元素一样显示,并添加样式列表标记。

2.

absolute 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。

fixed (老IE不支持)生成绝对定位的元素,相对于浏览器窗口进行定位。

relative生成相对定位的元素,相对于其正常位置进行定位。?static 默认值。没有定位,元素出现在正常的流中(忽略 top,

bottom, left, right z-index 声明)

inherit 规定从父元素继承 position 属性的值。六、 CSS3有哪些新特性 ##?

CSS3实现圆角(border-radius:8px),

发布者:admin,转转请注明出处:http://www.yc00.com/news/1687887647a54057.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信