当前位置:首页 » 网页前端 » 吉利集团前端面试题
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

吉利集团前端面试题

发布时间: 2022-10-03 13:26:47

‘壹’ 2020年Web前端面试题汇总(一)

今天小编要跟大家分享的文章是关于2020年Web前端面试题汇总。由于内容较多小编分开为大家介绍,今天首先来和小编一起看一看第一部分的内容,希望这些面试题能够对正准备找Web前端相关工作的小伙伴们有所帮助。

1.说几条写JavaScript的基本规范?


1)不要在同一行声明多个变量;


2)请使用===/!==来比较true/false或者数值;


3)使用对象字面量替代newObject这种形式;


4)减少使用全局函数,全局变量;


5)switch语句必须带有default分支;


6)if语句必须使用大括号;


7)for-in循环中的变量;


应该使用var关键字明确限定作用域;


从而避免作用域全局污染。


2.说说平衡二叉树?


平衡二叉搜索树(Self-balancingbinarysearchtree)


又被称为AVL树。


具有以下性质:


1)它是一棵空树或它的左右两个子树


的高度差的绝对值不超过1,


并且左右两个子树都是一棵平衡二叉树。


2)平衡二叉树必定是二叉搜索树,反之则不一定。


3)平衡二叉树的常用实现方法有红黑树、AVL、


替罪羊树、Treap、伸展树等。


最小二叉平衡树的节点的公式如下:


F(n)=F(n-1)+F(n-2)+1备注:1是根节点,


F(n-1)是左子树的节点数量,


F(n-2)是右子树的节点数量。


3.清除浮动和解决垂直外边距重叠的解决方案?


问题描述:


1)父元素没有设置宽高,尺寸由子元素撑起;


子元素一旦浮动,父元素高度会发生塌陷。


2)子元素设置margin-top会作用的父元素的margin-top;


此时会造成垂直外边距重叠。


.clearfix::after,.clearfix::before{


content:''


display:table;


clear:both;


}


4.sessionStorage、localStorage和cookie?


相同点:


都用于浏览器端存储缓存数据;


不同点:


1)存储内容是否发送到服务器端


当设置了Cookie后,数据会发送到服务器端,


造成一定的宽带浪费;xxxstorage则会将数据保存


到本地,不会造成宽带浪费;


2)数据存储大小不同


Cookie数据不能超过4K,适用于会话标识;


xxxstorage数据存储可以达到5M;


3)数据存储的有效期限不同


cookie只在设置了Cookid过期时间


之前一直有效,即使关闭窗口或者浏览器;


sessionStorage,仅在关闭浏览器之前有效;


localStorage,数据存储永久有效;


4)作用域不同


cookie和localStorage是在同源同窗口中


都是共享的;


sessionStorage不在不同的浏览器窗口


中共享,即使是同一个页面;


5.判断一个单词是否是回文?


回文是指把相同的词汇或句子,


在下文中调换位置或颠倒过来,


产生首尾回环的情景,


叫做回文,也叫回环。


比如cacac,redivider。


letcheckPalindrom=(str)=>{


returnstr===


str.split('').reverse().join('');


}


6.不借助临时变量,进行两个整数的交换?


输入a=3,b=1,


输出a=1,b=3


letswap=(a,b)=>{


b=b-a;


a=a+b;


b=a-b;


return[a,b];


}


7.请写出至少5个html5新增的标签,并说明其语义和应用场景?


section:定义文档中的一个章节;


nav:定义只包含导航链接的章节;


header:定义页面或章节的头部;


它经常包含logo、页面标题和导航性的目录。


footer:定义页面或章节的尾部;


它经常包含版权信息、法律信息链接和反馈建议用的地址。


aside:定义和页面内容关联度较低的内容,


如果被删除,剩下的内容仍然很合理。


8.get和post请求在缓存方面的区别?


get请求类似于查找的过程,用户获取数据,


可以不用每次都与数据库连接,所以可以使用缓存。


post不同,post做的一般是修改和删除的工作,


所以必须与数据库交互,所以不能使用缓存。


因此get请求适合于请求缓存。


9.如何解决异步回调地狱?


promise、generator、async/await


10.图片的懒加载和预加载?


预加载:提前加载图片,


当用户需要查看时可直接


从本地缓存中渲染。


懒加载:懒加载的主要目的


是作为服务器前端的优化,


减少请求数或延迟请求数。


两种技术的本质:


两者的行为是相反的,


一个是提前加载,


一个是迟缓甚至不加载。


懒加载对服务器前端有一定


的缓解压力作用,


预加载则会增加服务器前端压力。


11.bind,apply,call的区别?


通过apply和call改变函数的this指向,


这两个函数的第一个参数都是一样的,


表示要改变指向的那个对象,


第二个参数,apply是数组,


而call则是arg1,arg2...这种形式。


通过bind改变this作用域


会返回一个新的函数,


这个函数不会马上执行。


12.js怎么控制一次加载一张图片,加载完后再加载下一张?


方法一:





varobj=newImage();


obj.src="#/21.jpg";


obj.onload=function(){


document.getElementById("pic")


.innnerHTML="";


}


加载中

‘贰’ 2019Web前端面试题及答案汇总-Jquery篇

今天小编要跟大家分享的文章是关于2019Web前端面试题及答案汇总-Jquery篇。相信最近准备参加Web前端面试的小伙伴一定不在少数,为了帮助大家顺利的通过面试成为一名优秀的Web前端工程师,小编为大家准备了前端面试题系列,通过Web知识的整理以及经验的总结,希望能帮到更多的前端面试者。

Jquery相关


1、jQuery库中的$()是什么?


$()函数是jQuery()函数的别称。$()函数用于将任何对象包裹成jQuery对象,接着你就被允许调用定义在jQuery
对象上的多个不同方法。你可以将一个选择器字符串传入$()函数,它会返回一个包含所有匹配的DOM元素数组的jQuery对象。


2、如何找到所有HTMLselect标签的选中项?


$('[name=selectname]:selected')


3、$(this)和this关键字在jQuery中有何不同?


$(this)返回一个jQuery对象,你可以对它调用多个jQuery方法,比如用text()获取文本,用val()
获取值等等。


而this代表当前元素,它是JavaScript关键词中的一个,表示上下文中的当前DOM元素。你不能对它调用jQuery方法,直到它被
$()函数包裹,例如$(this)。


4、jquery怎么移除标签onclick属性?


获得a标签的onclick属性:$("a").attr("onclick")


删除onclick属性:$("a").removeAttr("onclick")


设置onclick属性:$("a").attr("onclick","test();")


5、jquery中addClass、removeClass、toggleClass的使用。


$(selector).addClass(class):为每个匹配的元素添加指定的类名


$(selector).removeClass(class):从所有匹配的元素中删除全部或者指定的类,删除class中某个值;


$(selector).toggleClass(class):如果存在(不存在)就删除(添加)一个类


$(selector).removeAttr(class);删除class这个属性;


6、JQuery有几种选择器?


(1)、基本选择器:#id,class,element,*;


(2)、层次选择器:parent>child,prev+next,prev~siblings


(3)、基本过滤器选择器::first,:last,:not,:even,:odd,:eq,:gt,:lt


(4)、内容过滤器选择器::contains,:empty,:has,:parent


(5)、可见性过滤器选择器::hidden,:visible


(6)、属性过滤器选择器:[attribute],[attribute=value],[attribute!=value]
,[attribute^=value],[attribute$=value],[attribute*=value]


(7)、子元素过滤器选择器::nth-child,:first-child,:last-child,:only-child


(8)、表单选择器::input,:text,:password,:radio,:checkbox,:submit等;


(9)、表单过滤器选择器::enabled,:disabled,:checked,:selected


7、jQuery中的Delegate()函数有什么作用?


delegate()会在以下两个情况下使用到:


1)、如果你有一个父元素,需要给其下的子元素添加事件,这时你可以使用delegate()了,代码如下:


$("ul").delegate("li","click",function(){$(this).hide();});


2)、当元素在当前页面中不可用时,可以使用delegate()


8、$(document).ready()方法和window.onload有什么区别?


(1)、window.onload方法是在网页中所有的元素(包括元素的所有关联文件)完全加载到浏览器后才执行的。


(2)、$(document).ready()方法可以在DOM载入就绪时就对其进行操纵,并调用执行绑定的函数。


9、如何用jQuery禁用浏览器的前进后退按钮?


实现代码如下:



$(document).ready(function(){

window.history.forward(1);

//ORwindow.history.forward(-1);

});



10、jquery中$.get()提交和$.post()提交有区别吗?


相同点:都是异步请求的方式来获取服务端的数据;


