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

前端开发的基本面试题

发布时间: 2022-10-02 09:42:34

前端开发工程师面试题目大全

HTML

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


HTML5为什么只需要写?


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


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


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


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


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


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


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


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


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


iframe有那些缺点?


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


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


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


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


页面可见性(PageVisibilityAPI)可以有哪些用途?


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


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


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


title与h1的区别、b与strong的区别、i与em的区别?


CSS


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


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


CSS优先级算法如何计算?


CSS3新增伪类有那些?


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


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


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


CSS3有哪些新特性?


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


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


css多列等高如何实现?


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


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


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


为什么要初始化CSS样式?


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


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


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


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


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


请解释一下为什么需要清除浮动?清除浮动的方式


zoom:1的清楚浮动原理?


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


使用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前有什么区别?


什么是CSS预处理器/后处理器?


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(CommonMoleDefinition)规范区别?


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


JS模块加载器的轮子怎么造,也就是如何实现一个模块加载器?


谈一谈你对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-siderendering么?


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


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


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


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


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


简述一下Handlebars的基本用法?


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


用js实现千位分隔符?(提示:正则+replace)


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


WhatisaPolyfill?


做的项目中,有没有用过或自己实现一些polyfill方案(兼容性处理方案)?


我们给一个dom同时绑定两个点击事件,一个用捕获,一个用冒泡。会执行几次事件,会先执行冒泡还是捕获?


使用JS实现获取文件扩展名?


答案自己先慢慢找哈。

㈡ 一份超全的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前端工程师!


§

㈢ Web前端面试的常见面试题汇总

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

1.渐进增强与优雅降级


渐进增强
并不是一种技术,而是一种设计思想。各个浏览器的渲染能力各不相同,要做一个每个人都能看到的网页、感受到的体验都一致的网站几乎不可能。但还是得网站的可访问性,保证用户在任何环境下都能正常访问网页得核心内容或能使用基本功能(避免网页打不开、排版错误等),并为他们提供当前条件下最好的体验,这就是渐进增强得核心思想。


优雅降级也是一种设计思想,为了保证在高版本浏览器中提供最好的体验,碰到低版本浏览器再降级进行兼容处理,使其能正常浏览。


这两种思想的区别在于:


1.渐进增强是向上兼容,优雅降级是向下兼容;


2.渐进增强是从简单到复杂,优雅降级是从复杂到简单;


3.渐进增强关注的是内容(保证核心内容),优雅降级关注的是浏览体验(为了兼容低版本浏览器)


2.DOCTYPE














作用


DTD(DocumentTypeDefinition,文档类型定义)是一系列的语法规则,用来定义XML或(X)HTML
的文档类型。浏览器会使用它来判断文档类型,决定何种协议来解析,以及切换浏览模式。


DOCTYPE是用来声明文档类型和DTD
规范的,一个主要的用途便是文件的合法性验证。如果文档代码不合法,那么浏览器解析时便会出现一些差错。


HTML5的文档类型声明:





HTML4.01Strict(HTML4.01严格模式)的DTD包含所有HTML
元素和属性,但不包括展示性的和弃用的元素(如font),它的文档类型声明:


"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">


标准模式与怪异模式


怪异模式(Quirks
Mode)用于模拟旧浏览器的行为。早期的网站并不会遵循完整的规范,随着浏览器支持越来越多的规范,在那些旧的浏览器中开发的页面在显示时会被破坏。为了向后兼容,浏览器发明了怪异模式,一行错误或无效的
DOCTYPE都会触发怪异模式。


浏览器使用文件开头的DOCTYPE来决定用怪异模式处理或标准模式处理。DOCTYPE
可以确保不同浏览器以相同的方式解析文档,以及执行相同的渲染模式。


怪异模式与标准模式的主要区别:


1.怪异模式的宽度和高度会包含padding和border。标准模式不包含,标准模式下可以通过设置box-sizing:
border-box将标准盒模型转化成怪异模式下的盒模型。


2.怪异模式下,当内容超出容器高度时,会将容器拉伸,而不是溢出。


