Web前端面试题目及答案汇总_答题前端web汇总怎么做,程序员面试题精选100题

96 阅读7分钟

// 3、选择符Hack

  • html .test{color:#090;} /* For IE6 and earlier */

    • html .test{color:#ff0;} /* For IE7 */

**6、简述同步和异步的区别**


同步是阻塞模式,异步是非阻塞模式。


同步就是指一个进程在执行某个请求的时候,若该请求需要一段时间才能返回信息,那么这个进程将会一直等待下去,直到收到返回信息才继续执行下去;


异步是指进程不需要一直等下去,而是继续执行下面的操作,不管其他进程的状态。当有消息返回时系统会通知进程进行处理,这样可以提高执行的效率。


**7pxem的区别**


pxem都是长度单位,区别是,px的值是固定的,指定是多少就是多少,计算比较容易。em得值不是固定的,并且em会继承父级元素的字体大小。


浏览器的默认字体高都是16px。所以未经调整的浏览器都符合: 1em=16px。那么12px=0.75em, 10px=0.625em


**8、什么叫优雅降级和渐进增强?**


渐进增强 progressive enhancement:


针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。


优雅降级 graceful degradation:


一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。


区别:


a. 优雅降级是从复杂的现状开始,并试图减少用户体验的供给


b. 渐进增强则是从一个非常基础的,能够起作用的版本开始,并不断扩充,以适应未来环境的需要


c. 降级(功能衰减)意味着往回看;而渐进增强则意味着朝前看,同时保证其根基处于安全地带


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


IE: trident内核


Firefoxgecko内核


Safariwebkit内核


Opera:以前是presto内核,Opera现已改用Google ChromeBlink内核


ChromeBlink(基于webkit,Google与Opera Software共同开发)


**[JavaScript]( )部分**


**1、怎样添加、移除、移动、复制、创建和查找节点?**


1)创建新节点


createDocumentFragment() //创建一个DOM片段


createElement() //创建一个具体的元素


createTextNode() //创建一个文本节点


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


appendChild() //添加


removeChild() //移除


replaceChild() //替换


insertBefore() //插入


3)查找


getElementsByTagName() //通过标签名称


getElementsByName() //通过元素的Name属性的值


getElementById() //通过元素Id,唯一性


**2、实现一个函数clone,可以对[Java]( )Script中的5种主要的数据类型(包括Number、String、Object、Array、Boolean)进行值复制。**



/**

  • 对象克隆

  • 支持基本数据类型及对象

  • 递归方法

*/

function clone(obj) {

var o;

switch (typeof obj) {

case "undefined":

break;

case "string":

o = obj + "";

break;

case "number":

o = obj - 0;

break;

case "boolean":

o = obj;

break;

case "object": // object 分为两种情况 对象(Object)或数组(Array)

if (obj === null) {

o = null;

} else {

if (Object.prototype.toString.call(obj).slice(8, -1) === "Array") {

o = [];

for (var i = 0; i obj.length; i++) {

o.push(clone(obj[i]));

}

} else {

o = {};

for (var k in obj) {

o[k] = clone(obj[k]);

}

}

}

break;

default:

o = obj;

break;

}

return o;

}


**3、如何消除一个数组里面重复的元素?**



// 方法一:

var arr1 =[1,2,2,2,3,3,3,4,5,6],

arr2 = [];

for(var i = 0,len = arr1.length; i< len; i++){

if(arr2.indexOf(arr1[i]) < 0){

arr2.push(arr1[i]);

}

}

document.write(arr2); // 1,2,3,4,5,6


**4、想实现一个对页面某个节点的拖曳?如何做?**


使用原生JS


**5、在Javascript中什么是伪数组?如何将伪数组转化为标准数组?**


伪数组(类数组):无法直接调用数组方法或期望length属性有什么特殊的行为,但仍可以对真正数组遍历方法来遍历它们。典型的是函数的argument参数,还有像调用getElementsByTagName,document.childNodes之类的,它们都返回NodeList对象都属于伪数组。可以使用Array.prototype.slice.call(fakeArray)将数组转化为真正的Array对象。



