本文由我收集总结了一些前端面试题,初学者阅后也要用心钻研其中的原理,重要知识需要系统学习、透彻学习,形成自己的知识链。万不可投机取巧,临时抱佛脚只求面试侥幸混过关是错误的!也是不可能的!不可能的!不可能的
前端还是一个年轻的行业,新的行业标准, 框架, 库都不断在更新和新增,正如赫门在2015JS大会上的《前端服务化之路》主题演讲中说的一句话:“每18至24个月,前端都会难一倍”,这些变化使前端的能力更加丰富、创造的应用也会更加完美。所以关注各种前端技术,跟上快速变化的节奏,也是身为一个前端程序员必备的技能之一。

目录

1.面试注意
2.HTML
    2.1 Doctype作用?标准模式与兼容模式各有什区别?
    2.2 HTML5 为什么只需要写 !DOCTYPE HTML?
    2.3 行内元素有哪些?块级元素有哪些? 空(void)元素有那些?
    2.4 页面导入样式时,使用link和@import有什么区别?
    2.5 介绍一下你对浏览器内核的理解?
    2.6 常见的浏览器内核有哪些?
    2.7 html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?
    2.8 简述一下你对HTML语义化的理解?
    2.9 HTML5的离线储存怎么使用,工作原理能不能解释一下?
    2.10 浏览器是怎么对HTML5的离线储存资源进行管理和加载的呢?
    2.11 请描述一下 cookies,sessionStorage 和 localStorage 的区别?
    2.12 iframe有那些缺点?
3.CSS
4.JavaScript

1.面试注意

面试有几点需注意

  1. 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。
  2. 题目类型: 理论知识、算法、项目细节、技术视野、开放性题、工作案例。
  3. 细节追问: 可以确保问到你开始不懂或面试官开始不懂为止,这样可以大大延展题目的区分度和深度,知道你的实际能力。因为这种知识关联是长时期的学习,临时抱佛脚绝对是记不住的。
  4. 回答问题再棒,面试官(可能是你面试职位的直接领导),会考虑我要不要这个人做我的同事?所以态度很重要、除了能做事,还要会做人。(感觉更像是相亲)
  5. 资深的前端开发能把absolute和relative弄混,这样的人不要也罢,因为团队需要的是:你这个人具有可以依靠的才能(靠谱)。

前端开发知识点

  • HTML&CSS:
    对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功:布局、盒子模型、选择器优先级、HTML5、CSS3、Flexbox
  • JavaScript:
    数据类型、运算、对象、Function、继承、闭包、作用域、原型链、事件、RegExp、JSON、Ajax、DOM、BOM、内存泄漏、跨域、异步装载、模板引擎、前端MVC、路由、模块化、Canvas、ECMAScript 6、Nodejs
  • 其他:
    移动端、响应式、自动化构建、HTTP、离线存储、WEB安全、优化、重构、团队协作、可维护、易用性、SEO、UED、架构、职业生涯、快速学习能力

作为一名前端工程师,无论工作年头长短都应该掌握的知识点:

  1. DOM结构 —— 两个节点之间可能存在哪些关系以及如何在节点之间任意移动。
  2. DOM操作 —— 如何添加、移除、移动、复制、创建和查找节点等。
  3. 事件 —— 如何使用事件,以及IE和标准DOM事件模型之间存在的差别。
  4. XMLHttpRequest —— 这是什么、怎样完整地执行一次GET请求、怎样检测错误。
  5. 严格模式与混杂模式 —— 如何触发这两种模式,区分它们有何意义。
  6. 盒模型 —— 外边距、内边距和边框之间的关系,及IE8以下版本的浏览器中的盒模型
  7. 块级元素与行内元素 —— 怎么用CSS控制它们、以及如何合理的使用它们
  8. 浮动元素 —— 怎么使用它们、它们有什么问题以及怎么解决这些问题。
  9. HTML与XHTML —— 二者有什么区别,你觉得应该使用哪一个并说出理由。
  10. JSON —— 作用、用途、设计结构。
2.HTML
2.1 Doctype作用?标准模式与兼容模式各有什区别?
  1. 声明位于位于HTML文档中的第一行,处于 标签之前。告知浏览器的解析器用什么文档标准解析这个文档。DOCTYPE不存在或格式不正确会导致文档以兼容模式呈现。
  2. 标准模式的排版 和JS运作模式都是以该浏览器支持的最高标准运行。在兼容模式中,页面以宽松的向后兼容的方式显示,模拟老式浏览器的行为以防止站点无法工作。
2.2 HTML5 为什么只需要写 !DOCTYPE HTML?

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

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

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

  1. 行内元素有:a b span img input select strong(强调的语气)
  2. 块级元素有:div ul ol li dl dt dd h1 h2 h3 h4…p
  3. 常见的空元素:
    <br> <hr> <img> <input> <link> <meta>
    鲜为人知的是:
    <area> <base> <col> <command> <embed> <keygen> <param> <source> <track> <wbr>