异同点:


1、请求方式不同:$.get()方法使用GET方法来进行异步请求的。$.post()方法使用POST方法来进行异步请求的。


2、参数传递方式不同:get请求会将参数跟在URL后进行传递,而POST请求则是作为HTTP消息的实体内容发送给Web服务器的,这种传递是对用户不可见的。


3、数据传输大小不同:get方式传输的数据大小不能超过2KB而POST要大的多


4、安全问题:GET方式请求的数据会被浏览器缓存起来,因此有安全问题。


11、写出一个简单的$.ajax()的请求方式?

$.ajax({

url:'http://www..com',

type:'POST',

data:data,

cache:true,

headers:{},

beforeSend:function(){},

success:function(){},

error:function(){},

complete:function(){}

});

ja

以上就是小编今天为大家分享的关于2019Web前端面试题及答案汇总-a
Jquery篇的文章,希望本篇文章中的面试题能够对正准备参加Web前端面试的小伙伴们有所帮助。想要了解更多Web前端方面的知识记得关注北大青鸟Web前端培训官网。最后祝愿小伙伴们面试成功成为一名优秀的Web前端工程师。


‘叁’ 2020年Web前端面试题及答案汇总

今天小编要跟大家分享的文章是关于2020年Web前端面试题及答案汇总。正准备参加Web前端面试的小伙伴们来和小编一起看一看吧,希望本篇文章能够对大家有所帮助。

一、Mysql数据库


1.MySQL中varchar与char的区别以及varchar(50)中的50代表的涵义?


答案:


Varchar是变长字符串,最多存储的大小是65535字节,查询速度相对较慢;Char
是定常字符串,最多存储的大小是255字节,查询速度相对较快;


varchar(50)表示:Mysql4.0表示存放50个字节,5.0存放50个字符。


2.简述浏览器打开#显示页面,中间都经过哪些过程?


答案:


向DNS服务器获取域名对应的IP地址并返回浏览器,通过IP地址向Web服务器发请求,Web服务器从文件服务器获取网页中所需要的文件,从数据库服务器获取网页中所需要的数据,最后讲完整的网页相应给浏览器。


3.如何解决MySQL中存储中文乱码问题?


答案:


脚本文件采用UTF8编码


客户端连接数据库使用UTF8编码


服务器端创建数据库使用UTF8编码


4.Float和Double的区别是什么?


答案:


FLOAT(单精度浮点数)类型数据可以存储至多8位十进制数,并在内存中占4字节。


DOUBLE(双精度浮点数)类型数据可以存储至多18位十进制数,并在内存中占8字节。


5.把数据id等于1的名字oldboy更改为oldgirl?


答案:


updatetestsetname='oldgirl'whereid=1;


6.如何登录mysql数据?


答案:


mysql-uroot。


二、JS基础


1.continue和break有什么区别?


答案:


break和continue都是用来控制循环结构的:


break终止循环,跳出循环体执行循环后面的语句。


continue跳过本次循环,执行下一次循环。


2.i++和++i的区别?


答案:


i++:先用i值后加1,


++i:先加1后用i值,


计算:varn=5;求varnum=n+++++n+n+++++n+n;//37


3.JavaScript都有哪些数据类型?


答案:


原始类型:数值型/字符串型/布尔型/undefined/null


引用类型:对象


4.自调用函数是什么?用于什么地方?