3.怪异模式下,在表格中的字体样式(如font-size)不会继承。


4.怪异模式下颜色值必须使用十六进制标记法。


3.语义化


HTML5
中的语义化就是让元素、属性或属性值有含义,更准确地标记特定类型的内容。对元素语义化的目的是为了让元素的语义和呈现分离,元素只负责文档内容的结构与含义,而CSS
样式控制内容的呈现,像元素,没有语义但却能将字体变粗,这类元素违背了语义化的目的,将会被废弃。


优点


·使得HTML文档结构清晰、布局合理、主体突出、可读性更强。


·有利于SEO,搜索引擎根据标签来确定上下文和各个关键字的权重。


·方便其他设备解析,如盲人阅读器根据语义渲染网页。


·有利于开发和维护,语义化更具可读性,代码更好维护,与CSS3关系更和谐。


语义化标签


·
定义文档的页眉区域,应作为介绍内容或者导航链接栏的容器;


·footer内容的页脚,通常包含该章节作者、版权数据或者与文档相关的链接等信息;


·article
文档、页面、应用或网站中的独立结构,是可独立分配的、可复用的结构,如在发布中,它可能是论坛帖子、杂志或新闻文章、博客、用户提交的评论、交互式组件,或者其他独立的内容项目;


·nav描述一个含有多个超链接的区域,该区域包含跳转到其他页面或页面内部其他部分的链接列表;


·section表示文档中的一个区域(或节),比如,内容中的一个专题组;


·main定义文档的主要内容,该内容在文档中应当是独一无二的,不包含任何在文档中重复的内容,比如侧边栏,导航栏链接,版权信息,网站
logo,搜索框(搜索框作为文档的主要内容);


·aside
表示一个和其余页面内容几乎无关的部分,被认为是独立于该内容的一部分且可以被单独的拆分出来而不会影响整体。通常表现为侧边栏或嵌入内容。


4.超链接伪类


:link、:visited、:active和:hover的声明顺序是怎样的?


:link表示未访问的链接状态;


:visited表示已访问状态;:active表示激活状态(鼠标按下);:hover表示悬停状态。


推荐顺序是LVHA,即:link:visited:hover:active。理由如下:


·当鼠标悬停在未访问的链接上时,:link和:hover都会命中,如果:hover在:link
之前声明,那么(:hover)就会被覆盖;


·当鼠标悬停在已访问的连接上时,:visited和:hover都会命中,如果:hover在:visited
之前声明,那么(:hover)就会被覆盖;


·当鼠标单击链接时,:active和:hover都会命中,我们大多是想让:hover只在悬停时展示样式,按下鼠标时使用:active
样式,因此:active在:hover之后声明;


·综上,:hover应在:link和:visited之后,在:active之前,因此active在最后。而:link和
:visited两者的顺序无所谓,互不影响。


5.CSS常见的长度单位


CSS中除了px长度单位之外,还有下面几个长度单位:


·pc六分之一英寸,1pc=12pt=1/6*1in=16px;


·pt一磅,72分之一英寸。1pt=1/12_1pc=1/72_1in≈1.33px;


·in一英寸,1in=2.54cm=96px;


·ex在含有“X”字母的字体中,它是该字体的小写字母的高度。对于很多字体来说,1ex≈0.5em;


·em1em等于父级元素的字体大小,2em就是父级元素字体大小的二倍;


·rem当用在根元素()的font-size上面时,它代表了它的初始值;


·ch代表元素所用字体font中“0”这一字形的宽度;


·vh1vh相当于视口高度的1%,100vh就是视口的高度;


·vw1vw相当于视口宽度的1%,100vw就是视口的宽度;


·vmax视口高度vw和宽度vh两者中的最小值


·vmin视口高度vw和宽度vh两种中的最大值;


·%相对于父级元素的大小来确定;


参考:CSS[1]


CSSpercentage[2]


6.事件对象


冒泡与捕获