不同浏览器(版本)、HTML4(5)、CSS2等实际略有差异
参考: http://stackoverflow.com/questions/6867254/browsers-default-css-for-html-elements

2.4 页面导入样式时,使用link和@import有什么区别?
  1. link属于XHTML标签,除了加载CSS外,还能用于定义RSS, 定义rel连接属性等作用;而@import是CSS提供的,只能用于加载CSS;
  2. 页面被加载的时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载;
  3. import是CSS2.1 提出的,只在IE5以上才能被识别,而link是XHTML标签,无兼容问题。
2.5 介绍一下你对浏览器内核的理解?

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

  • 渲染引擎:负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,然后会输出至显示器或打印机。浏览器的内核的不同对于网页的语法解释会有不同,所以渲染的效果也不相同。所有网页浏览器、电子邮件客户端以及其它需要编辑、显示网络内容的应用程序都需要内核。
  • JS引擎则:解析和执行javascript来实现网页的动态效果。
    最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独立,内核就倾向于只指渲染引擎。
2.6 常见的浏览器内核有哪些?

Trident内核:IE,MaxThon,TT,The World,360,搜狗浏览器等。[又称MSHTML]
Gecko内核:Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等
Presto内核:Opera7及以上。[Opera内核原为:Presto,现为:Blink]
Webkit内核:Safari,Chrome等。[ Chrome的:Blink(WebKit的分支)]
详细文章:浏览器内核的解析和对比

2.7 html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?
  • HTML5 现在已经不是 SGML 的子集,主要是关于图像,位置,存储,多任务等功能的增加。
    绘画 canvas;
    用于媒介回放的 video 和 audio 元素;
    本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失;
    sessionStorage 的数据在浏览器关闭后自动删除;
    语意化更好的内容元素,比如 article、footer、header、nav、section;
    表单控件,calendar、date、time、email、url、search;
    新的技术webworker, websocket, Geolocation
  • 移除的元素:
    纯表现的元素:basefont,big,center,font, s,strike,tt,u;
    对可用性产生负面影响的元素:frame,frameset,noframes
  • 支持HTML5新标签:
    IE8/IE7/IE6支持通过document.createElement方法产生的标签,
    可以利用这一特性让这些浏览器支持HTML5新标签,
    浏览器支持新标签后,还需要添加标签默认的样式
    当然也可以直接使用成熟的框架、比如html5shim;
<!--[if lt IE 9]><script> src="http://html5shim.googlecode.com/svn/trunk/html5.js"</script>
<![endif]-->
  • 如何区分HTML5: DOCTYPE声明/新增的结构元素/功能元素
2.8 简述一下你对HTML语义化的理解?

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

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

在用户没有与因特网连接时,可以正常访问站点或应用,在用户与因特网连接时,更新用户机器上的缓存文件。
原理:HTML5的离线存储是基于一个新建的.appcache文件的缓存机制(不是存储技术),通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来。之后当网络在处于离线状态下时,浏览器会通过被离线存储的数据进行页面展示。

如何使用:
1. 页面头部像下面一样加入一个manifest的属性;
2. 在cache.manifest文件的编写离线存储的资源;
CACHE MANIFEST
#v0.11
CACHE:
js/app.js
css/style.css
NETWORK:
resourse/logo.png
FALLBACK:
/ /offline.html
3. 在离线状态时,操作window.applicationCache进行需求实现。

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

在线的情况下,浏览器发现html头部有manifest属性,它会请求manifest文件,如果是第一次访问app,那么浏览器就会根据manifest文件的内容下载相应的资源并且进行离线存储。如果已经访问过app并且资源已经离线存储了,那么浏览器就会使用离线的资源加载页面,然后浏览器会对比新的manifest文件与旧的manifest文件,如果文件没有发生改变,就不做任何操作,如果文件改变了,那么就会重新下载文件中的资源并进行离线存储。
离线的情况下,浏览器就直接使用离线存储的资源。

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

cookie是网站为了标示用户身份而储存在用户本地终端(Client Side)上的数据(通常经过加密)。
cookie数据始终在同源的http请求中携带(即使不需要),记会在浏览器和服务器间来回传递。
sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。

存储大小:
cookie数据大小不能超过4k。
sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大。

有期时间:
localStorage:存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;
sessionStorage:数据在当前浏览器窗口关闭后自动删除。
cookie:设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭

2.12 iframe有那些缺点?
  • iframe会阻塞主页面的Onload事件;
  • 搜索引擎的检索程序无法解读这种页面,不利于SEO;
  • iframe和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的并行加载。

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

