当前位置: 主页 > 前端开发

web前端兼容性面试题-web前端浏览器兼容

发布时间:2023-03-09 21:04   浏览次数:次   作者:佚名

如果想进一步了解相关知识,可以 google 答案中的关键词,或者到SegmentFault 问答平台交流。

HTML

Doctype作用? 严格模式与混杂模式如何区分?它们有何意义?

声明位于文档中的最前面,处于标签之前。告知浏览器的解析器, 用什么文档类型 规范来解析这个文档。

严格模式的排版和 JS 运作模式是以该浏览器支持的最高标准运行。

在混杂模式中,页面以宽松的向后兼容的方式显示。模拟老式浏览器的行为以防止站点无法工作。

DOCTYPE不存在或格式不正确会导致文档以混杂模式呈现。

行内元素有哪些?块级元素有哪些? 空(void)元素有那些?

CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值, 比如div默认display属性值为“block”,成为“块级”元素; span默认display属性值为“inline”,是“行内”元素。

行内元素有:a b span img input select strong(强调的语气)

块级元素有:div ul ol li dl dt dd h1 h2 h3 h4…p

知名的空元素:

鲜为人知的是:

link 和@import 的区别是?

link属于XHTML标签,而@import是CSS提供的;

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

import只在IE5以上才能识别,而link是XHTML标签,无兼容问题;

link方式的样式的权重 高于@import的权重.

浏览器的内核分别是什么?

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

常见兼容性问题?

html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?

语义化的理解?

用正确的标签做正确的事情! html语义化就是让页面的内容结构化,便于对浏览器、搜索引擎解析; 在没有样式CCS情况下也以一种文档格式显示,并且是容易阅读的。 搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于 SEO。 使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解。

HTML5的离线储存?

描述一段语义的html代码吧。

web前端兼容性面试题_web前端浏览器兼容_web前端面试笔试题

(HTML5中新增加的很多标签(如:

、、和等) 就是基于语义化设计原则)

< div id="header"> 
< h1>标题< /h1> < h2>专注Web前端技术< /h2> < /div> 

iframe有那些缺点?

请描述一下 cookies,sessionStorage 和 localStorage 的区别?

CSS

介绍一下CSS的盒子模型?

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

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

CSS 选择符有哪些?哪些属性可以继承?优先级算法如何计算? CSS3新增伪类有那些?

选择器:

1.id选择器( # 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 ;

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

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

web前端浏览器兼容_web前端兼容性面试题_web前端面试笔试题

优先级为:

!important >  id > class > tag  
    important 比 内联优先级高

CSS3新增伪类举例:

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

列出display的值,说明他们的作用。position的值, relative和absolute定位原点是?

CSS3有哪些新特性?

为什么要初始化CSS样式。

对BFC规范的理解?

W3C CSS 2.1 规范中的一个概念,它决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用。

css定义的权重

以下是权重的规则:标签的权重为1,class的权重为10,id的权重为100web前端兼容性面试题,以下例子是演示各种定义的权重值:


/*权重为1*/ div{ } /*权重为10*/ .class1{ } /*权重为100*/ #id1{ } /*权重为100+1=101*/ #id1 div{ } /*权重为10+1=11*/ .class1 div{ } /*权重为10+10+1=21*/ .class1 .class2 div{ }

如果权重相同,则最后定义的样式会起作用,但是应该避免这种情况出现

JavaScript

eval是做什么的?

它的功能是把对应的字符串解析成JS代码并运行; 应该避免使用eval,不安全,非常耗性能(2次,一次解析成js语句,一次执行)。

写一个通用的事件侦听器函数。

        // event(事件)工具集,来源:github.com/markyun
        markyun.Event = {
            // 页面加载完成后

web前端面试笔试题_web前端浏览器兼容_web前端兼容性面试题

readyEvent : function(fn) { if (fn==null) { fn=document; } var oldonload = window.onload; if (typeof window.onload != 'function') { window.onload = fn; } else { window.onload = function() { oldonload(); fn(); }; } }, // 视能力分别使用dom0||dom2||IE方式 来绑定事件 // 参数: 操作的元素,事件名称 ,事件处理程序 addEvent : function(element, type, handler) { if (element.addEventListener) { //事件类型、需要执行的函数、是否捕捉 element.addEventListener(type, handler, false); } else if (element.attachEvent) { element.attachEvent('on' + type, function() { handler.call(element); }); } else { element['on' + type] = handler; } }, // 移除事件 removeEvent : function(element, type, handler) { if (element.removeEnentListener) { element.removeEnentListener(type, handler, false); } else if (element.datachEvent) { element.detachEvent('on' + type, handler); } else { element['on' + type] = null; } }, // 阻止事件 (主要是事件冒泡,因为IE不支持事件捕获) stopPropagation : function(ev) { if (ev.stopPropagation) { ev.stopPropagation(); } else { ev.cancelBubble = true; } }, // 取消事件的默认行为 preventDefault : function(event) { if (event.preventDefault) { event.preventDefault(); } else { event.returnValue = false; } }, // 获取事件目标 getTarget : function(event) { return event.target || event.srcElement; }, // 获取event对象的引用,取到事件的所有信息,确保随时能使用event; getEvent : function(e) { var ev = e || window.event; if (!ev) { var c = this.getEvent.caller; while (c) { ev = c.arguments[0]; if (ev && Event == ev.constructor) { break; } c = c.caller; } } return ev; } }; ```

Node.js的适用场景?

高并发、聊天、实时消息推送

介绍js的基本数据类型。

number,string,boolean,object,undefined

Javascript如何实现继承?

通过原型和构造器

["1", "2", "3"].map(parseInt) 答案是多少?

[1, NaN, NaN]因为 parseInt 需要两个参数 (val, radix) 但 map 传了 3 个 (element, index, array)

如何创建一个对象? (画出此对象的内存图)

function Person(name, age) { this.name = name; this.age = age; this.sing = function() { alert(this.name) } } 

谈谈This对象的理解。

this是js的一个关键字,随着函数使用场合不同,this的值会发生变化。 但是有一个总原则,那就是this指的是调用函数的那个对象。 this一般情况下:是全局对象Global。 作为方法调用,那么this就是指这个对象

事件是?IE与火狐的事件机制有什么区别? 如何阻止冒泡?

我们在网页中的某个操作(有的操作对应多个事件)。例如:当我们点击一个按钮就会产生一个事件。是可以被 JavaScript 侦测到的行为。事件处理机制:IE是事件冒泡、火狐是 事件捕获;ev.stopPropagation();

什么是闭包(closure),为什么要用它?

执行say667()后,say667()闭包内部变量会存在,而闭包内部函数的内部变量不会存在.使得Javascript的垃圾回收机制GC不会收回say667()所占用的资源,因为say667()的内部函数的执行需要依赖say667()中的变量。这是对闭包作用的非常直白的描述.

function say667() { // Local variable that ends up within closure var num = 666; var sayAlert = function() { alert(num); } num++; return sayAlert; } var sayAlert = say667(); sayAlert()//执行结果应该弹出的667 

"use strict";是什么意思 ? 使用它的好处和坏处分别是什么?

如何判断一个对象是否属于某个类?

使用instanceof (待完善)

 if(a instanceof Person){
     alert('yes');
 }

web前端面试笔试题_web前端兼容性面试题_web前端浏览器兼容

new操作符具体干了什么呢?

创建一个空对象,并且 this 变量引用该对象,同时还继承了该函数的原型。属性和方法被加入到 this 引用的对象中。新创建的对象由 this 所引用,并且最后隐式的返回 this 。

var obj  = {};
obj.__proto__ = Base.prototype;
Base.call(obj); 

Javascript中,有一个函数,执行时对象查找时,永远不会去查找原型,这个函数是?

hasOwnProperty

JSON 的了解?

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 它是基于JavaScript的一个子集。数据格式简单, 易于读写, 占用带宽小

{'age':'12', 'name':'back'}

js延迟加载的方式有哪些?

defer和async、动态创建DOM方式(用得最多)、按需异步载入js

如何解决跨域问题?

jsonp、 iframe、window.name、window.postMessage、服务器上设置代理页面

模块化怎么做?

立即执行函数,不暴露私有成员

var module1 = (function(){     var _count = 0;     var m1 = function(){       //...     };     var m2 = function(){       //...     };     return {       m1 : m1,       m2 : m2     }; })(); 

异步加载的方式有哪些?

defer,只支持IE

async:

创建script,插入到DOM中,加载完毕后callBack

documen.write和 innerHTML的区别

.call() 和 .apply() 的区别?

web前端浏览器兼容_web前端面试笔试题_web前端兼容性面试题

例子中用 add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运行结果为:alert(4);

注意:js 中的函数其实是对象,函数名是对 Function 对象的引用。

function add(a,b)
{
    alert(a+b);
}
function sub(a,b)
{
    alert(a-b);
}
add.call(sub,3,1);  

Jquery与jQuery UI 有啥区别?

jquery 中如何将数组转化为json字符串,然后再转化回来?

jQuery中没有提供这个功能web前端兼容性面试题,所以你需要先编写两个jQuery的扩展:

$.fn.stringifyArray = function(array) {
    return JSON.stringify(array) } $.fn.parseArray = function(array) { return JSON.parse(array) } 

然后调用:

$("").stringifyArray(array)

针对 jQuery 的优化方法?

那些操作会造成内存泄漏?

内存泄漏指任何对象在您不再拥有或需要它之后仍然存在。 垃圾回收器定期扫描对象,并计算引用了每个对象的其他对象的数量。如果一个对象的引用数量为 0(没有其他对象引用过该对象),或对该对象的惟一引用是循环的,那么该对象的内存即可回收。

setTimeout 的第一个参数使用字符串而非函数的话,会引发内存泄漏。

闭包、控制台日志、循环(在两个对象彼此引用且彼此保留时,就会产生一个循环)