事件冒泡与捕获是事件处理的两种机制,主要描述当在一个元素上有两个相同类型的事件处理器被激活会发生什么。


在点击子元素时,浏览器运行了两种不同的阶段:捕获阶段和冒泡阶段。捕获阶段的行为:


·浏览器检查元素的最外层祖先,是否在捕获阶段中注册了一个onclick事件处理程序,如果是,则运行它;


·
然后,它移动到中单击元素的下一个祖先元素,并执行相同的操作,然后是单击元素再下一个祖先元素,依此类推,直到到达实际点击的元素;


而冒泡与捕获恰恰相反:


·浏览器检查实际点击的元素是否在冒泡阶段中注册了一个onclick事件处理程序,如果是,则运行它;


·然后它移动到下一个直接的祖先元素,并做同样的事情,然后是下一个,等等,直到它到达元素;


而现代浏览器在默认情况下,所有事件处理程序都在冒泡阶段进行注册。因此上面代码在点击子元素时会先执行子元素绑定的事件,然后向上冒泡,触发父元素绑定的事件。


addEventListener函数的第三个参数是个布尔值。含义:


·当布尔值是false时(这也是默认值),表示向上冒泡触发事件;


·当布尔值是true时,表示向下捕获触发事件;


不能冒泡的事件


有些事件是不会冒泡的。比如:


·blur元素失去焦点时触发,focusout事件也是失去焦点时触发,但可以冒泡;


·focus元素获取焦点时触发;


·mouseenter鼠标移动到元素上时会触发该事件,与之对应的是mouseover事件,但会冒泡;


·mouseleave鼠标离开元素时触发,与之对应的是mouseout,但会冒泡;


事件冒泡可以让我们利用事件委托,尤其是处理大量子元素时,如果给每个子元素都绑定事件,这是不优雅的,可以将事件绑定到父元素上,并让子节点上发生的事件冒泡到父节点上,利用
e.target属性可以获取到当前触发事件的子元素。


事件对象中的方法


·stopPropagation()阻止事件冒泡,当设置后,点击该元素时父元素绑定的事件就不会再触发;


·preventDefault()阻止默认事件的发生;


·stopImmediatePropagation()它用来阻止监听同一事件的其他事件监听器被调用以及阻止事件冒泡,比如给同一个div
元素绑定多个click事件(使用addEventListener方法可以注册多个),当在第二个事件函数中调用
stopImmediatePropagation方法时,点击div元素时,后面注册的click将不会被触发,而且还会阻止事件冒泡;


比如下面的例子,给p绑定多个click事件,在第二个事件函数中调用stopImmediatePropagation,第三个click
事件就不会触发,因为也阻止了冒泡,因此父元素的click事件也不会触发。





paragraph




㈣ 常见的web前端面试题及答案分享

1、 说下行内元素和块级元素的区别?行内块元素的兼容性使用?(IE8 以下)


答:行内元素:会在水平方向排列,不能包含块级元素,设置width无效,height无效(可以设置line-height),margin上下无效,padding上下无效。块级元素:各占据一行,垂直方向排列。从新行开始结束接着一个断行。兼容性:display:inline-block;*display:inline;*zoom:1。



2、box-sizing常用的属性有哪些?分别有什么作用?


答:box-sizing: content-box|border-box|inherit。content-box:宽度和高度分别应用到元素的内容框。在宽度和高度之外绘制元素的内边距和边框(元素默认效果)。


border-box:元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制。通过从已设定的宽度和高度分别减去边框和内边距才能得到内容的宽度和高度。


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


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


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


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


答:HTML5 现在已经不是 SGML 的子集,主要是关于图像,位置,存储,多任务等功能的增加。


(1)绘画 canvas;


(2)用于媒介回放的 video 和 audio 元素;


(3)本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失;


(4)sessionStorage 的数据在浏览器关闭后自动删除;


(5)语意化更好的内容元素,比如 article、footer、header、nav、section;


(6)表单控件,calendar、date、time、email、url、search;


(7)新的技术webworker, websocket, Geolocation;


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


