史上最全的web前端面试题汇总及答案,2024年最新面试题目与答案

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

cellpadding:代表单元格边框到内容之间的距离(留白)

cellspacing:cellspacing属性用来指定表格各单元格之间的空隙。此属性的参数值是数字,表示单元格间隙所占的像素点数。

4、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

优先级

优先级就近原则,同权重情况下样式定义最近者为准,载入样式以最后载入的定位为准;

优先级为:

!important > id > class > tag

important 比 内联优先级高

CSS3新增伪类举例

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

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

p:only-of-type 选择属于其父元素唯一的<p>元素的每个<p>元素。

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

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

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

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

5、display与visibility有何异同?

display可以有很多值,visibility只有两个常用值:visible、hidden。

当display为none、visibility为hidden时都会隐藏元素。但display会隐藏掉元素空间,visibility会保留元素空间。

6、怎么在网页中实现绝对定位?

absolute

绝对定位与相对定位

7、table-layout、border-collapse有何用途?

①table-layout:设置表格是否自动调整宽高

②border-collapse:表格与单元格及单元格间的边框是否融合在一起。

8、简述盒模型

简述盒模型

9、链接标记target属性的_top、_parent、_blank、main、left、top各有何用处?

链接标记target与Dom,Bom

10、你对浏览器兼容怎么看?通常你都做哪些处理?

浏览器的兼容性

11、get和post的区别?

**GET:**一般用于信息获取,使用URL传递参数,对所发送信息的数量也有限制,一般在2000个字符

**POST:**一般用于修改服务器上的资源,对所发送的信息没有限制。

GET方式需要使用Request.QueryString来取得变量的值,而POST方式通过Request.Form来获取变量的值,也就是说Get是通过地址栏来传值,而Post是通过提交表单来传值。

然而,在以下情况中,请使用 POST 请求:

①无法使用缓存文件(更新服务器上的文件或数据库)向服务器发送大量数据(POST 没有数据量限制)。

②发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠。

12、xhtml和html有什么区别

①HTML是一种基本的WEB网页设计语言,XHTML是一个基于XML的置标语言

②最主要的不同:

XHTML 元素必须被正确地嵌套。

XHTML 元素必须被关闭。

标签名必须用小写字母。

XHTML 文档必须拥有根元素。

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

行内元素和块级元素的区别是什么?行内块元素的兼容性使用?(IE8 以下)

**块级元素:**div p h1 h2 h3 h4 form ul ol dl dt dd

行内元素: a b br i span input select image strong(强调的语气)

常见空元素:

<br>/<hr>/<img>/<input>/<link>/<meta>

不常见空元素:

<area>/<base>/<col>/<command>/<embed>/<keygen>/<param>/<source>/<track>/<wbr>

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

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

兼容性:

display:inline-block;*display:inline;*zoom:1;

14、CSS引入的方式有哪些? link和@import的区别是?

CSS引入的方式包括内联 内嵌 外链 导入

link和@import的区别是 :

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

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

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

④后者优先级更高

15、你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?介绍一下你对浏览器内核的理解

Ie(Ie内核) 火狐(Gecko) 谷歌(webkit) opera(blink)

对内核的理解:

主要分成两部分:渲染引擎(layout engineer或Rendering Engine)和JS引擎。

①渲染引擎:负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,然后会输出至显示器或打印机。浏览器的内核的不同对于网页的语法解释会有不同,所以渲染的效果也不相同。所有网页浏览器、电子邮件客户端以及其它需要编辑、显示网络内容的应用程序都需要内核。

②JS引擎:解析和执行javascript来实现网页的动态效果。

最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独立,内核就倾向于只指渲染引擎。

16、解释css sprites,如何使用。

Css 精灵 把一堆小的图片整合到一张大的图片上,减轻服务器对图片的请求数量。

适用于以下情况:

①静态图片,不随用户信息的变化而变化

②小图片,图片容量比较小

③加载量比较大

17、清除浮动的几种方式,各自的优缺点