function log(){

var args = Array.prototype.slice.call(arguments);

//为了使用unshift数组方法,将argument转化为真正的数组

args.unshift('(app)');

console.log.apply(console, args);

};


**6、Javascript中callee和caller的作用?**


caller是返回一个对函数的引用,该函数调用了当前函数;


callee是返回正在被执行的function函数,也就是所指定的function对象的正文。


**7、请描述一下cookies,sessionStorage和localStorage的区别**


sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。而localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。


web storage和cookie的区别


Web Storage的概念和cookie相似,区别是它是为了更大容量存储设计的。Cookie的大小是受限的,并且每次你请求一个新的页面的时候Cookie都会被发送过去,这样无形中浪费了带宽,另外cookie还需要指定作用域,不可以跨域调用。


除此之外,Web Storage拥有setItem,getItem,removeItem,clear等方法,不像cookie需要[前端开发]( )者自己封装setCookie,getCookie。但是Cookie也是不可以或缺的:Cookie的作用是与服务器进行交互,作为HTTP规范的一部分而存在 ,而Web Storage仅仅是为了在本地“存储”数据而生。


**8、手写数组快速排序**


关于快排算法的详细说明,可以参考阮一峰老师的文章快速排序


“快速排序”的思想很简单,整个排序过程只需要三步:


(1)在数据集之中,选择一个元素作为”基准”(pivot)。


(2)所有小于”基准”的元素,都移到”基准”的左边;所有大于”基准”的元素,都移到”基准”的右边。


(3)对”基准”左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止。


**9、统计字符串”aaaabbbccccddfgh”中字母个数或统计最多字母数。**



var str = "aaaabbbccccddfgh";

var obj = {};

for(var i=0;istr.length;i++){

var v = str.charAt(i);

if(obj[v] & obj[v].value == v){

obj[v].count = ++ obj[v].count;

}else{

obj[v] = {};

obj[v].count = 1;

obj[v].value = v;

}

}

for(key in obj){

document.write(obj[key].value +'='+obj[key].count+' '); // a=4 b=3 c=4 d=2 f=1 g=1 h=1

}


**10、写一个function,清除字符串前后的空格。(兼容所有浏览器)**



function trim(str) {

if (str & typeof str === "string") {

return str.replace(/(^s*)|(s*)$/g,""); //去除前后空白符

}

}


**其他部分**


**1、一次完整的HTTP事务是怎样的一个过程?**


基本流程:


a. 域名解析


b. 发起TCP的3次握手



#### css

1,盒模型
2,如何实现一个最大的正方形
3,一行水平居中,多行居左
4,水平垂直居中
5,两栏布局,左边固定,右边自适应,左右不重叠
6,如何实现左右等高布局
7,画三角形
8link @import导入css
9,BFC理解


![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/253939c9df874a57829a3e20b3fddc58~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771411425&x-signature=2VWOViM92ZI%2FB%2Ft8tAZT6brJYSw%3D)

#### js

1,判断 js 类型的方式
2,ES5 和 ES6 分别几种方式声明变量
3,闭包的概念?优缺点?
4,浅拷贝和深拷贝
5,数组去重的方法
6,DOM 事件有哪些阶段?谈谈对事件代理的理解
7,js 执行机制、事件循环
8,介绍下 promise.all
9,async 和 await,
10,ES6 的 class 和构造函数的区别
11,transform、translate、transition 分别是什么属性?CSS 中常用的实现动画方式,
12,介绍一下rAF(requestAnimationFrame)
13,javascript 的垃圾回收机制讲一下,
14,对前端性能优化有什么了解?一般都通过那几个方面去优化的?


![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/65a0495eb5334ae29c5d6b591c10cbbd~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771411425&x-signature=b%2FAMR07xIbg4CCHz1EV7wS5Jt8w%3D)


**开源分享:https://docs.qq.com/doc/DSmRnRGxvUkxTREhO**