答案:立即执行的函数。(function(){//函数体})();


用于创建一个局部作用域。


5.slice和splice有什么区别?


答案:


slice截取子数组,从指定的数组中,截取几个连续的元素组成一个新数组


splice允许从指定数组中,删除一部分元素,同时再添加另一部分元素


6.typeof返回的类型有哪些?


答案:


number、string、boolean、undefined、object、function


ex:


vararr=[1,2,3,4,5];


console.log(typeof(arr));//object


functionmyDemo(){


returnfunctiontest(){};


}


console.log(typeof(myDemo()));//function


7.取1~11之间的随机数(即包括1不包括11)?


答案:


Math.floor(Math.random()*10+1)


parseInt(Math.random()*10+1)


8.什么是变量声明提前?


答案:


使用var关键字声明的变量,会将声明提升到所在作用域的最前边。。


9.push、pop、shift和unshift区别?


答案:


这两组同为对数组的操作,并且会改变数组的本身的长度及内容。


不同的是push()、pop()是从数组的尾部进行增减,unshift()、shift()是从数组的头部进行增减。。


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


答案:


强制转换:parseInt/parseFloat/Number/toString


隐式转换:


字符串+数值数值转字符串


数值+布尔型布尔型中true转为1,false转为0


字符串+布尔型布尔型转为字符串。


11.函数声明与函数表达式的区别?


答案:


相同点:两者都可以创建函数。


不同点:函数声明可以存在函数提升(前),函数表达式不存在函数提升(前)。


//函数声明


functionmyFunction(){


functioninnerFunction(){}


}


//以下为函数表达式


varmyFunc=function(){};


myFunc(function(){


returnfunction(){};


});


12.请指出JavaScript宿主对象和原生对象的区别?


答案:


宿主对象:指JavaScript解释器提供的对象,由解释器厂家自定义并提供实现,不同的解释器提供的扩展对象存在较大的差异(DOM和BOM对象)。


原生对象:JavaScript语言本身预定义的对象,在ECMAScript标准中定义,由所有的解释器厂家来提供具体实现(Array,Date,Math,Number,String,Boolean等)。


13.js中有哪些内置函数?


答案:Object,Array,Boolean,Number,String,Function,Date,Math,RegExp,
Error,Global


14.列举出获取日期相关函数


答案:


console.log(Date.now());//返回当前日期和时间񟬢/01/0100:00:00'之间的毫秒值


vardt=newDate();//获取当前时间---年月日时分秒


console.log(dt.getTime());//返回当前日期和时间񟬢/01/0100:00:00'之间的毫秒值


console.log(dt.getFullYear());//年份


console.log(dt.getMonth()+1);//月份(0-11)


console.log(dt.getDate());//日期(0/1-31)


console.log(dt.getDay());//星期(0-6)


console.log(dt.getHours());//小时(0-23)


console.log(dt.getMinutes());//分钟(0-59)


console.log(dt.getMilliseconds);//返回毫秒(0-999)


console.log(dt.getSeconds());//秒(0-59)


15.Math相关函数


答案:


Math.random()-返回0~1之间的随机数


Math.abs(x)-返回数的绝对值


Math.ceil(x)-向上取整


Math.floor(x)-向下取整


Math.round()四舍五入


Math.max()和Max.min()获取一组数据中的最大值和最小值


Math.PI获取圆周率π的值Math.pow()获取一个值的多少次幂


Math.sqrt()对数值开方


Math.pow(10,2)=100;


Math.sqrt(100)=10;


16.null和undefined的区别?


答案:


undefined是访问一个未初始化的变量时返回的值,


null是访问一个尚不存在的对象时所返回的值。因此,可以把undefined看作是空的变量,而null看作是空的对象。


17.==和===有什么不同?


答案:


==抽象相等,比较时,会先进行类型转换,然后再比较值;


===严格相等,判断两个值相等同时数据类型也得相同。


18.setTimeout和setInterval的区别是什么?


答案:


二者都是用来设置定时操作的。


setTimeout:设置一个定时器,在定时器到期后执行一次函数或代码段


setInterval:设置一个定时器,以固定的时间间隔重复调用一个函数或者代码段


19.请说出以下代码执行结果


for(vari=0;i<3;i++){


setTimeout(function(){


console.log(i);


},0);


console.log(i);


}


答案:012333,执行过程如下


vari=0;


console.log(i);i++;


console.log(i);i++;


console.log(i);i++;


setTimeout(function(){console.log(i);


},0);s


etTimeout(function(){


console.log(i);


},0);


setTimeout(function(){


console.log(i);


},0);//输出012333


20.请说出(true+flase)>2+true的执行结果


答案:false


21.当前代码块输出结果是什么?


varz=10;


functionfoo(){console.log(z);}


(function(funArg){varz=20;funArg();})(foo);


答案:10,自调用函数。


22.setTimeout(function(){},10)表示什么意思?


答案:每隔10毫秒调用一次函数。


23.程序中捕获异常的方法?


答案:


try{


}catch(e){


}finally{


}


24.以下代码执行结果?


varuname='jack'


functionchange(){


alert(uname)//?


varuname='lily'


alert(uname)//?


}


change()


答案:undefinedlily


25.如何使用npm下载express模块?


答案:npminstallexpress


26.split和join的区别?


答案:split()将字符串按照指定的字符分割成一个数组,并返回


join()将数组用指定的字符连接成一个字符串,并返回


27.看下列代码会有什么样的输出?


varfoo="11"+2-"1";


console.log(foo);


console.log(typeoffoo);


答案:111number


28.foo=foo||bar,这行代码是什么意思?为什么要这样写?


答案:这种写法称之为短路表达式


相当于:


varfoo;


if(foo){


foo=foo;


}else{


foo=bar;


}


常用于函数参数的空判断


29.用js实现随机选取10_100之间的10个数字,存入一个数组,并排序


答案:


functiongetRandom(istart,iend){


variChoice=iend-istart+1;


returnMath.floor(Math.random()*iChoice+istart);


}variArray=[];


for(vari=0;i<10;i++){


varresult=getRandom(10,100);


iArray.push(result);


}iArray.sort();


30.如何获取javascript三个数中的最大值和最小值?


答案:Math.max(a,b,c);//最大值


Math.min(a,b,c)//最小值


31.实现冒泡排序?


vararray=[5,4,3,2,1];


vartemp=0;


for(vari=0;i

for(varj=0;j

if(array[j]>array[j+1]){


temp=array[j+1];


array[j+1]=array[j];


array[j]=temp;


}


}


三、NODEJS


1.同步和异步有何区别?


答案:


同步:指发送一个请求,需要等待返回,然后才能够发送下一个请求,有等待过程(在一个任务进行中时不能开启其他的任务)。


异步:指发送一个请求,不需要等待返回,随时可以再发送下一个请求,即不需要等待(在一个任务进行中时可以开启其他的任务)。


2.NodeJS中有哪些类型模块,文件操作用哪一个模块?


答案:


模块类型:核心模块、自定义模块、第三方模块。


文件操作:fs模块


3.对NodeJS的优点和缺点提出自己的看法?


答案:CPU密集型任务的特点是进行大量的计算,消耗CPU资源,比如计算圆周率(上千位)、对视频进行编码等,全靠CPU的运算能力
(一般用C语言,java)IO(Input/
Output)密集型任务,这类任务的特点是CPU消耗很少,大部分时间都在等待IO操作。常见的大部分任务都是IO密集型任务,比如Web应用(一般用脚本语言:python/Nodejs)。Nodejs设计思想中以事件驱动、异步、非堵塞I/O密集型为核心,他提供的大多数api都是基于事件的、异步的风格。所以非常适合处理高并发请求。此外,与Node服务器交互的客户端代码是由js语言编写的,因此客户端和服务器端都用同一种语言编写,减少了成本。


4.使用NodeJS完成登录功能(编写HTML页面和路由接口中的代码)?


答案:


HTML页面:





用户:



密码:









user.js路由


constexpress=require('express');


constpool=require('../pool.js');


varrouter=express.Router();


router.post('/login',(req,res)=>{


varobj=req.body;


var$uname=obj.uname;


if(!$uname){


res.send({code:401,msg:'unamerequired'});


return;


}


var$upwd=obj.upwd;


if(!$upwd){res.send({code:402,msg:'upwdrequired'});


return;


}


varsql='SELECT*FROMxz_userWHEREuname=?ANDupwd=?'
pool.query(sql,[$uname,$upwd],(err,result)=>{


if(err)throwerr;


if(result.length>0){


res.send({code:200,msg:'loginsuccess'});


}else{


res.send({code:301,msg:'loginerror'});


}});


});


//路由器导出


mole.exports=router;


5.什么是Nodejs?


Nodejs是一个JavaScript的运行环境,是一个服务器端的“JavaScript解释器”,用于方便高效地搭建一些响应速度快、易于扩展的网络应用。它采用事件驱动、异步编程,为网络服务而设计

‘肆’ 前端面试 问什么问题

web前端面试会问人事方面的内容和web前端技术的内容;

人事的面试

web前端人事面试方面,需要注意如何自我介绍、性格有哪些优劣势、职业规划方向是什么、你的特长是什么、对于加班之类你是怎么看待等人事面试内容;

web前端技术的面试

技术面试,需要注意HTML+CSS+JavaScript以及JS主流框架的使用,比如Vue、React等,前端相关技术,比如tcp握手协议、网络安全、后端技术等;

对于web前端面试准备,建议你去看“决胜前端”(min app),它里面包含了很多web前端技术面试、人事面试等面试真题,而且针对面试题做了详细的分析与解答。

我给你截图看一下例子吧

‘伍’ 前端hr面试常问的问题

面试其实就是一个不断选择与被选择的过程(不知道说的对不对)。不同公司的面试方式都有所不同,大多数人都有过多次面试的经历,前端面试也不外乎那么一些啦(好像有些废话的感觉)。

面试之前的小故事

HR会打电话过来我是××公司的,在××上看到你投到我们公司的简历,问你何时候有空约一个呗,然后说就星期*吧,既然都打电话请我面试了,好吧,那就约一个!

然后有些人会精心准备,不停刷面试题,整夜整夜的看着HTML/JS/CSS知识点,还有那些最新的、时髦的技术,看看到时候能不能唬住面试官;而有些人对自己胸有成竹,哥那么多年的前端经验了,啥项目没有经历过,不就一个面试,怕啥呢。

很快或者很慢的来到那天。你打扮的清清爽爽漂漂亮亮的,打扮的好会有加分不,没错,第一印象也是挺重要的。途中有些人可能会还一直想着面试官会问啥题目呢,那啥**属性是什么来着呢,再次拿出手机默默的看起资料;有些人可能就会想着公司不知道妹子多不多漂亮不呢,环境和福利不知道咋样,最好别碰到傻逼一样的面试官哎,不然这以后咋相处好呢。

来到公司,大小公司大家都见多了嘛,也是得看发展是吧,我们也不是肤浅的人,见到前台妹妹,哟,还不错哦。领你进会议室里,让你稍等一下,她去通知面试官,过了一会儿,不是面试官进来,那就是前台妹妹给您送来一杯水。面试官踱步向前,咦~,我是继续坐着呢,还是站着呢,还是站起来显礼貌一些嗯。

给面试的一般会是Team Leader或者非常资深的工程师。首先会让你自我介绍下,然后巴拉巴拉介绍自己,途中或者聊到面试官喜欢的`部分那就会中断问几个问题吧,介绍完自己,就进入正式的战斗了吧,一般会有2-3轮的回合。遇知战斗详情,请听下回分解。

哈哈, 开玩笑。以上瞎编胡造,如有雷同,纯属巧合。

这里就只谈谈前端技术的战斗回合吧,写的不好,请多见谅。

普通型

面试中问题会比较的零碎,html/js/css肯定都会有涉及。知识点不会有太大的规律,可能几个公司面试下来你遇到的问题一个都不带重复的。哎,前端的知识点就是乍一看深似海,仔细一看深似黑洞啊。问题好的话,一方面考察了面试人对前端接触的广度,深度的话也可以从中接触到一些。因为面试的时间有限,其实也非常考验面试官对一个人的洞察能力。

一般如果不是应届生的话,也就是会跟你交流你之前的项目,你担当的角色,你遇到的难题,怎么解决问题,用的框架,与其他工程师的交流沟通协作等等。 这些其实你心里肯定是有答案的(可能也有懵逼的),就看你的表达,能不能对上面试官的胃口。

进阶型

除了基本的问题,面试中会有一些明显设计过的题目。针对某几个知识点,或让你手写代码,或让你提供算法或思路。如果之前没有遇到过这类问题的话其实一下子真的挺难回答,或者直接懵逼了,或者回答不出面试官满意的答案。这其实对工程师的要求也是比较的高,不能只是单纯的切切页面,用用插件,需要对某一类问题或者模式或者算法有深入的了解,对问题的解决思路有很好的把握。

算法可能不是前端工程师的长项,但作为优秀的工程师,对算法的了解应该会只深不浅。

这种面试的题目既提现了公司对面试者的要求,也相对而言的会有所体现公司的水平。

出题型

题目比较的综合,会通过邮件发给你,或者有专门的页面提供,在面试之前让你2-3天的时间做完。题目可能是很有名的某一类交互,或游戏,或页面,或公司自己出的一类小东西。

因为非当场面试,所有有比较充足的时间来思考,来写一些代码。一般都会完成,所以其实比较的关注点就是对代码的质量,通过代码来考察面试者的思路以及代码**惯等等。

其未知性也比较多,可能因为有些东西可能没法通过代码来传递,沟通,其他的思路,或者题目的缺陷等等。所以这只是面试途中的一个小部分,大多数人其实都会能做的很好。

直接上机型

还有的就会直接给你某一个交互,或者一张静态页面,或者一个布局等等,直接给你台电脑让你当场写出来。写完之后再有所交流,说说自己的想法或者接着谈其他的。

当你写代码时候,其实暴露的东西也挺多的。你写的**惯,思路清晰不清晰,对代码的熟悉程度,可能你平时都是ctrl C + V的,这时候你咋办呢。

这个可能遇到的比较少,但也会是有的。

结束语

许多面试可能都会结合以上的几种类型,多方面的考察面试者,其实,大家都懂的。

‘陆’ 前端面试题(十五)

已知高度和宽度的元素:

设置父元素为相对定位relative,给子元素设置绝对定位absoluted,top: 0; right: 0; bottom: 0; left: 0; margin: auto;

设置父元素为相对定位,给子元素设置绝对定位,left: 50%; top: 50%; margin-left: --元素宽度的一半px; margin-top: --元素高度的一半px;

未知高度和宽度的元素:

设置父元素为相对定位,给子元素设置绝对定位,left: 50%; top: 50%; transform: translate(-50%,-50%);

设置父元素为相对定位,给子元素设置绝对定位,left: 50%; top: 50%; transform:translate(-50%,-50%);

组件中的 data 写成一个函数,数据以函数返回值形式定义,这样每复用一次组件,就会返回一份新的 data ,类似于给每个组件实例创建一个私有的数据空间,让各个组件实例维护各自的数据。而单纯的写成对象形式,就使得所有组件实例共用了一份 data ,就会造成一个变了全都会变的结果。

for of:

支持 return ,并且是值 of 数组(不能遍历对象)
1. 可以避免所有 for-in 循环的陷阱
2. 不同于 forEach(),可以使用 break, continue 和 return
3. for-of 循环不仅仅支持数组的遍历。同样适用于很多类似数组的对象
4. 它也支持字符串的遍历
5. for-of 并不适用于处理原有的原生对象

for in:

forEach:

assets文件夹里是静态资源;components是放组件;router是定义路由相关的配置;view视图;app.vue是一个应用主组件;main.js是入口文件

在组件切换过程中将状态保留在内存中,防止重复渲染DOM,减少加载时间及性能消耗,提高用户体验性。

生命周期函数: activated( 组件激活时调用 )、deactivated( 组件停用时调用

常见的使用场景可以分为三类:

当频繁执行条件时,不适合使用 v-if ,用 v-show ;
反之执行条件的次数很少,使用 v-if 即可。

v-if 和 v-for ,不推荐两者一起使用在同一个元素上,虽然也能运行,但是编辑器会报警告;两者一起使用时,v-for比v-if具有更高的优先级,

‘柒’ web前端经典面试题

为大家带来一些web前端的面试题,希望可以帮助到大家啊。


1.css3有哪些新特性?


选择器、圆角、动画、多重背景、背景的宽度高度flex布局响应式布局边框阴影文本阴影


2.响应式布局怎么理解的,响应式布局是通过什么实现?


根据不同的屏幕加载不同的css样式


1).移动端适配


2).一套代码适配pc端移动端多个


3.js创建对象有哪几种方式?


1).自面量


2).newObject


3).构造函数


4.es6有哪些新特性?


1).letconst


2).模板字符串


3).方法的简写属性的简写


4).三点运算符


5).解构赋值


6).箭头函数


7).setmap


8).class类


9).模块化


5.箭头函数和普通的方法有什么区别?


1).箭头函数省略了function


2).箭头函数里面的this指向上下文(可以改变this指向)


6.gulp可以干什么


gulp自动化构建工具。


压缩代码合并代码压缩图片自动处理前缀创建web服务处理sass


7.清除浮动有哪些方法。


1).浮动元素的父元素overflow:hiddenoverflow:auto


2).浮动元素的最后面加一个空div给他clear:both


3).after伪类清除浮动


.clearfix:after{


content:"";


dislpay:block;


height:0px;


clear:both;


}


4)、给父元素设置高度。


8.行内元素块元素的区别?


1)块元素默认独占一行,行内元素默认情况不独占一行,行内元素的的宽度就是内容的宽度


2)默认情况块元素可以设置宽度高度默认情况行内元素不可以设置宽度高度


3)默认可以margin上下左右,行内默认只能margin左右不能上下。


9.网站加载速度优化?


1).图片不失真尽量小


2).多个背景图片合并


3).代码压缩代码合并


4).js写到页面最底部


5).懒加载


6).不要有冗余代码


7).服务器带宽款一些


8).服务器固态硬盘


9).开启缓存


10.以前写代码什么情况会成出现乱码怎么解决?


解决乱码文件保存的编码和设置的编码必须保持一致


11.以前如何测试调试移动端页面


1).首先在浏览器自带的调试工具模拟器里面调试


2).真机的内置浏览器调试


3).真机上面的UC里面调试


4).真机上的微信里面调试。

‘捌’ 你遇到的前端面试题都有什么

大家好,我是王我。

随着春节的结束,各个行业也普遍开始了上班的节奏, 不过本人17号才上班。为什么?因为长得帅的都上班比较晚。 当然,每到新年结束,又迎来了一批招聘者与面试者,我来说说作为一年工作经验应该知道的面试题。

HTML篇

1.doctype是什么?有哪些类型?

2.input有哪些新类型?简要说明其8用法。

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

4.bootstrap响应式的原理是什么?

5.多移动终端页面适配是如何实现的?

CSS篇

1.如何实现两列布局,左边自适应,右边固定宽度?

2.用CSS画一个三角形

3.CSS实现字体大写

4.display有哪些常用的属性值?分别是什么意思?

5.position为absolute,relative,fixed的定点位置

6.用三种方法清除浮动

7.请介绍一下margin塌陷问题

js篇

1.什么是事件冒泡和捕获?如何阻止事件冒泡?(分别用原生和jquery实现)

2.js创建对象,至少使用三种方法

3.简述一下事件穿透以及解决办法

4.用三种方式判断变量类型是否是数组

5.如何实现对象的拷贝?

6.什么是闭包?闭包的优缺点。

7.简述一下ajax请求的过程。

8.简述一下new一个人构造函数的人过程。

9.为什么会有跨域?是怎么解决跨域问题的?简述一下原理。

10.js原始数据类型有哪些?

11.学一个函数,判断一个变量是否是字符串

12.typeof有哪些结果?

13.剪头函数和普通函数有什么区别?

14.请用三种方法实现数组去重

15.href和src有什么区别?

jquery篇

1.attr()和prop()有什么区别?

2.on和bind有什么区别?js动态添加的dom元素是通过on还是bind?

3.touch和click有什么区别?

4.window.onload和jquery的ready有什么区别?

vue篇

1.简述一下vue的生命周期及其特点

2.vue双向绑定的原理是什么?

3.vue的特点有哪些?和jquery有什么区别?

4.父子组件之间传递数据的方法

5.子组件如何共享数据?

6.一般有什么工具进行数据交互?

7.webpack的原理是什么?

8.简述一下$nextTick的用法

浏览器篇

1.cookie、sessionStorage、localStorage的区别是什么?

2.有用过浏览器缓存吗?简述一下基本的缓存机制

网络篇

1.http和https之间的区别

2.从服务器的安全考虑,是使用get请求还是post请求?

3.URL请求的过程有哪些?

项目经验篇

1.项目中遇到的最大挑战以及解决办法

2.常见的网页优化有哪些?

作为一个面试一年以内工作经验的前端程序员来说,以上的问题能够倒答如流月薪6k应该不成问题啦。这些面试题也是我在很多面试中感觉经常被问到的题目。

希望大家年后找工作能够顺顺利利, 千万不要跟我一样哦,只有帅气就一无所有了。

大家好,我是王我,中国最帅的前端程序员。

前几次都是各种培训公司,各种忽悠就不提了,说说后面4次面试的经历。

第一次是面一个小公司,不过他们好像没有厉害的前端,来面我的是个后端,一来没有问我关于js的知识,直接问我以前做过什么,有没有经验,我本人不会吹牛,简历也没怎么包装,就是自己把自学的知识和做的几个小demo弄在上面,也用github挂在页面上了,不过他根本不点开看,也不问,问我会不会vue,我当时对框架还不了解,他就说他们需要能直接上手开始写的,所以我第一个就直接挂了。

第二次面试是一个国企,这个问了很多问题,都很基础,js数据类型,数组操作,事件,大概就是高程的前面几章看看就差不多都能答到,然后因为他们主要用jq,所以问了很多jq的操作,关于节点的,动画的,我看锋利的jq大概看了3遍,也练过多次,所以我答的很熟。然后问了些布局方面的,bootstrap我了解过,又看过css3,所以这方面也没啥问题,最后在现场做了个题目,主要就是布局然后通过ajax呈现数据。后面听介绍我面试的说面试官比较满意,说我jq很熟,一面就过了。可惜后面电话面试不知怎么回事可能表现的不够自信,虽然没问技术,但是我没啥自信,把没项目经验什么的也不知怎么就一五一十交代了,估计因为这个挂掉了。

第三次没问问题,直接就是一套题开做,我在那做了一个多小时。题目就是按照要求一步一步做一个页面出来,我也搞忘了我当时卡在哪个地方了,坐在那得时候就是做不出来,没有设计图,要根据他的描述自己找个设计图然后做,我第一次遇到这个有点懵,虽然当时没做出来,不过回来我自己花了几个小时把它做了。所以这个也是凉了。

第四个问的比较多,数据类型,数组操作,跨域,ajax,闭包,原型链,继承,深拷贝,浅拷贝,模块amd cmd,基本都是问的js。然后问了html5的新特性 css3 的新特性,遇到过什么浏览器的兼容性问题,怎么解决的,以后想往什么方面发展。这个时候我已经会点vue了,照着做了个小demo,不过后来知道公司用的angularjs,面试官也没看我做的,问也没问。。以前听网上说要带上自己的项目去面试感觉没起多大效果。

最后总结下如果面的比较初级的岗位,应该主要问js,原型链,继承,闭包,深浅拷贝,ajax,跨域,然后js的基础知识,对了还有apply和call也问了,html5的新特性了解下就行。主要就是看你js掌握的程度,如果稍微要求高一点的,暂时还没面过,等以后面过在来回答

1. cookie session 的用途和区别,以及有效期

1、cookie数据存放在客户的浏览器上,session数据放在服务器上。

2、cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗

考虑到安全应当使用session。

3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能

考虑到减轻服务器性能方面,应当使用COOKIE。

4、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。

2. vue的数据绑定原理,mvvm与mvc的区别

MVVM:

m:model数据模型层 v:view视图层 vm:ViewModel
vue中采用的是mvvm模式,这是从mvc衍生过来的
MVVM让视图与viewmodel直接的关系特别的紧密,就是为了解决mvc反馈不及时的问题

图片说明一下:


说到MVVM就要说一下双向绑定和数据劫持的原理,

MVC:

m:model数据模型层 v:view视图层 c:controller控制器

原理: c层需要控制model层的数据在view层进行显示

MVC两种方式,图片说明:


总结:

mvvm与mvc最大的区别:
MVVM实现了view与model的自动同步,也就是model属性改变的时候, 我们不需要再自己手动操作dom元素去改变view的显示,而是改变属性后该属性对应的view层会自动改变。

不懂得可以复制链接查看:

https://www.pianshen.com/article/3716256399/

3. storage 的区别 sessionStorage localStorage

localStorage 的生命周期是永久性的。假若使用localStorage存储数据,即使关闭浏览器,也不会让数据消失,除非主动的去删除数据,使用的方法如上所示。localStorage有length属性


sessionStorage 的生命周期是在浏览器关闭前。也就是说,在整个浏览器未关闭前,其数据一直都是存在的。sessionStorage也有length属性,其基本的判断和使用方法和localStorage的使用是一致的


4.v-model双向数据原理

有一个文本框 通过v-bind绑定了value属性 值为myname 是我们在vue实例中定义的属性
传统我们获取文本框值方法 可能通过getElementById找到文本框 然后获取其value属性
但是vue中直接通过v-bind绑定了value属性 所以不需要像之前那样获取值
所以在后面的按钮中获取name值 直接获取vue实例对象data里面的myname属性即可

【数据为尊 ----数据映射到浏览器 如果数据v-model后修改(肯定input)然后到数据在有数据映射到浏览器页面 ----映射关系统称】



5.keepAlive用过吗?什么作用?

缓存路由组件


使用的是vue的一个组件,参考vue的官方文档

使用这个东西可以保证我们在切换组件的时候,原来显示的组件不被销毁

-----【保障组件的数据不会被切换路由而销毁数据】

Home是对应的组件对象的名字,不是路由的名字

6.多维数组拍平

数组拍平也称数组扁平化,就是将数组里面的数组打开,最后合并为一个数组

一红六种方法吧……

了解的请看: https://www.cnblogs.com/guan-shan/p/10165737.html

7.跨域的原因 解决方案

跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。

这样就可以说同源策略----协议---端口---域名

原生的src和href可以解决跨域

代理可以解决

请求头也可以携带浏览器提示的也可以解决

一般都是后端解决跨域问题

【别的需要了解看下方链接】

https://blog.csdn.net/qq_41604383/article/details/100770100

8.uniApp兼容问题

§ 如果你使用cli创建项目(即项目根目录是package.json),不管用什么ide,即便是用HBuilderX,切记cli项目的编译器是在项目下的,HBuilderX不管怎么升级都不会影响编译器版本。你需要手动npm update来升级编译器。以及如果你想要安装less、scss等预编译器,也需要自己npm安装在项目下,而不是在HBuilderX的插件管理里安装。

§ 如果你使用离线打包,请注意HBuilderX升级后,真机运行基座和云打包对应引擎跟随HBuilderX升级,而你的sdk需要手动升级。sdk的版本升级一般滞后HBuilderX正式版升级一两天。

§ 如果你使用自定义基座,之前制作的自定义基座是不会跟随HBuilderX升级的,升级HBuilderX后你应该重新制作新版自定义基座。

§ 如果你使用wgt升级,新版HBuilderX编译的wgt,运行到之前的runtime上,一定要先测试好,看有没有兼容性问题。如果有问题,就不要wgt升级,整包升级。

§ 考虑到向下兼容,uni-app编译器在升级为新的自定义组件模式后,同时保留了对老编译模式的向下兼容。
在HBuilderX alpha版中,App端一定会使用新编译器,不理会manifest配置。
在HBuilderX 正式版中,新创建的项目会使用新编译器,老项目不会强制使用,而是开发者自己在manifest里配置开启。

§ 如果你使用其他ide开发uni-app,会经常因为拼错单词而运行失败,因为经过webpack编译一道,很多错误反应的不够直观,排错时间很长,不如从开始就依赖有良好提示的HBuilderX,避免敲错单词。

§ 云打包的引擎版本说明
HBuilderX Alpha,只有1套云打包机,不管你的HBuilderX alpha版本多少,对应的打包机一定是最新的alpha版的客户端引擎。
HBuilderX正式版,有2套打包机,一个是最新正式版,一个是次新正式版。
中间的紧急更新版本没有独立打包机。
举个例子:
HBuilderX 有1.8.0、1.8.1、1.8.2、1.9.0、1.9.1这几个正式版。
那么当前可用的打包机有1.9.1和1.8.2这2台。(即每个大版本的最后一个版本)
除了这2个HBuilderX版本外,其他版本的云打包都指向最新的1.9.1版对应的打包机。(即只保留2个大版本的云打包机)

【详情请看】

https://ask.dcloud.net.cn/article/35845

一、HTML

HTML书写规范

H5新增标签

HTML渲染过程

二、CSS

css盒子模型概念

css弹性布局概念

三、JavaScript

事件模型

DOM2级事件模型

闭包

原型链

四、移动Web开发

常见的布局方案

移动端前端常见的触摸相关事件touch、tap、swipe等整理

移动端前端手势事件

移动端页面渲染优化

GPU渲染

GPU核心渲染过程

五、调试

常用的调试工具

Chrome控制台调试js使用

移动端测试

六、HTTP网络知识

常见的HTTP状态码

不同请求类型的区别

WEB缓存方案

——————————

牛客网(www.nowcoder.com)

- 专业IT笔试面试备考平台

- 最全C++JAVA前端等互联网技术求职题库

- 全面提升IT编程能力

- 程序员交友圣地

分享了一些Web前端的面试题,限时一小时,你看看自己能够答出多少道!

放心,这些面试题都是一些非常基础的知识,只要你在平时认真听课、学习了,那么这些面试题肯定不会难道你。

建议:虽然没有人监督你,但还是希望你不要去寻找答案,脱离网络,拿起纸笔,你试一下自己究竟能够答出个什么水平!有没有真本领?答案尽在这些面试题里!那么,你准备好了吗?OK!计时开始!

一、HTML常见题目

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

02、HTML5为什么只需要写?

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

04、页面导入样式时,使用link和@import有什么区别?

05、介绍一下你对浏览器内核的理解?

06、常见的浏览器内核有哪些?

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

08、如何区分HTML和HTML5?

09、简述一下你对HTML语义化的理解?

10、HTML5的离线储存怎么使用,工作原理能不能解释一下?

二、CSS类的题目

01、介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的?

02、CSS选择符有哪些?哪些属性可以继承?

03、CSS优先级算法如何计算?

04、CSS3新增伪类有那些?

05、如何居中p?如何居中一个浮动元素?如何让绝对定位的p居中?

06、display有哪些值?说明他们的作用。

07、position的值relative和absolute定位原点是?

08、CSS3有哪些新特性?

09、请解释一下CSS3的Flexbox(弹性盒布局模型),以及适用场景?

10、用纯CSS创建一个三角形的原理是什么?

三、Java类的题目

01、介绍Java的基本数据类型。

02、说说写Java的基本规范?

03、Java原型,原型链?有什么特点?

04、Java有几种类型的值?(堆:原始数据类型和栈:引用数据类型),你能画一下他们的内存图吗?

05、Java如何实现继承?

06、Java创建对象的几种方式?

07、Java作用链域?

08、谈谈This对象的理解。

09、eval是做什么的?

10、什么是window对象?什么是document对象?

OK,一小时到了,这个时间可不算短了,那么这些面试题你答出了几道呢?你写的答案正确了吗?现在你可以去翻看答案了。

如果你答出了绝大多数的或者是全部的题,并且答案也正确了,那么恭喜你……

你这时心里是不是有点小窃喜,认为自己有能力拿高薪了?虽然我也很想这么告诉你,但事实上这只能表明你的基础扎实,毕竟这只是一些非常基础的面试题。骚年~继续努力吧!

如果你只答出了小部分或者答出了大部分题但答案不正确,那么我只想说:“骚年,你的水平还差的远呢。”连这么基础的题你都打不出来,还想拿高薪?回去再练一段时间吧!

扎实的基础是你拿高薪的重要武器,如果你连基础都不扎实,那么想要攻克“高薪”这个厚实的堡垒,那只是痴人说梦罢了。

1.前端框架类问题,问你会不会用vue react啊

2.语言类,问你一些JavaScript语言的问题

3.项目经验,让你讲讲做过的项目,遇到的问题和解决之道

‘玖’ Web前端岗位面试题有哪些

前端面试题汇总,基本上会有四大类问题,具体如下:
一、HTML

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

2、HTML5 为什么只需要写 <!DOCTYPE HTML>?
3、行内元素有哪些?块级元素有哪些? 空(void)元素有那些?
4、页面导入样式时,使用link和@import有什么区别?
5、介绍一下你对浏览器内核的理解?
6、常见的浏览器内核有哪些?
7、html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?
8、简述一下你对HTML语义化的理解?
9、HTML5的离线储存怎么使用,工作原理能不能解释一下?
10、浏览器是怎么对HTML5的离线储存资源进行管理和加载的呢?
11、请描述一下 cookies,sessionStorage 和 localStorage 的区别?
12、iframe有那些缺点?
13、Label的作用是什么?是怎么用的?(加 for 或 包裹)
14、HTML5的form如何关闭自动完成功能?
15、如何实现浏览器内多个标签页之间的通信? (阿里)
16、webSocket如何兼容低浏览器?(阿里)
17、页面可见性(Page Visibility)API 可以有哪些用途?
18、如何在页面上实现一个圆形的可点击区域?
19、实现不使用 border 画出1px高的线,在不同浏览器的Quirksmode和CSSCompat模式下都能保持同一效果。
20、网页验证码是干嘛的,是为了解决什么安全问题?
21、tite与h1的区别、b与strong的区别、i与em的区别?

二、css

1、介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的?

2、CSS选择符有哪些?哪些属性可以继承?
3、CSS优先级算法如何计算?
4、CSS3新增伪类有那些?
5、如何居中div?如何居中一个浮动元素?如何让绝对定位的div居中?
6、display有哪些值?说明他们的作用。
7、position的值relative和absolute定位原点是?
8、CSS3有哪些新特性?
9、请解释一下CSS3的Flexbox(弹性盒布局模型),以及适用场景?
10、用纯CSS创建一个三角形的原理是什么?

11、一个满屏 品 字布局 如何设计?

三、常见兼容性问题?


  1. 1、li与li之间有看不见的空白间隔是什么原因引起的?有什么解决办法?
    2、经常遇到的浏览器的兼容性有哪些?原因,解决方法是什么,常用hack的技巧 ?
    3、为什么要初始化CSS样式。
    4、absolute的containing block计算方式跟正常流有什么不同?
    5、CSS里的visibility属性有个collapse属性值是干嘛用的?在不同浏览器下以后什么区别?
    6、position跟display、margin collapse、overflow、float这些特性相互叠加后会怎么样?
    7、对BFC规范(块级格式化上下文:block formatting context)的理解?
    8、CSS权重优先级是如何计算的?
    9、请解释一下为什么会出现浮动和什么时候需要清除浮动?清除浮动的方式
    10、移动端的布局用过媒体查询吗?
    11、使用 CSS 预处理器吗?喜欢那个?
    12、CSS优化、提高性能的方法有哪些?
    13、浏览器是怎样解析CSS选择器的?
    14、在网页中的应该使用奇数还是偶数的字体?为什么呢?
    15、margin和padding分别适合什么场景使用?
    16、抽离样式模块怎么写,说出思路,有无实践经验?[阿里航旅的面试题]
    17、元素竖向的百分比设定是相对于容器的高度吗?
    18、全屏滚动的原理是什么?用到了CSS的那些属性?
    19、什么是响应式设计?响应式设计的基本原理是什么?如何兼容低版本的IE?
    20、视差滚动效果,如何给每页做不同的动画?(回到顶部,向下滑动要再次出现,和只出现一次分别怎么做?)
    21、::before 和 :after中双冒号和单冒号 有什么区别?解释一下这2个伪元素的作用。
    22、如何修改chrome记住密码后自动填充表单的黄色背景 ?
    23、你对line-height是如何理解的?
    24、设置元素浮动后,该元素的display值是多少?(自动变成display:block)
    25、怎么让Chrome支持小于12px 的文字?
    26、让页面里的字体变清晰,变细用CSS怎么做?(-webkit-font-smoothing: antialiased;)
    27、font-style属性可以让它赋值为“oblique” oblique是什么意思?
    28、position:fixed;在android下无效怎么处理?
    29、如果需要手动写动画,你认为最小时间间隔是多久,为什么?(阿里)
    30、display:inline-block 什么时候会显示间隙?(携程)
    31、overflow: scroll时不能平滑滚动的问题怎么处理?
    32、有一个高度自适应的div,里面有两个div,一个高度100px,希望另一个填满剩下的高度。
    33、png、jpg、gif 这些图片格式解释一下,分别什么时候用。有没有了解过webp?
    34、什么是Cookie 隔离?(或者说:请求资源的时候不要让它带cookie怎么做)
    35、style标签写在body后与body前有什么区别?

    四、JavaScript

    1、介绍JavaScript的基本数据类型。
    2、说说写JavaScript的基本规范?
    3、JavaScript原型,原型链 ? 有什么特点?
    4、JavaScript有几种类型的值?(堆:原始数据类型和 栈:引用数据类型),你能画一下他们的内存图吗?
    5、Javascript如何实现继承?
    6、Javascript创建对象的几种方式?
    7、Javascript作用链域?
    8、谈谈This对象的理解。
    9、eval是做什么的?
    10、什么是window对象? 什么是document对象?
    11、null,undefined的区别?
    12、写一个通用的事件侦听器函数(机试题)。
    13、[“1”, “2”, “3”].map(parseInt) 答案是多少?
    14、关于事件,IE与火狐的事件机制有什么区别? 如何阻止冒泡?
    15、什么是闭包(closure),为什么要用它?
    16、javascript 代码中的”use strict”;是什么意思 ? 使用它区别是什么?
    17、如何判断一个对象是否属于某个类?
    18、new操作符具体干了什么呢?
    19、用原生JavaScript的实现过什么功能吗?
    20、Javascript中,有一个函数,执行时对象查找时,永远不会去查找原型,这个函数是?
    21、对JSON的了解?
    22、[].forEach.call($$("*"),function(a){ a.style.outline="1px solid #"+(~~(Math.random()*(1<<24))).toString(16) }) 能解释一下这段代码的意思吗?
    23、js延迟加载的方式有哪些?
    24、Ajax 是什么? 如何创建一个Ajax?
    25、同步和异步的区别?
    26、如何解决跨域问题?
    27、页面编码和被请求的资源编码如果不一致如何处理?
    28、模块化开发怎么做?
    29、AMD(Moles/Asynchronous-Definition)、CMD(Common Mole

    Definition)规范区别?
    30、requireJS的核心原理是什么?(如何动态加载的?如何避免多次加载的?如何 缓存的?)
    31、让你自己设计实现一个requireJS,你会怎么做?
    32、谈一谈你对ECMAScript6的了解?
    33、ECMAScript6 怎么写class么,为什么会出现class这种东西?
    34、异步加载的方式有哪些?
    35、documen.write和 innerHTML的区别?
    36、DOM操作——怎样添加、移除、移动、复制、创建和查找节点?
    37、.call() 和 .apply() 的含义和区别?
    38、数组和对象有哪些原生方法,列举一下?
    39、JS 怎么实现一个类。怎么实例化这个类
    40、JavaScript中的作用域与变量声明提升?
    41、如何编写高性能的Javascript?
    42、那些操作会造成内存泄漏?
    43、JQuery的源码看过吗?能不能简单概况一下它的实现原理?
    44、jQuery.fn的init方法返回的this指的是什么对象?为什么要返回this?
    45、jquery中如何将数组转化为json字符串,然后再转化回来?
    46、jQuery 的属性拷贝(extend)的实现原理是什么,如何实现深拷贝?
    47、jquery.extend 与 jquery.fn.extend的区别?
    48、jQuery 的队列是如何实现的?队列可以用在哪些地方?
    49、谈一下Jquery中的bind(),live(),delegate(),on()的区别?
    50、JQuery一个对象可以同时绑定多个事件,这是如何实现的?
    51、是否知道自定义事件。jQuery里的fire函数是什么意思,什么时候用?
    52、jQuery 是通过哪个方法和 Sizzle 选择器结合的?(jQuery.fn.find()进入Sizzle)
    53、针对 jQuery性能的优化方法?
    54、Jquery与jQuery UI有啥区别?
    55、JQuery的源码看过吗?能不能简单说一下它的实现原理?
    56、jquery 中如何将数组转化为json字符串,然后再转化回来?
    57、jQuery和Zepto的区别?各自的使用场景?
    58、针对 jQuery 的优化方法?
    59、Zepto的点透问题如何解决?
    60、jQueryUI如何自定义组件?
    61、需求:实现一个页面操作不会整页刷新的网站,并且能在浏览器前进、后退时正确响应。给出你的技术实现方案?
    62、如何判断当前脚本运行在浏览器还是node环境中?(阿里)
    63、移动端最小触控区域是多大?
    64、jQuery 的 slideUp动画 ,如果目标元素是被外部事件驱动, 当鼠标快速地连续触发外部元素事件, 动画会滞后的反复执行,该如何处理呢?
    65、把 Script 标签 放在页面的最底部的body封闭之前 和封闭之后有什么区别?浏览器会如何解析它们?
    66、移动端的点击事件的有延迟,时间是多久,为什么会有? 怎么解决这个延时?(click 有 300ms 延迟,为了实现safari的双击事件的设计,浏览器要知道你是不是要双击操作。)
    67、知道各种JS框架(Angular, Backbone, Ember, React, Meteor, Knockout…)么? 能讲出他们各自的优点和缺点么?
    68、Underscore 对哪些 JS 原生对象进行了扩展以及提供了哪些好用的函数方法?
    69、解释JavaScript中的作用域与变量声明提升?
    70、那些操作会造成内存泄漏?
    71、JQuery一个对象可以同时绑定多个事件,这是如何实现的?
    72、Node.js的适用场景?
    (如果会用node)知道route, middleware, cluster, nodemon, pm2, server-side rendering么?
    73、解释一下 Backbone 的 MVC 实现方式?
    74、什么是“前端路由”?什么时候适合使用“前端路由”? “前端路由”有哪些优点和缺点?
    75、知道什么是webkit么? 知道怎么用浏览器的各种工具来调试和debug代码么?
    76、如何测试前端代码么? 知道BDD, TDD, Unit Test么? 知道怎么测试你的前端工程么(mocha, sinon, jasmin, qUnit..)?
    77、前端templating(Mustache, underscore, handlebars)是干嘛的, 怎么用?
    78、简述一下 Handlebars 的基本用法?
    79、简述一下 Handlerbars 的对模板的基本处理流程, 如何编译的?如何缓存的?
    80、用js实现千位分隔符?(来源:前端农民工,提示:正则+replace)
    检测浏览器版本版本有哪些方式?
    81、我们给一个dom同时绑定两个点击事件,一个用捕获,一个用冒泡,你来说下会执行几次事件,然后会先执行冒泡还是捕获

‘拾’ 一份超全的Web前端工程师面试题!收藏~

今天小编为大家准备了一份超全的Web前端工程师面试题,准备换工作参加Web前端工程师面试的小伙伴们快来和小编一起看一看这些题目吧,希望能够对你的面试有所帮助!

一、HTML


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


§HTML5为什么只需要写?


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


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


§介绍一下你对浏览器内核的理解?


§常见的浏览器内核有哪些?


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


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


§HTML5的离线储存怎么使用,工作原理能不能解释一下?


§浏览器是怎么对HTML5的离线储存资源进行管理和加载的呢?


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


§iframe有那些缺点?


§Label的作用是什么?是怎么用的?(加for或包裹)


§HTML5的form如何关闭自动完成功能?


§如何实现浏览器内多个标签页之间的通信?(阿里)


§webSocket如何兼容低浏览器?(阿里)


§页面可见性(PageVisibility)API可以有哪些用途?


§如何在页面上实现一个圆形的可点击区域?


§实现不使用border画出1px高的线,在不同浏览器的Quirksmode和CSSCompat模式下都能保持同一效果。


§网页验证码是干嘛的,是为了解决什么安全问题?


§tite与h1的区别、b与strong的区别、i与em的区别?


二、CSS


§介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的?


§CSS选择符有哪些?哪些属性可以继承?


§CSS优先级算法如何计算?


§CSS3新增伪类有那些?


§如何居中div?如何居中一个浮动元素?如何让绝对定位的div居中?


§display有哪些值?说明他们的作用。


§position的值relative和absolute定位原点是?


§CSS3有哪些新特性?


§请解释一下CSS3的Flexbox(弹性盒布局模型),以及适用场景?


§用纯CSS创建一个三角形的原理是什么?


§一个满屏品字布局如何设计?


§常见兼容性问题?


§li与li之间有看不见的空白间隔是什么原因引起的?有什么解决办法?


§经常遇到的浏览器的兼容性有哪些?原因,解决方法是什么,常用hack的技巧?


§为什么要初始化CSS样式。


§absolute的containingblock计算方式跟正常流有什么不同?


§CSS里的visibility属性有个collapse属性值是干嘛用的?在不同浏览器下以后什么区别?


§position跟display、margincollapse、overflow、float这些特性相互叠加后会怎么样?


§对BFC规范(块级格式化上下文:blockformattingcontext)的理解?


§CSS权重优先级是如何计算的?


§请解释一下为什么会出现浮动和什么时候需要清除浮动?清除浮动的方式


§移动端的布局用过媒体查询吗?


§使用CSS预处理器吗?喜欢那个?


§CSS优化、提高性能的方法有哪些?


§浏览器是怎样解析CSS选择器的?


§在网页中的应该使用奇数还是偶数的字体?为什么呢?


§margin和padding分别适合什么场景使用?


§抽离样式模块怎么写,说出思路,有无实践经验?[阿里航旅的面试题]


§元素竖向的百分比设定是相对于容器的高度吗?


§全屏滚动的原理是什么?用到了CSS的那些属性?


§什么是响应式设计?响应式设计的基本原理是什么?如何兼容低版本的IE?


§视差滚动效果,如何给每页做不同的动画?(回到顶部,向下滑动要再次出现,和只出现一次分别怎么做?)


§::before和:after中双冒号和单冒号有什么区别?解释一下这2个伪元素的作用。


§如何修改chrome记住密码后自动填充表单的黄色背景?


§你对line-height是如何理解的?


§设置元素浮动后,该元素的display值是多少?(自动变成display:block)


§怎么让Chrome支持小于12px的文字?


§让页面里的字体变清晰,变细用CSS怎么做?(-webkit-font-smoothing:antialiased;)


§font-style属性可以让它赋值为“oblique”oblique是什么意思?


§position:fixed;在android下无效怎么处理?


§如果需要手动写动画,你认为最小时间间隔是多久,为什么?(阿里)


§display:inline-block什么时候会显示间隙?(携程)


§overflow:scroll时不能平滑滚动的问题怎么处理?


§有一个高度自适应的div,里面有两个div,一个高度100px,希望另一个填满剩下的高度。


§png、jpg、gif这些图片格式解释一下,分别什么时候用。有没有了解过webp?


§什么是Cookie隔离?(或者说:请求资源的时候不要让它带cookie怎么做)


§style标签写在body后与body前有什么区别?


三、JavaScript


§介绍JavaScript的基本数据类型。


§说说写JavaScript的基本规范?


§JavaScript原型,原型链?有什么特点?


§JavaScript有几种类型的值?(堆:原始数据类型和栈:引用数据类型),你能画一下他们的内存图吗?


§Javascript如何实现继承?


§Javascript创建对象的几种方式?


§Javascript作用链域?


§谈谈This对象的理解。


§eval是做什么的?


§什么是window对象?什么是document对象?


§null,undefined的区别?


§写一个通用的事件侦听器函数(机试题)。


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


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


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


§javascript代码中的”usestrict”;是什么意思?使用它区别是什么?


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


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


§用原生JavaScript的实现过什么功能吗?


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


§对JSON的了解?


§[].forEach.call($$("*"),function(a){a.style.outline="1pxsolid
#"+(~~(Math.random()*(1<<24))).toString(16)})能解释一下这段代码的意思吗?


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


§Ajax是什么?如何创建一个Ajax?


§同步和异步的区别?


§如何解决跨域问题?


§页面编码和被请求的资源编码如果不一致如何处理?


§模块化开发怎么做?


§AMD(Moles/Asynchronous-Definition)、CMD(CommonMole
Definition)规范区别?


§requireJS的核心原理是什么?(如何动态加载的?如何避免多次加载的?如何缓存的?)


§让你自己设计实现一个requireJS,你会怎么做?


§谈一谈你对ECMAScript6的了解?


§ECMAScript6怎么写class么,为什么会出现class这种东西?


§异步加载的方式有哪些?


§documen.write和innerHTML的区别?


§DOM操作——怎样添加、移除、移动、复制、创建和查找节点?


§.call()和.apply()的含义和区别?


§数组和对象有哪些原生方法,列举一下?


§JS怎么实现一个类。怎么实例化这个类


§JavaScript中的作用域与变量声明提升?


§如何编写高性能的Javascript?


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


§JQuery的源码看过吗?能不能简单概况一下它的实现原理?


§jQuery.fn的init方法返回的this指的是什么对象?为什么要返回this?


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


§jQuery的属性拷贝(extend)的实现原理是什么,如何实现深拷贝?


§jquery.extend与jquery.fn.extend的区别?


§jQuery的队列是如何实现的?队列可以用在哪些地方?


§谈一下Jquery中的bind(),live(),delegate(),on()的区别?


§JQuery一个对象可以同时绑定多个事件,这是如何实现的?


§是否知道自定义事件。jQuery里的fire函数是什么意思,什么时候用?


§jQuery是通过哪个方法和Sizzle选择器结合的?(jQuery.fn.find()进入Sizzle)


§针对jQuery性能的优化方法?


§Jquery与jQueryUI有啥区别?


§JQuery的源码看过吗?能不能简单说一下它的实现原理?


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


§jQuery和Zepto的区别?各自的使用场景?


§针对jQuery的优化方法?


§Zepto的点透问题如何解决?


§jQueryUI如何自定义组件?


§需求:实现一个页面操作不会整页刷新的网站,并且能在浏览器前进、后退时正确响应。给出你的技术实现方案?


§如何判断当前脚本运行在浏览器还是node环境中?(阿里)


§移动端最小触控区域是多大?


§jQuery的slideUp动画,如果目标元素是被外部事件驱动,当鼠标快速地连续触发外部元素事件,
动画会滞后的反复执行,该如何处理呢?


§把Script标签放在页面的最底部的body封闭之前和封闭之后有什么区别?浏览器会如何解析它们?


§移动端的点击事件的有延迟,时间是多久,为什么会有?怎么解决这个延时?(click有300ms
延迟,为了实现safari的双击事件的设计,浏览器要知道你是不是要双击操作。)


§知道各种JS框架(Angular,Backbone,Ember,React,Meteor,Knockout)么?
能讲出他们各自的优点和缺点么?


§Underscore对哪些JS原生对象进行了扩展以及提供了哪些好用的函数方法?


§解释JavaScript中的作用域与变量声明提升?


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


§JQuery一个对象可以同时绑定多个事件,这是如何实现的?


§Node.js的适用场景?


§(如果会用node)知道route,middleware,cluster,nodemon,pm2,server-side
rendering么?


§解释一下Backbone的MVC实现方式?


§什么是“前端路由”?什么时候适合使用“前端路由”?“前端路由”有哪些优点和缺点?


§知道什么是webkit么?知道怎么用浏览器的各种工具来调试和debug代码么?


§如何测试前端代码么?知道BDD,TDD,UnitTest么?知道怎么测试你的前端工程么(mocha,sinon,jasmin,
qUnit..)?


§前端templating(Mustache,underscore,handlebars)是干嘛的,怎么用?


§简述一下Handlebars的基本用法?


§简述一下Handlerbars的对模板的基本处理流程,如何编译的?如何缓存的?


§用js实现千位分隔符?(来源:前端农民工,提示:正则+replace)


§检测浏览器版本版本有哪些方式?


§我们给一个dom同时绑定两个点击事件,一个用捕获,一个用冒泡,你来说下会执行几次事件,然后会先执行冒泡还是捕获。


四、其他问题


§原来公司工作流程是怎么样的,如何与其他人协作的?如何夸部门合作的?


§你遇到过比较难的技术问题是?你是如何解决的?


§设计模式知道什么是singleton,factory,strategy,decrator么?


§常使用的库有哪些?常用的前端开发工具?开发过什么应用或组件?


§页面重构怎么操作?


§列举IE与其他浏览器不一样的特性?


§99%的网站都需要被重构是那本书上写的?


§什么叫优雅降级和渐进增强?


§是否了解公钥加密和私钥加密。


§WEB应用从服务器主动推送Data到客户端有那些方式?


§对Node的优点和缺点提出了自己的看法?


§你有用过哪些前端性能优化的方法?


§http状态码有那些?分别代表是什么意思?


§一个页面从输入URL到页面加载显示完成,这个过程中都发生了什么?(流程说的越详细越好)


§部分地区用户反应网站很卡,请问有哪些可能性的原因,以及解决方法?


§从打开app到刷新出内容,整个过程中都发生了什么,如果感觉慢,怎么定位问题,怎么解决?


§除了前端以外还了解什么其它技术么?你最最厉害的技能是什么?


§你用的得心应手用的熟练地编辑器&开发环境是什么样子?


§对前端界面工程师这个职位是怎么样理解的?它的前景会怎么样?


§你怎么看待WebApp、hybridApp、NativeApp?


§你移动端前端开发的理解?(和Web前端开发的主要区别是什么?)


§你对加班的看法?


§平时如何管理你的项目?


§说说最近最流行的一些东西吧?常去哪些网站?


§如何设计突发大规模并发架构?


§说说最近最流行的一些东西吧?常去哪些网站?


§是否了解开源的工具bower、npm、yeoman、grunt、gulp,一个npm的包里的package.json
具备的必要的字段都有哪些?(名称、版本号,依赖)


§每个模块的代码结构都应该比较简单,且每个模块之间的关系也应该非常清晰,随着功能和迭代次数越来越多,你会如何去保持这个状态的?


§Git知道branch,diff,merge么?


§如何设计突发大规模并发架构?


§当团队人手不足,把功能代码写完已经需要加班的情况下,你会做前端代码的测试吗?


§说说最近最流行的一些东西吧?平时常去哪些网站?


§知道什么是SEO并且怎么优化么?知道各种metadata的含义么?


§移动端(AndroidIOS)怎么做好用户体验?


§简单描述一下你做过的移动APP项目研发流程?


§你在现在的团队处于什么样的角色,起到了什么明显的作用?


§你认为怎样才是全端工程师(FullStackdeveloper)?


§介绍一个你最得意的作品吧?


§你有自己的技术博客吗,用了哪些技术?


§对前端安全有什么看法?


§是否了解Web注入攻击,说下原理,最常见的两种攻击(XSS和CSRF)了解到什么程度?


§项目中遇到国哪些印象深刻的技术难题,具体是什么问题,怎么解决?。


§最近在学什么东西?


§你的优点是什么?缺点是什么?


§如何管理前端团队?


§最近在学什么?能谈谈你未来3,5年给自己的规划吗?


§
以上就是小编今天为大家分享的关于web前端工程师面试题的文章,希望本篇文章能够对正准备学习编程技术的小伙伴们有所帮助。想要了解更多web前端相关知识记得关注北大青鸟web前端培训官网哦!最后希望小伙伴们能够好好准备这些问题的答案,在面试中取得好成绩,成为一名优秀的web前端工程师!


§