以上就是环球青藤小编关于web前端面试题的相关分享,希望对大家有所帮助,想要了解更多相关内容,请及时关注本平台并进行查看!

㈤ 前端部分面试题整理

(持续更新中)

1)直接通过数组下标赋值 例如 arr[0]=7 。
2)直接改变数组长度 arr.length = 3 。

Array.prototype.slice.call()

Object.prototype.toString.call(obj) === '[object Object]'

混入,可混入data,methods,钩子函数,同名methods 函数、data 变量,组件内的会覆盖掉mixins中的,钩子函数不会,会加入队列,mixins的先执行,组件内的后执行。

等待(pending)、已完成(fulfilled)、已拒绝(rejected)

all必须所有的异步操作全部执行完后才会执行then,race 只接受最快的异步操作

由于箭头函数不绑定this, 它会捕获其所在(即定义的位置)上下文的this值, 作为自己的this值。

call、apply、bind都是改变this指向的方法, bind不立即执行,bind(obj,1,2),call和apply会立即调用,apply(obj,[1,2]),call(obj,1,2)

㈥ 前端面试题整理

JavaScript:

1.介绍一下isNaN函数?

如果参数不是数字类型的话isNaN返回true(函数名称:isnan函数功能:判断数组的元素是否是NaN。)


2.javascript都支持哪些布尔型的操作?


&&,||和!(&&逻辑与,||逻辑或,!逻辑非)


3.“1″+2+4在javascript中得到什么?


因为“1”是String类型,所以所有的操作数都是String,结果为124


4.2+5+”8″得到的结果是什么?


因为2和5是数字类型,8是字符串,所以得到的结果是78


5.javascript有几种loop(循环)方法?


for,while,do-while,for...in语句用于遍历数组或者对象的属性(对数组或者对象的属性进行循环操作)。


6.javascript如何创建一个新的对象?


varobj=newObject()或者varobj={}


7.如何为一个对象属性赋值?


obj["age"]=17或者obj.age=17


8.如何为一个数组添加一个值?


arr[arr.length]=value;


9.javascript基本数据类型/javascript中的typeof返回哪些数据类型


Number类型、Boolean类型、Object类型、String类型、Null、Undefined类型/


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


强制(parseInt,parseFloat,number)隐式(==_===)


11.数组方法pop()push()unshift()shift()


Push()尾部添加pop()尾部删除Unshift()头部添加shift()头部删除


12.闭包是什么,有什么特性,对页面有什么影响


闭包就是能够读取其他函数内部变量的函数。


13.添加删除替换插入到某个接点的方法


obj.appendChild()obj.innersetBefore()obj.replaceChild()obj.removeChild()


14.javascript的本地对象,内置对象和宿主对象


本地对象为arrayobjregexp等可以new实例化


内置对象为gloadMath等不可以实例化的


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


15.介绍一下eval()函数


eval()函数可计算某个字符串,并执行其中的的JavaScript代码。


16.介绍一下JSON


JSON:JavaScript对象表示法(JavaScriptObjectNotation)。


JSON是存储和交换文本信息的语法。类似XML。


JSON比XML更小、更快,更易解析。


17.jQueryUI与jquery的主要区别是:


(1)jQuery是一个js库,主要提供的功能是选择器,属性修改和事件绑定等等。


(2)jQueryUI则是在jQuery的基础上,利用jQuery的扩展性,设计的插件。提供了一些常用的界面元素,诸如对话框、拖动行为、改变大小行为等等。


(3)jQuery本身注重于后台,没有漂亮的界面,而jQueryUI则补充了前者的不足,他提供了华丽的展示界面,使人更容易接受。既有强大的后台,又有华丽的前台。


html+css:


1.对WEB标准以及W3C的理解与认识:


标签闭合、标签小写、不乱嵌套、提高搜索机器人搜索几率、使用外链css和js脚本、结构行为表现的分离、文件下载与页面速度更快、内容能被更多的用户所访问、内容能被更广泛的设备所访问、更少的代码和组件,容易维护、改版方便,不需要变动页面内容、提供打印版本而不需要复制内容、提高网站易用性;