(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种方式,好多网站都这么用。

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

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

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

注意点:

HTML5 只需要写<!DOCTYPEHTML>不需要对DTD进行引用,因为HTML5不基于 SGML,因此不需要对DTD进行引用,但是需要doctype来规范浏览器的行为(让浏览器按照它们应该的方式来运行)。

而HTML4.01基于SGML,所以需要对DTD进行引用,才能告知浏览器文档所使用的文档类型。

19、iframe有哪些缺点?

①iframe会阻塞主页面的Onload事件,搜索引擎的检索程序无法解读这种页面,不利于SEO;

②iframe和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的并行加载。

使用iframe之前需要考虑这两个缺点。如果需要使用iframe,最好是通过javascript动态给iframe添加src属性值,这样可以绕开以上两个问题。

20、如何实现浏览器内多个标签页之间的通信?

①通过WebSocket、SharedWorker来实现;

②也可以调用localstorge、cookies等本地存储方式。

localstorge另一个浏览上下文(另一个标签页)里被添加、修改或删除时,它都会触发一个事件,我们通过监听事件,控制它的值来进行页面信息通信。

注意quirks:Safari 在无痕模式下设置localstorge值时会抛出 QuotaExceededError 的异常。

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

①map+area或者svg

②border-radius

③纯js实现 需要求一个点在不在圆上简单算法、获取鼠标坐标等等

22、CSS3有哪些新特性?

① CSS3实现圆角(border-radius:8px),阴影(box-shadow:10px);

② 对文字加特效(text-shadow、),线性渐变(gradient),旋转(transform);

③ transform:rotate(9deg) scale(0.85,0.90) translate(0px,-30px) skew(-9deg,0deg);

//旋转,缩放,定位,倾斜

④ 增加了更多的CSS选择器 多背景 rgba

CSS3新增属性

Html5


1、Html5与html4相比,各有何优缺点? 怎样处理html5新标签的兼容性问题?

html5余html4的异同请看以下的链接

html5与html4的异同

兼容性问题

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

Javascript


1、JS如何使页面跳转?怎么引入一个外部JS文件?

①直接在head标签内写入js代码,如下

②引入写好的js文件,使用语句

也是直接放入到head标签里头,也有的是放在前面。

2、输入框的验证用什么事件?

change(fn)

3、undefined与null有何异同?

null是一个表示"无"的对象,转为数值时为0;undefined是一个表示"无"的原始值,转为数值时为NaN。

undefined:

(1)变量被声明了,但没有赋值时,就等于undefined。

(2) 调用函数时,应该提供的参数没有提供,该参数等于undefined。

(3)对象没有赋值的属性,该属性的值为undefined。

(4)函数没有返回值时,默认返回undefined。

null:

(1) 作为函数的参数,表示该函数的参数不是对象。

(2) 作为对象原型链的终点。

它们都表示空,转换为boolean后都为false,但是null代表一个对象变量已经被初始化,但未装入对象;undefined表示未初始化变量

4、=有何异同?

相同点:都是判定两个值是否相等

不同点:不会判断类型,而=会判断类型

5、如何判断一个变量的值是否为数字?以及有哪些手段判断变量值的数据类型?

全局函数isNaN可以判断一个变量的值是否为数字。

可以使用运算符type、instanceof判断变量值的数据类型。

6、什么是Bom什么是Dom?你如何理解Dom?

链接标记target与Dom,Bom

7、Array的join、push、splice、slice各有何用途,splice与slice有何异同?

join:使用指定间隔符连接所有元素为字符串

push:在尾部添加元素并维护array实例的length

splice与slice都是截取一部分元素。不同的在于:slice返回截取后的新实例,splice在原array实例上操作,更详细的请见下文链接。

JS中数组对象详解

8、如何阻止表单提交?

在onsubmit事件中返回false

9、如何动态操作表格?

可以像普通dom一样操作,但是因为表格的dom比较复杂,所以我通常是使用table的insertRow、deleteRow及tr对象的insetCell、deleteCell操作。

10、String.match与RegExp.exec有何区别?

match只会返回没有分组的全部匹配结果或者有分组的第一次匹配结果;

而exec可以利用循环返回全部匹配结果。

11、为验证手机号写一个正则。

function checkSubmitMobil()

{

if ($(“#phoneNum”).val() == “”) {

alert(“手机号码不能为空!”);

//$(“#moileMsg”).html(“手机号码不能为空!”);

$(“#mobile”).focus();

return false;

}

if (!KaTeX parse error: Expected 'EOF', got '#' at position 3: ("#̲phoneNum").val(…/))

{

alert(“手机号码格式不正确!”);

//$(“#moileMsg”).html(“手机号码格式不正确!请重新输入!”);

$(“#phoneNum”).focus();

return false;

}

return true;

}

12、正则的i标记与g标记各有何用途?

i:不区分大小写;

g:全局匹配。

13、为String添加trim()方法。

String.prototype.trim = function() {

return this.replace(/^ +| +$/g,“”);

}

14、简述COOKIE。在JS中如何操作Cookie?

简述cookie,在JS中如何操作cookie

15、谈谈javascript数组排序方法sort()的使用,重点介绍sort()参数的使用及其内部机制。

JS数组排序方法sort()的使用

16、谈谈innerHTML outerHTML innerText之间的区别。

①innerHTML是w3c的html dom定义的方法,而后两者是IE独有的方法;

②innerHTML代表一个元素节点内由所有子节点,不包括当前节点组成的html代码;

③outerHTML代表一个元素节点内由所有子节点和当前节点组成的html代码;

④innerText代表一个元素节点内由所有子文本节点内容组成的文本;

17、在JavaScript中定时调用函数 foo() 如何写?

setTimeout(

foo,

1000 //这里设置延时数

);

18、setTimeout与setInterval有何区别?

①setTimeout和setInterval的语法相同。它们都有两个参数,一个是将要执行的代码字符串,还有一个是以毫秒为单位的时间间隔,当过了那个时间段之后就将执行那段代码。

②不过这两个函数还是有区别的,setInterval在执行完一次代码之后,经过了那个固定的时间间隔,它还会自动重复执行代码,而setTimeout只执行一次那段代码。

19、你在js中用过array吗?如果用过,array中添加数据用什么方法?

在尾部添加使用push();

在头部添加使用unshift();

在任意位置添加使用splice(),但要注意把它的删除个数设置为0;

array详细介绍请看下文链接

JS中数组对象详解

20、简述javascript的优缺点。

**优点:**简单易用,与Java有类似的语法,可以使用任何文本编辑工具编写,只需要浏览器就可执行程序,并且事先不用编译,逐行执行,无需进行严格的变量声明,而且内置大量现成对象,编写少量程序可以完成目标;

**缺点:**不适合开发大型应用程序;

21、Javascript有哪些内置对象?

只有Math和Global(在浏览器环境中,Global就是Window)

22、列举Javascript的本地对象。

Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError

23、javascript的typeof返回哪些数据类型

object number function boolean undefind string

24、例举3种强制类型转换和2种隐式类型转换?

强制(parseInt,parseFloat,number)

隐式(== – ===)

25、IE和DOM事件流的区别

①执行顺序不一样、

②参数不一样

③事件加不加on

④this指向问题

26、事件绑定和普通事件有什么区别

①事件绑定就是针对dom元素的事件,绑定在dom元素上

②普通事件即为非针对dom元素的事件

27、事件委托是什么

利用事件冒泡的原理,让自己的所触发的事件,由他的父元素代替执行!

通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却加到别人身上来做,完成这个事件。

例子请看以下链接

JS中的事件委托

28、闭包是什么,有什么特性,对页面有什么影响

什么是闭包

“官方”的解释:所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。

在 Scala、Scheme、Common Lisp、Smalltalk、Groovy、JavaScript、Ruby、 Python、Go、Lua、objective c、swift 以及Java(Java8及以上)等语言中都能找到对闭包不同程度的支持。

通俗的讲就是函数a的内部函数b,被函数a外部的一个变量引用的时候,就创建了一个闭包。

闭包的特性:

①.封闭性:外界无法访问闭包内部的数据,如果在闭包内声明变量,外界是无法访问的,除非闭包主动向外界提供访问接口;

②.持久性:一般的函数,调用完毕之后,系统自动注销函数,而对于闭包来说,在外部函数被调用之后,闭包结构依然保存在;

对页面的影响

使用闭包会占有内存资源,过多的使用闭包会导致内存溢出等。

详细请看以下推荐链接

深入理解JavaScript的闭包特性 如何给循环中的对象添加事件

29、javascript的本地对象,内置对象和宿主对象

①本地对象为array obj regexp等可以new实例化

②内置对象为gload Math 等不可以实例化的

③宿主为浏览器自带的document,window 等

30、编写一个数组去重的方法

思路:

1.创建一个新的数组存放结果

2.创建一个空对象

3.for循环时,每次取出一个元素与对象进行对比,如果这个元素不重复,则把它存放到结果数组中,同时把这个元素的内容作为对象的一个属性,并赋值为1,存入到第2步建立的对象中。

说明:至于如何对比,就是每次从原数组中取出一个元素,然后到对象中去访问这个属性,如果能访问到值,则说明重复。

代码如下:

Array.prototype.unique3 = function(){

var res = [];

var json = {};

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

if(!json[this[i]]){

res.push(this[i]);

json[this[i]] = 1;

}

}

return res;

}

var arr = [112,112,34,‘你好’,112,112,34,‘你好’,‘str’,‘str1’];

alert(arr.unique3());

31、this对象的理解

①this总是指向函数的直接调用者(而非间接调用者);

②如果有new关键字,this指向new出来的那个对象;

③在事件中,this指向触发这个事件的对象,特殊的是,IE中的attachEvent中的this总是指向全局对象Window;

32、eval是做什么的?

①它的功能是把对应的字符串解析成JS代码并运行;

②应该避免使用eval,不安全,非常耗性能(2次,一次解析成js语句,一次执行)。

③由JSON字符串转换为JSON对象的时候可以用eval,var obj =eval('('+ str +')');

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

①创建一个空对象,并且 this 变量引用该对象,同时还继承了该函数的原型。

②属性和方法被加入到 this 引用的对象中。

③新创建的对象由 this 所引用,并且最后隐式的返回 this 。

34、call() 和 apply() 的区别和作用?

①apply()函数有两个参数:第一个参数是上下文,第二个参数是参数组成的数组。如果上下文是null,则使用全局对象代替。

如:function.apply(this,[1,2,3]);

②call()的第一个参数是上下文,后续是实例传入的参数序列。

Vue 编码基础

2.1.1. 组件规范

2.1.2. 模板中使用简单的表达式

2.1.3 指令都使用缩写形式

2.1.4 标签顺序保持一致

2.1.5 必须为 v-for 设置键值 key

2.1.6 v-show 与 v-if 选择

2.1.7 script 标签内部结构顺序

2.1.8 Vue Router 规范

Vue 项目目录规范

2.2.1 基础

2.2.2 使用 Vue-cli 脚手架

2.2.3 目录说明

2.2.4注释说明

2.2.5 其他

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
this 变量引用该对象,同时还继承了该函数的原型。

②属性和方法被加入到 this 引用的对象中。

③新创建的对象由 this 所引用,并且最后隐式的返回 this 。

34、call() 和 apply() 的区别和作用?

①apply()函数有两个参数:第一个参数是上下文,第二个参数是参数组成的数组。如果上下文是null,则使用全局对象代替。

如:function.apply(this,[1,2,3]);

②call()的第一个参数是上下文,后续是实例传入的参数序列。

Vue 编码基础

2.1.1. 组件规范

2.1.2. 模板中使用简单的表达式

2.1.3 指令都使用缩写形式

2.1.4 标签顺序保持一致

2.1.5 必须为 v-for 设置键值 key

2.1.6 v-show 与 v-if 选择

2.1.7 script 标签内部结构顺序

2.1.8 Vue Router 规范

Vue 项目目录规范

2.2.1 基础

2.2.2 使用 Vue-cli 脚手架

2.2.3 目录说明

2.2.4注释说明

2.2.5 其他

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-36brOudg-1713075190850)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 8
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值