前端面试题(不定期更新)相关推荐

  1. 100道最常见的校招前端面试题(更新中)

    Http协议中Post和Get方法的区别? Get请求比Post执行更有效率,是因为浏览器在发送Post请求时,会先将请求头发送给服务器确认,服务器返回100 continue响应后,浏览器才开始发送 ...

  2. 初级前端面试题(更新中)

    一.html+css 1.css 实现元素水平垂直居中 1.1绝对定位(已知宽高) width:100px;height: 100px;position: absolute;left: 50%;top ...

  3. web前端面试题(面试题大全)

    web前端面试题[持续更新中...] React系列 UmiJS系列 Webpack系列 ES6系列 Vue系列 JavaScript系列 CSS系列 HTTP系列 模块化系列 版本控制系列 Type ...

  4. 前端面试题整理(定期更新)

    前言 因为面试的原因,最近又开始关注前端面试题,浏览过网上很多面试题集合,有很多小伙伴整理的很全面,但是我发现其中有很多技术点在当下已不再流行,而面试题一般都是映射开发中常遇到的一些技能和问题,再结合 ...

  5. 详细前端面试题javascript篇--持续更新

    最新前端面试题汇总大全(超详细含vue,react,css,js,webpack,性能优化等)–持续更新点击查看 前端HTML篇 前端CSS篇 前端面试题js篇--持续更新 1. JS 数据类型 ?存 ...

  6. 前端面试题总结【持续更新···】

    前端面试题总结 1.说说你对react的理解?有哪些特性? 2.说说React diff算法是怎么运作的? 3.说说React生命周期有哪些不同的阶段?每个阶段对应的方法是? 4.说说你对React中 ...

  7. 前端面试题整理(会不断更新哦!~~~~~)

    前端面试题 1.bind, call, apply有什么区别? 1.都是改变this的指向 2.call和apply会立即执行函数,bind会返回一个新函数 3.传参不同,call和bind是对象传参 ...

  8. react前端面试题(实时更新)

    React前端面试题 1. 对React-Fiber的理解,他解决了什么问题 2.对webSocket的理解 4.说说你对koa中洋葱模型的理解? 5.说说package.json中版本号的规则? 6 ...

  9. 2022年最新互联网大厂前端面试题及答案-前端工程必备技能(持续整理更新中【关注收藏不迷路】)

    对于做前端的朋友,或者做了前端几年了,基础不好的,或者想进大厂的想了解深入,下面的知识点很多前端朋友都没有深入了解.很重要,看完有种茅塞顿开感觉,**关注+收藏哦,总有一天用的得.** 涉及到知识点: ...

  10. 最新前端面试题整理和答案(全)一直更新

    最新前端面试题整理和答案(全) 参考地址:https://blog.csdn.net/wdlhao/article/details/79079660 javascript: JavaScript中如何 ...

最新文章

  1. ContentObserver类的使用
  2. java求婚代码_屌丝程序员的求婚道具--内含视频
  3. OpenCV2学习笔记(一)
  4. TensorFlow 教程 --进阶指南--3.3可视化学习
  5. lisp如何调用linux头文件,Lisp之 程序的交互执行和非交互执行
  6. python下:用 matplotlib.pyplot 显示 Opencv 读取的图像
  7. 获取Linux服务器信息脚本
  8. SQL Server数据库的管理
  9. 分享接手的Android项目如何打包
  10. python scrapy框架 简书_7、Python Scrapy框架,简单学习
  11. 超级冷笑话,冷死人不偿命
  12. whisper客服源码_whisper客服系统兼容HTTPS方案
  13. win7安不了python_win7下安装python失败问题
  14. 07169软件开发工具与环境考试大纲
  15. 真无线蓝牙耳机排名前十的品牌,公认佩戴舒适性好的蓝牙耳机分享
  16. 在arm-linux上用gdb调试程序,出现“Program received signal SIGPIPE, Broken pipe”
  17. ps人物磨皮美容插件:Pro Retouch Panel(支持ps2021)
  18. PHP 在线预览文档
  19. linux平台性能监控系统,如何使用top命令监控Linux系统性能
  20. 灵感:从想法的天空到现实的地面

热门文章

  1. 计算机网络验证性实践
  2. mysql workbench 安全模式_MySQL Workbench解决安全模式
  3. LOGO特训营 第三节 首字母创意手法
  4. 案例|双循环下的国货自信:波司登抵御寒冬的新战袍
  5. 阿里Leader都干些啥
  6. CTF 小白教程《从0到1:CTFer成长之路》SQL - 2 解题过程
  7. 模拟器使用Fiddler代理后,浏览器报错【该网站的安全证书有问题】解决方法
  8. [分享]加拿大渥太华市卡尔顿大学John W. Chinneck教授谈如何组织论文
  9. OVM虚拟化开启公测,支持Docker全新体验!
  10. matlab fft能量守恒吗,功能关系 能量守恒定律