2.xhtml和html有什么区别:


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


最主要的不同:


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


XHTML元素必须被关闭。


标签名必须用小写字母。


XHTML文档必须拥有根元素。


3.行内元素有哪些?块级元素有哪些?CSS的盒模型?


块级元素:divph1h2h3h4formul


行内元素:abbrispaninputselect


Css盒模型:内容,border,margin,padding


4.前端页面有哪三层构成,分别是什么?作用是什么?


结构层Html表示层CSS行为层js


5.写出几种IE6BUG的解决方法:


双边距BUGfloat引起的使用display


3像素问题使用float引起的使用dislpay:inline-3px


超链接hover点击后失效使用正确的书写顺序linkvisitedhoveractive


Iez-index问题给父级添加position:relative


Png透明使用js代码改


Min-height最小高度!Important解决’


select在ie6下遮盖使用iframe嵌套


为什么没有办法定义1px左右的宽度容器(IE6默认的行高造成的,使用over:hidden,zoom:0.08line-height:1px)


6.解释csssprites,如何使用。


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


7.你如何对网站的文件和资源进行优化?期待的解决方案包括:


文件合并


文件最小化/文件压缩


使用CDN托管


缓存的使用


8.清除浮动的几种方式,各自的优缺点:


使用空标签清除浮动clear:both(理论上能清楚任何标签,,,增加无意义的标签)


使用overflow:auto(空标签元素清除浮动而不得不增加无意代码的弊端,,使用zoom:1用于兼容IE)


是用afert伪元素清除浮动(用于非IE浏览器)


9.浏览器内核


1、Trident内核:IE最先开发或使用的,也称IE内核,360浏览器使用的也是IE内核;


2、Webkit内核:谷歌chrome浏览器最先开发或使用,也叫谷歌内核,枫树浏览器、太阳花使用的也是谷歌内核;


3、Gecko内核:Netscape6开始采用的内核,后来的MozillaFireFox(火狐浏览器)也采用了该内核,K-Meleon浏览器也是使用这种内核;


4、Presto内核:目前只有Opera浏览器采用该内核

㈦ 你遇到的前端面试题都有什么

大家好,我是王我。

随着春节的结束,各个行业也普遍开始了上班的节奏, 不过本人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.项目经验,让你讲讲做过的项目,遇到的问题和解决之道

㈧ 前端常见面试题

前端开发可能问到的问题:
自我介绍(一定要对项目很熟悉)
ui-app web前端技术体系?

响应式怎么做?

render跟状态的差异
类组件的生命周期?
阻止冒泡,阻止事件默认行为
文本垂直居中。 line-height设置为元素高度。

用rece讲数组中的对象进行合并
解释localstorage sessionstorage cookie
eventbus满足event.on('eventname', callback)

display有几个值?默认值?
position有几个值?默认值?
div水平垂直居中?
position有哪些值

react相关问题(概念理解、通讯组件等)、react常用内置
React-router
html+css

页面增删改查

position的值 absolute relative fixed static

工作中是怎么联调和上线的(现场想合适的前后端联调方式,能和webpack环境切换联系起来)
antd的Form shouldUpdate增量更新方式,性能优化。
对Hooks的理解

3:操作dom点击事件向服务器上传数据,在上传未完成之前不可重复操作事件
4:日期格式化,日期不足前两位补0(2021-06-06 06:06:00)

用css写一个布局,左侧固定宽度,右侧自适应

你看

㈨ 前端面试题整理(一)

进程是CPU资源分配的最小单位,线程是CPU调度的最小单位

其中GUI渲染线程和JS引擎是无法同时工作的

默认情况下, TCP 连接会启用延迟传送算法 (Nagle 算法), 在数据发送之前缓存他们. 如果短时间有多个数据发送, 会缓冲到一起作一次发送 (缓冲大小见 socket.bufferSize), 这样可以减少 IO 消耗提高性能.

如果是传输文件的话, 那么根本不用处理粘包的问题, 来一个包拼一个包就好了. 但是如果是多条消息, 或者是别的用途的数据那么就需要处理粘包.

可以参见网上流传比较广的一个例子, 连续调用两次 send 分别发送两段数据 data1 和 data2, 在接收端有以下几种常见的情况:

A. 先接收到 data1, 然后接收到 data2 .
B. 先接收到 data1 的部分数据, 然后接收到 data1 余下的部分以及 data2 的全部.
C. 先接收到了 data1 的全部数据和 data2 的部分数据, 然后接收到了 data2 的余下的数据.
D. 一次性接收到了 data1 和 data2 的全部数据.
其中的 BCD 就是我们常见的粘包的情况. 而对于处理粘包的问题, 常见的解决方案有:

多次发送之前间隔一个等待时间
关闭 Nagle 算法
进行封包/拆包

通过滑动窗口协议(连续ARQ协议)实现,保证了分组无差错、有序接收、流量控制。接收方返回的ACK中会包含自己的接收窗口的大小,并且利用大小来控制发送方的数据发送。

当发送者收到了一个窗口为0的应答,发送者便停止发送,等待接收者的下一个应答。如果这个窗口不为0的应答在传输过程中丢失,发送者一直等待,接收者以为发送者收到该应答,等待接收新数据,这样双方就相互等待,从而产生死锁

TCP使用了持续计时器。每当发送者收到一个0窗口的应答后就启动该计时器。计时器到时便主动发送报文询问接收者的窗口大小。若接收者仍然返回0窗口,则重置该计时器继续等待;若窗口不为0,则标识应答报文丢失了,此时重置发送窗口开始发送,这样就避免了死锁的产生

拥塞控制是作用于网络的,防止网络负载过大,常用的方法:1.慢启动、拥塞避免 2.快重传、快恢复。流量控制是作用于接收者的,控制发送者的发送速度使接收者来得及接收,防止分组丢失

发送方维持一个叫做拥塞窗口CWnd的状态变量,控制着传输速度,TCP开始发送报文时CWnd=1。一个传输轮次所经历的时间就是往返时间RTT,每经过一个RTT并且按时收到确认,就将拥塞窗口CWnd加倍。还有一个叫慢启动门限ssthresh的状态变量,当CWnd<ssthresh时,使用慢启动,当CWnd>=ssthresh改用拥塞避免算法

每经过一个往返时间RTT就把发送方的拥塞窗口cwnd加1而不是加倍。无论在慢启动阶段还是拥塞避免阶段,只要发送方没有按时收到确认,就把慢启动门限设置为出现拥塞时的拥塞窗口cwnd的一半(但不小于2)。然后把拥塞窗口cwnd重置为1,执行慢启动算法

接收方收到一个失序的报文段后就立刻发出重复确认而不是等到自己发送数据时捎带确认。只要发送方一连收到三个重复确认就立即重传对方尚未收到的报文段,而不是等待重传计时器到期

当发送方连续收到三个重复确认时,把慢启动门限ssthresh减半,但是并不执行慢开始算法,而是将拥塞窗口cwnd设置为ssthresh减半后的值,直接执行拥塞避免算法。快重传配合快恢复的TCP Reno版本是目前使用最广的版本。

帧:HTTP/2 数据通信的最小单位消息:指 HTTP/2 中逻辑上的 HTTP 消息。例如请求和响应等,消息由一个或多个帧组成。
流:存在于连接中的一个虚拟通道。流可以承载双向消息,每个流都有一个唯一的整数ID

HTTP/1.x会在请求和响应中中重复地携带不常改变的、冗长的头部数据,给网络带来额外的负担。

服务端可以在发送页面HTML时主动推送其它资源,而不用等到浏览器解析到相应位置,发起请求再响应。例如服务端可以主动把JS和CSS文件推送给客户端,而不需要客户端解析HTML时再发送这些请求。

服务端可以主动推送,客户端也有权利选择是否接收。如果服务端推送的资源已经被浏览器缓存过,浏览器可以通过发送RST_STREAM帧来拒收。主动推送也遵守同源策略,服务器不会随便推送第三方资源给客户端。

HTTP 1.x 中,如果想并发多个请求,必须使用多个 TCP 链接,且浏览器为了控制资源,还会对单个域名有 6-8个的TCP链接请求限制。

HTTP2中:

同域名下所有通信都在单个连接上完成。
单个连接可以承载任意数量的双向数据流。
数据流以消息的形式发送,而消息又由一个或多个帧组成,多个帧之间可以乱序发送,因为根据帧首部的流标识可以重新组装

前端面试与进阶指南
从输入URL到页面加载的过程?如何由一道题完善自己的前端知识体系!

㈩ 前端常见面试题-hr

因为前端是用户最直观能接触和交互的地方,所有 “用户体验”最重要。

早期学习都是有点野路子,遇到问题解决问题,
后面发现有很多问题没有系统的学习 很难分析出具体的问题,
然后会开始看一下比较基本和底层一点的书或者视频,包括一些api。
有了系统的知识后,就可以去研究相关一些大神的源码,当然也借鉴了很多人的学习心的再去慢慢消化。
如果单纯看和听 其实我觉得只能吸收10%左右。
我一般会把学习的内容和工作上解决了比较难的问题都通过 掘金或者的方式记录下来。这样我觉可以消化40%的内容。
最后最好的学习方法,当然是给别人说一遍,这也是我们前端组为什么每个月做技术分享的原因。
这样我觉得可以最整个知识跟深刻的思考和别人互动互相检验学习的质量。

首先我确实挺感谢我现在公司,因为我之前去过外包公司,我深刻的感受到企业文化对公司的重要性。倡导以员工的成长为主,
公司会定期给我们请外面的老师做管理干部的培训,有管理的有经验的。确实让我学习了很多成长了很多。
不过由于我们是传统服装制造业,对于技术的迭代和要求没那么高,我在这里也工作了6年多,我自身也感觉有点 开始进入舒适区的感觉,
我想在新的环境,跟更多行业优秀的人才一起学习,让自己做一个T字型人才,把纵向的技术能力扎深扎稳。

应该就是capp项目,由于公司战略要求,要在3个月内完成原来capp工时工序客户端系统到web的切换,两个前端,两个后端,由于周期短,要在短时间交付项目成果,确实是一个很难解决的大难题。
(1)首先我觉得沟通很重要,在需求方面,我和后端组长积极与产品沟通,分析系统各个模块的使用场景和优先级。把最关键的核心模块提取出来,优先开发,并与领导协商后面再继续迭代其他基础功能。 每个功能都讨论仔细避免交付时才返工。
(2)在框架上,一个稳定的容用的框架是高效迭代开发所必须的,所以作为框架的搭建就刻不容缓,我和后端负责人也是沟通分析赶工,不断打磨一个稳定有效的框架。制定了很多约定与规范。
(3)在时间上,打包比较花时间,为了解放不必要的投入,我引进入CI/CD工具,大量的节省了前端后端的部署时间。把精力都花在刀刃上。
(4)团队的氛围, 毕竟还有很多功能要开发,加班是再所难免。
其实我觉得人加班为什么会累,一/般是一个人在奋战,会感到孤独和无助。所以我们采取在关键节点交付前集体加班的方式,由于大家都在,即保证了开发过程的效率,也可以避免007的噩梦。
(5)仪式感与明确的目标,跟上级申请项目立项,让公司发起启动会,让每一个参与开发同事有仪式感,意识自己参与项目的重要性与意义。并申请项目奖金,在每个阶段性节点按时交付,我们都给予员工及时的奖励和认可,由于有了明确的目标和方向。

整体项目最终以2个半月交付核心业务功能,4个月后完成整个系统所有功能交付,并顺利上线。

我们喜欢的运动是羽毛球,平时喜欢用碎片化的时间 听得到的一些可能,有it类的有经济学类的,可以扩充自身的视野。
还是在掘金写写博客。