还剩58页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
前端开发面试题分类 编程技术本文收集总结了一些前端面试题,初学者阅后也要用心钻研其中的原理,重要知识需要系统学习、透彻学习,形成自己的知识链万不可投机取巧,临时抱佛脚只求面试侥幸混过关是错误的!也是不可能的!不可能的!不可能的!前端还是一个年轻的行业,新的行业标准,框架,库都不断在更新和新增,正如赫门在2015深JS大会上的《前端服务化之路》主题演讲中说的一句话每18至24个月,前端都会难一倍,这些变化使前端的能力更加丰富、创造的应用也会更加完美所以关注各种前端技术,跟上快速变化的节奏,也是身为一个前端程序员必备的技能之一最近也收到许多微博私信的鼓励和更正题目信息,后面会经常更新题目和答案到github博客希望前端er达到既能使用也会表达,对理论知识有自己的理解可根据下面的知识点一个一个去进阶学习,形成自己的职业技能链面试有几点需注意来源寒冬winter 老师,github:@wintercn
1.面试题目根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加
1.
1.题目类型理论知识、算法、项目细节、技术视野、开放性题、工作案例
1.
1.细节追问可以确保问到你开始不懂或面试官开始不懂为止,这样可以大大延展题目的区分度和深度,知道你的实际能力因为这种知识关联是长时期的学习,临时抱佛脚绝对是记不住的
1.
1.回答问题再棒,面试官(可能是你面试职位的直接领导),会考虑我要不要这个人做我的同事?所以态度很重要、除了能做事,还要会做人(感觉更像是相亲•̣̣̣̣̣̥́௰•̣̣̣̣̣̥̀)
1.
1.资深的前端开发能把absolute和relative弄混,这样的人不要也罢,因为团队需要的是你这个人具有可以依靠的才能(靠谱)
1.前端开发知识点HTMLCSS对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功布局、盒子模型、选择器优先级、HTML
5、CSS
3、FlexboxJavaScript数据类型、运算、对象、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——作用、用途、设计结构备注根据自己需要选择性阅读,面试题是对理论知识的总结,让自己学会应该如何表达资料答案不够正确和全面,欢迎欢迎Star和提交issues格式不断修改更新中更新记录2016年3月25日新增ECMAScript6相关问题更新时间:2016-3-25HTMLDoctype作用?标准模式与兼容模式各有什么区别
(1)、!DOCTYPE声明位于位于HTML文档中的第一行,处于html标签之前告知浏览器的解析器用什么文档标准解析这个文档DOCTYPE不存在或格式不正确会导致文档以兼容模式呈现
(2)、标准模式的排版和JS运作模式都是以该浏览器支持的最高标准运行在兼容模式中,页面以宽松的向后兼容的方式显示模拟老式浏览器的行为以防止站点无法工作HTML5为什么只需要写!DOCTYPEHTML?HTML5不基于SGML,因此不需要对DTD进行引用,但是需要doctype来规范浏览器的行为(让浏览器按照它们应该的方式来运行);而HTML
4.01基于SGML所以需要对DTD进行引用,才能告知浏览器文档所使用的文档类型行内元素有哪些?块级元素有哪些?空void元素有那些?首先CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,如div的display默认值为“block”,则为“块级”元素;span默认display属性值为“inline”,是“行内”元素
(1)行内元素有abspanimginputselectstrong(强调的语气)
(2)块级元素有divulollidldtddh1h2h3h4…p
(3)常见的空元素brhrimginputlinkmeta鲜为人知的是areabasecolcommandembedkeygenparamsourcetrackwbr页面导入样式时,使用link和@import有什么区别?
(1)link属于XHTML标签,除了加载CSS外,还能用于定义RSS定义rel连接属性等作用;而@import是CSS提供的,只能用于加载CSS;
(2)页面被加载的时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载;
(3)import是CSS
2.1提出的,只在IE5以上才能被识别,而link是XHTML标签,无兼容问题;介绍一下你对浏览器内核的理解?主要分成两部分渲染引擎layoutengineer或RenderingEngine和JS引擎渲染引擎负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,然后会输出至显示器或打印机浏览器的内核的不同对于网页的语法解释会有不同,所以渲染的效果也不相同所有网页浏览器、电子邮件客户端以及其它需要编辑、显示网络内容的应用程序都需要内核JS引擎则解析和执行javascript来实现网页的动态效果最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独立,内核就倾向于只指渲染引擎常见的浏览器内核有哪些?Trident内核IEMaxThonTTTheWorld360搜狗浏览器等[又称MSHTML]Gecko内核Netscape6及以上版本,FFMozillaSuite/SeaMonkey等Presto内核Opera7及以上[Opera内核原为Presto,现为Blink;]Webkit内核SafariChrome等[Chrome的Blink(WebKit的分支)]详细文章浏览器内核的解析和对比html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分HTML和HTML5?*HTML5现在已经不是SGML的子集,主要是关于图像,位置,存储,多任务等功能的增加绘画canvas;用于媒介回放的video和audio元素;本地离线存储localStorage长期存储数据,浏览器关闭后数据不丢失;sessionStorage的数据在浏览器关闭后自动删除;语意化更好的内容元素,比如article、footer、header、nav、section;表单控件,calendar、date、time、email、url、search;新的技术webworkerwebsocketGeolocation;移除的元素纯表现的元素basefont,big,center,fonts,strike,tt,u;对可用性产生负面影响的元素frame,frameset,noframes;*支持HTML5新标签IE8/IE7/IE6支持通过document.createElement方法产生的标签,可以利用这一特性让这些浏览器支持HTML5新标签,浏览器支持新标签后,还需要添加标签默认的样式当然也可以直接使用成熟的框架、比如html5shim;!--[ifltIE9]scriptsrc=/script![endif]--*如何区分HTML5DOCTYPE声明\新增的结构元素\功能元素简述一下你对HTML语义化的理解?用正确的标签做正确的事情html语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;即使在没有样式CSS情况下也以一种文档格式显示,并且是容易阅读的;搜索引擎的爬虫也依赖于HTML标记来确定上下文和各个关键字的权重,利于SEO;使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解HTML5的离线储存怎么使用,工作原理能不能解释一下?在用户没有与因特网连接时,可以正常访问站点或应用,在用户与因特网连接时,更新用户机器上的缓存文件原理HTML5的离线存储是基于一个新建的.appcache文件的缓存机制不是存储技术,通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来之后当网络在处于离线状态下时,浏览器会通过被离线存储的数据进行页面展示如何使用
1、页面头部像下面一样加入一个manifest的属性;
2、在cache.manifest文件的编写离线存储的资源;CACHEMANIFEST#v
0.11CACHE:js/app.jscss/style.cssNETWORK:resourse/logo.pngFALLBACK://offline.html
3、在离线状态时,操作window.applicationCache进行需求实现详细的使用请参考有趣的HTML5离线存储浏览器是怎么对HTML5的离线储存资源进行管理和加载的呢?在线的情况下,浏览器发现html头部有manifest属性,它会请求manifest文件,如果是第一次访问app,那么浏览器就会根据manifest文件的内容下载相应的资源并且进行离线存储如果已经访问过app并且资源已经离线存储了,那么浏览器就会使用离线的资源加载页面,然后浏览器会对比新的manifest文件与旧的manifest文件,如果文件没有发生改变,就不做任何操作,如果文件改变了,那么就会重新下载文件中的资源并进行离线存储离线的情况下,浏览器就直接使用离线存储的资源详细的使用请参考有趣的HTML5离线存储请描述一下cookies,sessionStorage和localStorage的区别?cookie是网站为了标示用户身份而储存在用户本地终端(ClientSide)上的数据(通常经过加密)cookie数据始终在同源的http请求中携带(即使不需要),记会在浏览器和服务器间来回传递sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存存储大小cookie数据大小不能超过4ksessionStorage和localStorage虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大有期时间localStorage存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;sessionStorage数据在当前浏览器窗口关闭后自动删除cookie设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭iframe有那些缺点?*iframe会阻塞主页面的Onload事件;*搜索引擎的检索程序无法解读这种页面,不利于SEO;*iframe和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的并行加载使用iframe之前需要考虑这两个缺点如果需要使用iframe,最好是通过javascript动态给iframe添加src属性值,这样可以绕开以上两个问题Label的作用是什么?是怎么用的?label标签来定义表单控制间的关系当用户选择该标签时,浏览器会自动将焦点转到和标签相关的表单控件上labelfor=NameNumber:/labelinputtype=“text“name=Nameid=Name/labelDate:inputtype=textname=B//labelHTML5的form如何关闭自动完成功能?给不想要提示的form或某个input设置为autocomplete=off如何实现浏览器内多个标签页之间的通信阿里WebSocket、SharedWorker;也可以调用localstorge、cookies等本地存储方式;localstorge另一个浏览上下文里被添加、修改或删除时,它都会触发一个事件,我们通过监听事件,控制它的值来进行页面信息通信;注意quirks Safari在无痕模式下设置localstorge值时会抛出QuotaExceededError的异常;webSocket如何兼容低浏览器?阿里AdobeFlashSocket、ActiveXHTMLFileIE、基于multipart编码发送XHR、基于长轮询的XHR页面可见性(PageVisibilityAPI)可以有哪些用途?通过visibilityState的值检测页面当前是否可见,以及打开网页的时间等;在页面被切换到其他后台进程的时候,自动暂停音乐或视频的播放;如何在页面上实现一个圆形的可点击区域?
1、map+area或者svg
2、border-radius
3、纯js实现需要求一个点在不在圆上简单算法、获取鼠标坐标等等实现不使用border画出1px高的线,在不同浏览器的标准模式与怪异模式下都能保持一致的效果divstyle=height:1px;overflow:hidden;background:red/div网页验证码是干嘛的,是为了解决什么安全问题区分用户是计算机还是人的公共全自动程序可以防止恶意破解密码、刷票、论坛灌水;有效防止黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试title与h1的区别、b与strong的区别、i与em的区别?title属性没有明确意义只表示是个标题,H1则表示层次明确的标题,对页面信息的抓取也有很大的影响;strong是标明重点内容,有语气加强的含义,使用阅读设备阅读网络时strong会重读,而B是展示强调内容i内容展示为斜体,em表示强调的文本;PhysicalStyleElements--自然样式标签biuspreSemanticStyleElements--语义样式标签strongeminsdelcode应该准确使用语义样式标签但不能滥用如果不能确定时首选使用自然样式标签CSS介绍一下标准的CSS的盒子模型?低版本IE的盒子模型有什么不同的?
(1)有两种,IE盒子模型、W3C盒子模型;
(2)盒模型内容content、填充padding、边界margin、边框border;
(3)区别IE的content部分把border和padding计算了进去;CSS选择符有哪些?哪些属性可以继承?*
1.id选择器(#myid)
2.类选择器(.myclassname)
3.标签选择器(divh1p)
4.相邻选择器(h1+p)
5.子选择器(ulli)
6.后代选择器(lia)
7.通配符选择器(*)
8.属性选择器(a[rel=external])
9.伪类选择器(a:hoverli:nth-child)*可继承的样式font-sizefont-familycolorULLIDLDDDT;*不可继承的样式borderpaddingmarginwidthheight;CSS优先级算法如何计算?*优先级就近原则,同权重情况下样式定义最近者为准;*载入样式以最后载入的定位为准;优先级为:!importantidclasstagimportant比内联优先级高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-child2选择属于其父元素的第二个子元素的每个p元素:after在元素之前添加内容也可以用来做清除浮动:before在元素之后添加内容:enabled:disabled控制表单控件的禁用状态:checked单选框或复选框被选中如何居中div?如何居中一个浮动元素?如何让绝对定位的div居中?给div设置一个宽度,然后添加margin:0auto属性div{width:200px;margin:0auto;}居中一个浮动元素确定容器的宽高宽500高300的层设置层的外边距.div{width:500px;height:300px;//高度可以不设margin:-150px00-250px;position:relative;//相对定位background-color:pink;//方便看效果left:50%;top:50%;}让绝对定位的div居中position:absolute;width:1200px;background:none;margin:0auto;top:0;left:0;bottom:0;right:0;display有哪些值?说明他们的作用block象块类型元素一样显示none缺省值象行内元素类型一样显示inline-block象行内元素一样显示,但其内容象块类型元素一样显示list-item象块类型元素一样显示,并添加样式列表标记table此元素会作为块级表格来显示inherit规定应该从父元素继承display属性的值position的值relative和absolute定位原点是?absolute生成绝对定位的元素,相对于值不为static的第一个父元素进行定位fixed(老IE不支持)生成绝对定位的元素,相对于浏览器窗口进行定位relative生成相对定位的元素,相对于其正常位置进行定位static默认值没有定位,元素出现在正常的流中(忽略topbottomleftrightz-index声明)inherit规定从父元素继承position属性的值CSS3有哪些新特性?新增各种CSS选择器(:not.input所有class不是“input”的节点)圆角(border-radius:8px)多列布局(multi-columnlayout)阴影和反射(Shadow\Reflect)文字特效(text-shadow、)文字渲染(Text-decoration)线性渐变(gradient)旋转(transform)增加了旋转缩放定位倾斜动画,多背景transform:\scale
0.
850.90\translate0px-30px\skew-9deg0deg\Animation:请解释一下CSS3的Flexbox(弹性盒布局模型)以及适用场景?.用纯CSS创建一个三角形的原理是什么?把上、左、右三条边隐藏掉(颜色设为transparent)#demo{width:0;height:0;border-width:20px;border-style:solid;border-color:transparenttransparentredtransparent;}一个满屏品字布局如何设计简单的方式上面的div宽100%,下面的两个div分别宽50%,然后用float或者inline使其不换行即可经常遇到的浏览器的兼容性有哪些?原因,解决方法是什么,常用hack的技巧?*png24位的图片在iE6浏览器上出现背景,解决方案是做成PNG
8.*浏览器默认的margin和padding不同解决方案是加一个全局的*{margin:0;padding:0;}来统一*IE6双边距bug:块属性标签float后,又有横行的margin情况下,在ie6显示margin比设置的大浮动ie产生的双倍距离#box{float:left;width:10px;margin:000100px;}这种情况之下IE会产生20px的距离,解决方案是在float的标签样式控制中加入——_display:inline;将其转化为行内属性_这个符号只有ie6会识别渐进识别的方式,从总体中逐渐排除局部首先,巧妙的使用“\9”这一标记,将IE游览器从所有情况中分离出来接着,再次使用“+”将IE8和IE
7、IE6分离开来,这样IE8已经独立识别css.bb{background-color:#f1ee18;/*所有识别*/.background-color:#00deff\9;/*IE
6、
7、8识别*/+background-color:#a200ff;/*IE
6、7识别*/_background-color:#1e0bd1;/*IE6识别*/}*IE下可以使用获取常规属性的方法来获取自定义属性也可以使用getAttribute获取自定义属性;Firefox下只能使用getAttribute获取自定义属性解决方法:统一通过getAttribute获取自定义属性*IE下even对象有xy属性但是没有pageXpageY属性;Firefox下event对象有pageXpageY属性但是没有xy属性*解决方法(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数*Chrome中文界面下默认会将小于12px的文本强制按照12px显示可通过加入CSS属性-webkit-text-size-adjust:none;解决超链接访问过后hover样式就不出现了被点击访问过的超链接样式不在具有hover和active了解决方法是改变CSS属性的排列顺序:L-V-H-A:a:link{}a:visited{}a:hover{}a:active{}li与li之间有看不见的空白间隔是什么原因引起的?有什么解决办法?行框的排列会受到中间空白(回车\空格)等的影响,因为空格也属于字符这些空白也会被应用样式,占据空间,所以会有间隔,把字符大小设为0,就没有空格了为什么要初始化CSS样式-因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的,如果没对CSS初始化往往会出现浏览器之间的页面显示差异-当然,初始化样式会对SEO有一定的影响,但鱼和熊掌不可兼得,但力求影响最小的情况下初始化最简单的初始化方法*{padding:0;margin:0;}(强烈不建议)淘宝的样式初始化代码bodyh1h2h3h4h5h6hrpblockquotedldtddulollipreformfieldsetlegendbuttoninputtextareathtd{margin:0;padding:0;}bodybuttoninputselecttextarea{font:12px/
1.5tahomaarial\5b8b\4f53;}h1h2h3h4h5h6{font-size:100%;}addresscitedfnemvar{font-style:normal;}codekbdpresamp{font-family:couriernewcouriermonospace;}small{font-size:12px;}ulol{list-style:none;}a{text-decoration:none;}a:hover{text-decoration:underline;}sup{vertical-align:text-top;}sub{vertical-align:text-bottom;}legend{color:#000;}fieldsetimg{border:0;}buttoninputselecttextarea{font-size:100%;}table{border-collapse:collapse;border-spacing:0;}absolute的containingblock容器块计算方式跟正常流有什么不同?无论属于哪种,都要先找到其祖先元素中最近的position值不为static的元素,然后再判断
1、若此元素为inline元素,则containingblock为能够包含这个元素生成的第一个和最后一个inlinebox的paddingbox除marginborder外的区域的最小矩形;
2、否则则由这个祖先元素的paddingbox构成如果都找不到,则为initialcontainingblock补充
1.static默认的/relative简单说就是它的父元素的内容框(即去掉padding的部分)
2.absolute:向上找最近的定位为absolute/relative的元素
3.fixed:它的containingblock一律为根元素html/body,根元素也是initialcontainingblockCSS里的visibility属性有个collapse属性值是干嘛用的?在不同浏览器下以后什么区别?position跟display、margincollapse、overflow、float这些特性相互叠加后会怎么样?对BFC规范块级格式化上下文blockformattingcontext的理解?(W3CCSS
2.1规范中的一个概念它是一个独立容器,决定了元素如何对其内容进行定位以及与其他元素的关系和相互作用)一个页面是由很多个Box组成的元素的类型和display属性决定了这个Box的类型不同类型的Box会参与不同的FormattingContext(决定如何渲染文档的容器)因此Box内的元素会以不同的方式渲染也就是说BFC内部的元素和外部的元素不会互相影响css定义的权重以下是权重的规则标签的权重为1,class的权重为10,id的权重为100,以下例子是演示各种定义的权重值/*权重为1*/div{}/*权重为10*/.class1{}/*权重为100*/#id1{}/*权重为100+1=101*/#id1div{}/*权重为10+1=11*/.class1div{}/*权重为10+10+1=21*/.class
1.class2div{}如果权重相同,则最后定义的样式会起作用,但是应该避免这种情况出现请解释一下为什么会出现浮动和什么时候需要清除浮动?清除浮动的方式移动端的布局用过媒体查询吗?使用CSS预处理器吗?喜欢那个?SASSSASS、LESS没有本质区别,只因为团队前端都是用的SASSCSS优化、提高性能的方法有哪些?浏览器是怎样解析CSS选择器的?在网页中的应该使用奇数还是偶数的字体?为什么呢?margin和padding分别适合什么场景使用?抽离样式模块怎么写,说出思路,有无实践经验?[阿里航旅的面试题]元素竖向的百分比设定是相对于容器的高度吗?全屏滚动的原理是什么?用到了CSS的那些属性?什么是响应式设计?响应式设计的基本原理是什么?如何兼容低版本的IE?视差滚动效果,如何给每页做不同的动画?(回到顶部,向下滑动要再次出现,和只出现一次分别怎么做?)::before和:after中双冒号和单冒号有什么区别?解释一下这2个伪元素的作用如何修改chrome记住密码后自动填充表单的黄色背景?你对line-height是如何理解的?设置元素浮动后,该元素的display值是多少?(自动变成display:block)怎么让Chrome支持小于12px的文字?让页面里的字体变清晰,变细用CSS怎么做?(-webkit-font-smoothing:antialiased;)font-style属性可以让它赋值为obliqueoblique是什么意思?position:fixed;在android下无效怎么处理?如果需要手动写动画,你认为最小时间间隔是多久,为什么?(阿里)多数显示器默认频率是60Hz,即1秒刷新60次,所以理论上最小间隔为1/60*1000ms=
16.7msdisplay:inline-block什么时候会显示间隙?携程移除空格、使用margin负值、使用font-size:
0、letter-spacing、word-spacingoverflow:scroll时不能平滑滚动的问题怎么处理?有一个高度自适应的div,里面有两个div,一个高度100px,希望另一个填满剩下的高度png、jpg、gif这些图片格式解释一下,分别什么时候用有没有了解过webp?什么是Cookie隔离?(或者说请求资源的时候不要让它带cookie怎么做)如果静态文件都放在主域名下,那静态文件请求的时候都带有的cookie的数据提交给server的,非常浪费流量,所以不如隔离开因为cookie有域的限制,因此不能跨域提交请求,故使用非主要域名的时候,请求头中就不会带有cookie数据,这样可以降低请求头的大小,降低请求时间,从而达到降低整体请求延时的目的同时这种方式不会将cookie传入WebServer,也减少了WebServer对cookie的处理分析环节,提高了webserver的http请求的解析速度style标签写在body后与body前有什么区别?什么是CSS预处理器/后处理器?-预处理器例如LESS、Sass、Stylus,用来预编译Sass或less,增强了css代码的复用性,还有层级、mixin、变量、循环、函数等,具有很方便的UI组件模块化开发能力,极大的提高工作效率-后处理器例如PostCSS,通常被视为在完成的样式表中根据CSS规范处理CSS,让其更有效;目前最常做的是给CSS属性添加浏览器私有前缀,实现跨浏览器兼容性的问题JavaScript介绍js的基本数据类型Undefined、Null、Boolean、Number、String介绍js有哪些内置对象?Object是JavaScript中所有对象的父对象数据封装类对象Object、Array、Boolean、Number和String其他对象Function、Arguments、Math、Date、RegExp、Error说几条写JavaScript的基本规范?
1.不要在同一行声明多个变量
2.请使用===/!==来比较true/false或者数值
3.使用对象字面量替代newArray这种形式
4.不要使用全局函数
5.Switch语句必须带有default分支
6.函数不应该有时候有返回值,有时候没有返回值
7.For循环必须使用大括号
8.If语句必须使用大括号
9.for-in循环中的变量应该使用var关键字明确限定作用域,从而避免作用域污染JavaScript原型,原型链有什么特点?每个对象都会在其内部初始化一个属性,就是prototype原型,当我们访问一个对象的属性时,如果这个对象内部不存在这个属性,那么他就会去prototype里找这个属性,这个prototype又会有自己的prototype,于是就这样一直找下去,也就是我们平时所说的原型链的概念关系instance.constructor.prototype=instance.__proto__特点JavaScript对象是通过引用来传递的,我们创建的每个新对象实体中并没有一份属于自己的原型副本当我们修改原型时,与之相关的对象也会继承这一改变当我们需要一个属性的时,Javascript引擎会先看当前对象中是否有这个属性,如果没有的话,就会查找他的Prototype对象是否有这个属性,如此递推下去,一直检索到Object内建对象functionFunc{}Func.prototype.name=Sean;Func.prototype.getInfo=function{returnthis.name;}varperson=newFunc;//现在可以参考varperson=Object.createoldObject;console.logperson.getInfo;//它拥有了Func的属性和方法//Seanconsole.logFunc.prototype;//Func{name=SeangetInfo=function}JavaScript有几种类型的值?,你能画一下他们的内存图吗?栈原始数据类型(Undefined,Null,Boolean,Number、String)堆引用数据类型(对象、数组和函数)两种类型的区别是存储位置不同;原始数据类型直接存储在栈stack中的简单数据段,占据空间小、大小固定,属于被频繁使用数据,所以放入栈中存储;引用数据类型存储在堆heap中的对象占据空间大、大小不固定如果存储在栈中,将会影响程序运行的性能;引用数据类型在栈中存储了指针,该指针指向堆中该实体的起始地址当解释器寻找引用值时,会首先检索其在栈中的地址,取得地址后从堆中获得实体HYPERLINKhttps://camo.githubusercontent.com/d1947e624a0444d1032a85800013df487adc5550/687474703a2f2f7777772e77337363686f6f6c2e636f6d2e636e2f692f63745f6a735f76616c75652e676966\thttp://www.runoob.com/w3cnote/_blankINCLUDEPICTUREhttps://camo.githubusercontent.com/d1947e624a0444d1032a85800013df487adc5550/687474703a2f2f7777772e77337363686f6f6c2e636f6d2e636e2f692f63745f6a735f76616c75652e676966\*MERGEFORMATJavascript如何实现继承?
1、构造继承
2、原型继承
3、实例继承
4、拷贝继承原型prototype机制或apply和call方法去实现较简单,建议使用构造函数与原型混合方式functionParent{this.name=wang;}functionChild{this.age=28;}Child.prototype=newParent;//继承了Parent,通过原型vardemo=newChild;alertdemo.age;alertdemo.name;//得到被继承的属性}JavaScript继承的几种实现方式?参考构造函数的继承,非构造函数的继承;javascript创建对象的几种方式?javascript创建对象简单的说无非就是使用内置对象或各种自定义对象,当然还可以用JSON;但写法有很多种,也能混合使用
1、对象字面量的方式person={firstname:Marklastname:Yunage:25eyecolor:black};
2、用function来模拟无参的构造函数functionPerson{}varperson=newPerson;//定义一个function,如果使用new实例化该function可以看作是一个Classperson.name=Mark;person.age=25;person.work=function{alertperson.name+hello...;}person.work;
3、用function来模拟参构造函数来实现(用this关键字定义构造的上下文属性)functionPetnameagehobby{this.name=name;//this作用域当前对象this.age=age;this.hobby=hobby;this.eat=function{alert我叫+this.name+我喜欢+this.hobby+是个程序员;}}varmaidou=newPet麦兜25coding;//实例化、创建对象maidou.eat;//调用eat方法
4、用工厂方式来创建(内置对象)varwcDog=newObject;wcDog.name=旺财;wcDog.age=3;wcDog.work=function{alert我是+wcDog.name+汪汪汪......;}wcDog.work;
5、用原型方式来创建functionDog{}Dog.prototype.name=旺财;Dog.prototype.eat=function{alertthis.name+是个吃货;}varwangcai=newDog;wangcai.eat;
5、用混合方式来创建functionCarnameprice{this.name=name;this.price=price;}Car.prototype.sell=function{alert我是+this.name+,我现在卖+this.price+万元;}varcamry=newCar凯美瑞27;camry.sell;Javascript作用链域全局函数无法查看局部函数的内部细节,但局部函数可以查看其上层的函数细节,直至全局细节当需要从局部函数查找某一属性或方法时,如果当前作用域没有找到,就会上溯到上层作用域查找,直至全局函数,这种组织形式就是作用域链谈谈This对象的理解this总是指向函数的直接调用者(而非间接调用者);如果有new关键字,this指向new出来的那个对象;在事件中,this指向触发这个事件的对象,特殊的是,IE中的attachEvent中的this总是指向全局对象Window;eval是做什么的?它的功能是把对应的字符串解析成JS代码并运行;应该避免使用eval,不安全,非常耗性能(2次,一次解析成js语句,一次执行)由JSON字符串转换为JSON对象的时候可以用eval,varobj=eval+str+;什么是window对象什么是document对象null,undefined的区别?null表示一个对象被定义了,值为“空值”;undefined表示不存在这个值typeofundefined//undefinedundefined:是一个表示无的原始值或者说表示缺少值,就是此处应该有一个值,但是还没有定义当尝试读取时会返回undefined;例如变量被声明了,但没有赋值时,就等于undefinedtypeofnull//objectnull:是一个对象空对象没有任何属性和方法;例如作为函数的参数,表示该函数的参数不是对象;注意在验证null时,一定要使用 ===,因为==无法分别null和 undefined再来一个例子nullQ有张三这个人么?A有!Q张三有房子么?A没有!undefinedQ有张三这个人么?A没有!参考阅读undefined与null的区别写一个通用的事件侦听器函数//event事件工具集,来源github.com/markyunmarkyun.Event={//页面加载完成后readyEvent:functionfn{iffn==null{fn=document;}varoldonload=window.onload;iftypeofwindow.onload!=function{window.onload=fn;}else{window.onload=function{oldonload;fn;};}}//视能力分别使用dom0||dom2||IE方式来绑定事件//参数操作的元素事件名称事件处理程序addEvent:functionelementtypehandler{ifelement.addEventListener{//事件类型、需要执行的函数、是否捕捉element.addEventListenertypehandlerfalse;}elseifelement.attachEvent{element.attachEventon+typefunction{handler.callelement;};}else{element[on+type]=handler;}}//移除事件removeEvent:functionelementtypehandler{ifelement.removeEventListener{element.removeEventListenertypehandlerfalse;}elseifelement.datachEvent{element.detachEventon+typehandler;}else{element[on+type]=null;}}//阻止事件主要是事件冒泡,因为IE不支持事件捕获stopPropagation:functionev{ifev.stopPropagation{ev.stopPropagation;}else{ev.cancelBubble=true;}}//取消事件的默认行为preventDefault:functionevent{ifevent.preventDefault{event.preventDefault;}else{event.returnValue=false;}}//获取事件目标getTarget:functionevent{returnevent.target||event.srcElement;}//获取event对象的引用,取到事件的所有信息,确保随时能使用event;getEvent:functione{varev=e||window.event;if!ev{varc=this.getEvent.caller;whilec{ev=c.arguments
[0];ifevEvent==ev.constructor{break;}c=c.caller;}}returnev;}};
[123].mapparseInt答案是多少?[1NaNNaN]因为parseInt需要两个参数valradix,其中radix表示解析时用的基数map传了3个elementindexarray,对应的radix不合法导致解析失败事件是?IE与火狐的事件机制有什么区别?如何阻止冒泡?
1.我们在网页中的某个操作(有的操作对应多个事件)例如当我们点击一个按钮就会产生一个事件是可以被JavaScript侦测到的行为
2.事件处理机制IE是事件冒泡、Firefox同时支持两种事件模型,也就是捕获型事件和冒泡型事件;
3.ev.stopPropagation;(旧ie的方法ev.cancelBubble=true;)什么是闭包(closure),为什么要用它?闭包是指有权访问另一个函数作用域中变量的函数,创建闭包的最常见的方式就是在一个函数内创建另一个函数,通过另一个函数访问这个函数的局部变量利用闭包可以突破作用链域,将函数内部的变量和方法传递到外部闭包的特性
1.函数内再嵌套函数
2.内部函数可以引用外层的参数和变量
3.参数和变量不会被垃圾回收机制回收//li节点的onclick事件都能正确的弹出当前被点击的li索引ulid=testULliindex=0/liliindex=1/liliindex=2/liliindex=3/li/ulscripttype=text/javascriptvarnodes=document.getElementsByTagNameli;fori=0;inodes.length;i+=1{nodes[i].onclick=function{console.logi+1;//不用闭包的话,值每次都是4}i;}/script执行say667后say667闭包内部变量会存在而闭包内部函数的内部变量不会存在使得Javascript的垃圾回收机制GC不会收回say667所占用的资源因为say667的内部函数的执行需要依赖say667中的变量这是对闭包作用的非常直白的描述functionsay667{//Localvariablethatendsupwithinclosurevarnum=666;varsayAlert=function{alertnum;}num++;returnsayAlert;}varsayAlert=say667;sayAlert//执行结果应该弹出的667javascript代码中的usestrict;是什么意思使用它区别是什么?usestrict是一种ECMAscript5添加的(严格)运行模式这种模式使得Javascript在更严格的条件下运行使JS编码更加规范化的模式消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为默认支持的糟糕特性都会被禁用,比如不能用with,也不能在意外的情况下给全局变量赋值;全局变量的显示声明函数必须声明在顶层,不允许在非函数代码块内声明函数arguments.callee也不允许使用;消除代码运行的一些不安全之处,保证代码运行的安全限制函数中的arguments修改,严格模式下的eval函数的行为和非严格模式的也不相同;提高编译器效率,增加运行速度;为未来新版本的Javascript标准化做铺垫如何判断一个对象是否属于某个类?使用instanceof(待完善)ifainstanceofPerson{alertyes;}new操作符具体干了什么呢
1、创建一个空对象,并且this变量引用该对象,同时还继承了该函数的原型
2、属性和方法被加入到this引用的对象中
3、新创建的对象由this所引用,并且最后隐式的返回thisvarobj={};obj.__proto__=Base.prototype;Base.callobj;用原生JavaScript的实现过什么功能吗?Javascript中,有一个函数,执行时对象查找时,永远不会去查找原型,这个函数是?hasOwnPropertyjavaScript中hasOwnProperty函数方法是返回一个布尔值,指出一个对象是否具有指定名称的属性此方法无法检查该对象的原型链中是否具有该属性;该属性必须是对象本身的一个成员使用方法object.hasOwnPropertyproName其中参数object是必选项一个对象的实例proName是必选项一个属性名称的字符串值如果object具有指定名称的属性,那么JavaScript中hasOwnProperty函数方法返回true,反之则返回falseJSON的了解?JSONJavaScriptObjectNotation是一种轻量级的数据交换格式它是基于JavaScript的一个子集数据格式简单易于读写占用带宽小如{age:12name:back}JSON字符串转换为JSON对象:varobj=eval+str+;varobj=str.parseJSON;varobj=JSON.parsestr;JSON对象转换为JSON字符串varlast=obj.toJSONString;varlast=JSON.stringifyobj; 能解释一下这段代码的意思吗?js延迟加载的方式有哪些?defer和async、动态创建DOM方式(用得最多)、按需异步载入jsAjax是什么如何创建一个Ajax?ajax的全称AsynchronousJavascriptAndXML异步传输+js+xml所谓异步,在这里简单地解释就是向服务器发送请求的时候,我们不必等待结果,而是可以同时做其他的事情,等到有了结果它自己会根据设定进行后续操作,与此同时,页面是不会发生整页刷新的,提高了用户体验1创建XMLHttpRequest对象也就是创建一个异步调用对象2创建一个新的HTTP请求并指定该HTTP请求的方法、URL及验证信息3设置响应HTTP请求状态变化的函数4发送HTTP请求5获取异步调用返回的数据6使用JavaScript和DOM实现局部刷新同步和异步的区别同步浏览器访问服务器请求,用户看得到页面刷新,重新发请求等请求完,页面刷新,新内容出现,用户看到新内容进行下一步操作异步浏览器访问服务器请求,用户正常操作,浏览器后端进行请求等请求完,页面不刷新,新内容也会出现,用户看到新内容(待完善)如何解决跨域问题jsonp、iframe、window.name、window.postMessage、服务器上设置代理页面页面编码和被请求的资源编码如果不一致如何处理?模块化开发怎么做?立即执行函数不暴露私有成员varmodule1=function{ var_count=0; varm1=function{ //... }; varm2=function{ //... }; return{ m1:m1 m2:m2 }; };(待完善)AMD(Modules/Asynchronous-Definition)、CMD(CommonModuleDefinition)规范区别?AMD规范在这里https://github.com/amdjs/amdjs-api/wiki/AMDCMD规范在这里https://github.com/seajs/seajs/issues/242AsynchronousModuleDefinition,异步模块定义,所有的模块将被异步加载,模块加载不影响后面语句运行所有依赖某些模块的语句均放置在回调函数中区别
1.对于依赖的模块,AMD是提前执行,CMD是延迟执行不过RequireJS从
2.0开始,也改成可以延迟执行(根据写法不同,处理方式不同)CMD推崇aslazyaspossible.
2.CMD推崇依赖就近,AMD推崇依赖前置看代码//CMDdefinefunctionrequireexportsmodule{vara=require./aa.doSomething//此处略去100行varb=require./b//依赖可以就近书写b.doSomething//...}//AMD默认推荐define[./a./b]functionab{//依赖必须一开始就写好a.doSomething//此处略去100行b.doSomething//...}requireJS的核心原理是什么?(如何动态加载的?如何避免多次加载的?如何缓存的?)谈一谈你对ECMAScript6的了解?ECMAScript6怎么写class么,为什么会出现class这种东西异步加载JS的方式有哪些?1defer,只支持IE2async3创建script,插入到DOM中,加载完毕后callBackdocumen.write和innerHTML的区别document.write只能重绘整个页面innerHTML可以重绘页面的一部分DOM操作——怎样添加、移除、移动、复制、创建和查找节点
(1)创建新节点createDocumentFragment//创建一个DOM片段createElement//创建一个具体的元素createTextNode//创建一个文本节点
(2)添加、移除、替换、插入appendChildremoveChildreplaceChildinsertBefore//在已有的子节点前插入一个新的子节点
(3)查找getElementsByTagName//通过标签名称getElementsByName//通过元素的Name属性的值IE容错能力较强,会得到一个数组,其中包括id等于name值的getElementById//通过元素Id,唯一性.call和.apply的区别?例子中用add来替换sub,add.callsub31==add31,所以运行结果为alert4;注意js中的函数其实是对象,函数名是对Function对象的引用functionaddab{alerta+b;}functionsubab{alerta-b;}add.callsub31;数组和对象有哪些原生方法,列举一下?JS怎么实现一个类怎么实例化这个类JavaScript中的作用域与变量声明提升?如何编写高性能的Javascript?那些操作会造成内存泄漏?JQuery的源码看过吗?能不能简单概况一下它的实现原理?jQuery.fn的init方法返回的this指的是什么对象?为什么要返回this?jquery中如何将数组转化为json字符串,然后再转化回来?jQuery的属性拷贝extend的实现原理是什么,如何实现深拷贝?jQuery的队列是如何实现的?队列可以用在哪些地方?谈一下Jquery中的bindlivedelegateon的区别?JQuery一个对象可以同时绑定多个事件,这是如何实现的?是否知道自定义事件jQuery里的fire函数是什么意思,什么时候用?针对jQuery性能的优化方法?Jquery与jQueryUI有啥区别?*jQuery是一个js库,主要提供的功能是选择器,属性修改和事件绑定等等*jQueryUI则是在jQuery的基础上,利用jQuery的扩展性,设计的插件提供了一些常用的界面元素,诸如对话框、拖动行为、改变大小行为等等JQuery的源码看过吗?能不能简单说一下它的实现原理?jquery中如何将数组转化为json字符串,然后再转化回来?jQuery中没有提供这个功能,所以你需要先编写两个jQuery的扩展$.fn.stringifyArray=functionarray{returnJSON.stringifyarray}$.fn.parseArray=functionarray{returnJSON.parsearray}然后调用$.stringifyArrayarrayjQuery和Zepto的区别?各自的使用场景?针对jQuery的优化方法?*基于Class的选择性的性能相对于Id选择器开销很大,因为需遍历所有DOM元素*频繁操作的DOM,先缓存起来再操作用Jquery的链式调用更好比如varstr=$a.attrhref;*forvari=size;iarr.length;i++{}for循环每一次循环都查找了数组arr的.length属性,在开始循环的时候设置一个变量来存储这个数字,可以让循环跑得更快forvari=sizelength=arr.length;ilength;i++{}Zepto的点透问题如何解决?jQueryUI如何自定义组件需求实现一个页面操作不会整页刷新的网站,并且能在浏览器前进、后退时正确响应给出你的技术实现方案?如何判断当前脚本运行在浏览器还是node环境中?(阿里)通过判断Global对象是否为window,如果不为window,当前脚本没有运行在浏览器中移动端最小触控区域是多大?jQuery的slideUp动画,如果目标元素是被外部事件驱动当鼠标快速地连续触发外部元素事件动画会滞后的反复执行,该如何处理呢把Script标签放在页面的最底部的body封闭之前和封闭之后有什么区别?浏览器会如何解析它们?移动端的点击事件的有延迟,时间是多久,为什么会有?怎么解决这个延时?(click有300ms延迟为了实现safari的双击事件的设计,浏览器要知道你是不是要双击操作)知道各种JS框架AngularBackboneEmberReactMeteorKnockout...么能讲出他们各自的优点和缺点么Underscore对哪些JS原生对象进行了扩展以及提供了哪些好用的函数方法?解释JavaScript中的作用域与变量声明提升?那些操作会造成内存泄漏?内存泄漏指任何对象在您不再拥有或需要它之后仍然存在垃圾回收器定期扫描对象,并计算引用了每个对象的其他对象的数量如果一个对象的引用数量为0(没有其他对象引用过该对象),或对该对象的惟一引用是循环的,那么该对象的内存即可回收setTimeout的第一个参数使用字符串而非函数的话,会引发内存泄漏闭包、控制台日志、循环(在两个对象彼此引用且彼此保留时,就会产生一个循环)JQuery一个对象可以同时绑定多个事件,这是如何实现的?Node.js的适用场景?如果会用node知道routemiddlewareclusternodemonpm2server-siderendering么解释一下Backbone的MVC实现方式?什么是前端路由什么时候适合使用前端路由前端路由有哪些优点和缺点知道什么是webkit么知道怎么用浏览器的各种工具来调试和debug代码么如何测试前端代码么知道BDDTDDUnitTest么知道怎么测试你的前端工程么mochasinonjasminqUnit..前端templatingMustacheunderscorehandlebars是干嘛的怎么用简述一下Handlebars的基本用法?简述一下Handlerbars的对模板的基本处理流程,如何编译的?如何缓存的?用js实现千位分隔符来源前端农民工,提示正则+replacefunctioncommafynum{num=num+;varreg=/-d+d{3}/;ifreg.testnum{num=num.replacereg$1$2;}returnnum;}检测浏览器版本版本有哪些方式?功能检测、userAgent特征检测比如navigator.userAgent//Mozilla/
5.0Macintosh;IntelMacOSX10_10_2AppleWebKit/
537.36KHTMLlikeGeckoChrome/
41.
0.
2272.101Safari/
537.36WhatisaPolyfillpolyfill是“在旧版浏览器上复制标准API的JavaScript补充”可以动态地加载JavaScript代码或库,在不支持这些标准API的浏览器中模拟它们例如,geolocation(地理位置)polyfill可以在navigator对象上添加全局的geolocation对象,还能添加getCurrentPosition函数以及“坐标”回调对象,所有这些都是W3C地理位置API定义的对象和函数因为polyfill模拟标准API,所以能够以一种面向所有浏览器未来的方式针对这些API进行开发,一旦对这些API的支持变成绝对大多数,则可以方便地去掉polyfill,无需做任何额外工作做的项目中,有没有用过或自己实现一些polyfill方案(兼容性处理方案)?比如html5shiv、Geolocation、Placeholder我们给一个dom同时绑定两个点击事件,一个用捕获,一个用冒泡会执行几次事件,会先执行冒泡还是捕获?ECMAScript6相关Object.is与原来的比较操作符===、==的区别?两等号判等,会在比较时进行类型转换;三等号判等判断严格,比较时不进行隐式类型转换(类型不同则会返回false);Object.is在三等号判等的基础上特别处理了NaN、-0和+0,保证-0和+0不再相同,但Object.isNaNNaN会返回true.Object.is应被认为有其特殊的用途,而不能用它认为它比其它的相等对比更宽松或严格前端框架相关react-router路由系统的实现原理?React中如何解决第三方类库的问题其他问题原来公司工作流程是怎么样的,如何与其他人协作的?如何夸部门合作的?你遇到过比较难的技术问题是?你是如何解决的?设计模式知道什么是singletonfactorystrategydecrator么常使用的库有哪些?常用的前端开发工具?开发过什么应用或组件?页面重构怎么操作?网站重构在不改变外部行为的前提下,简化结构、添加可读性,而在网站前端保持一致的行为也就是说是在不改变UI的情况下,对网站进行优化,在扩展的同时保持一致的UI对于传统的网站来说重构通常是表格table布局改为DIV+CSS使网站前端兼容于现代浏览器针对于不合规范的CSS、如对IE6有效的对于移动平台的优化针对于SEO进行优化深层次的网站重构应该考虑的方面减少代码间的耦合让代码保持弹性严格按规范编写代码设计可扩展的API代替旧有的框架、语言如VB增强用户体验通常来说对于速度的优化也包含在重构中压缩JS、CSS、image等前端资源通常是由服务器来解决程序的性能优化如数据读写采用CDN来加速资源加载对于JSDOM的优化HTTP服务器的文件缓存列举IE与其他浏览器不一样的特性?
1、事件不同之处触发事件的元素被认为是目标(target)而在IE中,目标包含在event对象的srcElement属性;获取字符代码、如果按键代表一个字符(shift、ctrl、alt除外),IE的keyCode会返回字符代码(Unicode),DOM中按键的代码和字符是分离的,要获取字符代码,需要使用charCode属性;阻止某个事件的默认行为,IE中阻止某个事件的默认行为,必须将returnValue属性设置为false,Mozilla中,需要调用preventDefault方法;停止事件冒泡,IE中阻止事件进一步冒泡,需要设置cancelBubble为true,Mozzilla中,需要调用stopPropagation;99%的网站都需要被重构是那本书上写的?网站重构应用web标准进行设计(第2版)什么叫优雅降级和渐进增强?优雅降级Web站点在所有新式浏览器中都能正常工作,如果用户使用的是老式浏览器,则代码会针对旧版本的IE进行降级处理了使之在旧式浏览器上以某种形式降级体验却不至于完全不能用如border-shadow渐进增强从被所有浏览器支持的基本功能开始,逐步地添加那些只有新版本浏览器才支持的功能向页面增加不影响基础浏览器的额外样式和功能的当浏览器支持时,它们会自动地呈现出来并发挥作用如默认使用flash上传,但如果浏览器支持HTML5的文件上传功能,则使用HTML5实现更好的体验;是否了解公钥加密和私钥加密一般情况下是指私钥用于对数据进行签名,公钥用于对签名进行验证;HTTP网站在浏览器端用公钥加密敏感数据,然后在服务器端再用私钥解密WEB应用从服务器主动推送Data到客户端有那些方式?html5提供的Websocket不可见的iframeWebSocket通过FlashXHR长时间连接XHRMultipartStreamingscript标签的长时间连接可跨域对Node的优点和缺点提出了自己的看法?*(优点)因为Node是基于事件驱动和无阻塞的,所以非常适合处理并发请求,因此构建在Node上的代理服务器相比其他技术实现(如Ruby)的服务器表现要好得多此外,与Node代理服务器交互的客户端代码是由javascript语言编写的,因此客户端和服务器端都用同一种语言编写,这是非常美妙的事情*(缺点)Node是一个相对新的开源项目,所以不太稳定,它总是一直在变,而且缺少足够多的第三方库支持看起来,就像是Ruby/Rails当年的样子你有用过哪些前端性能优化的方法?
(1)减少http请求次数CSSSpritesJS、CSS源码压缩、图片大小控制合适;网页Gzip,CDN托管,data缓存,图片服务器
(2)前端模板JS+数据,减少由于HTML标签导致的带宽浪费,前端用变量保存AJAX请求结果,每次操作本地变量,不用请求,减少请求次数
(3)用innerHTML代替DOM操作,减少DOM操作次数,优化javascript性能
(4)当需要设置的样式很多时设置className而不是直接操作style
(5)少用全局变量、缓存DOM节点查找的结果减少IO读取操作
(6)避免使用CSSExpression(css表达式又称Dynamicproperties动态属性
(7)图片预加载,将样式表放在顶部,将脚本放在底部加上时间戳
(8)避免在页面的主体布局中使用table,table要等其中的内容完全下载之后才会显示出来,显示比div+css布局慢对普通的网站有一个统一的思路,就是尽量向前端优化、减少数据库操作、减少磁盘IO向前端优化指的是,在不影响功能和体验的情况下,能在浏览器执行的不要在服务端执行,能在缓存服务器上直接返回的不要到应用服务器,程序能直接取得的结果不要到外部取得,本机内能取得的数据不要到远程取,内存能取到的不要到磁盘取,缓存中有的不要去数据库查询减少数据库操作指减少更新次数、缓存结果减少查询次数、将数据库执行的操作尽可能的让你的程序完成(例如join查询),减少磁盘IO指尽量不使用文件系统作为缓存、减少读写文件次数等程序优化永远要优化慢的部分,换语言是无法“优化”的http状态码有那些?分别代表是什么意思?简单版[100Continue继续,一般在发送post请求时,已发送了httpheader之后服务端将返回此信息,表示确认,之后发送具体参数信息200OK正常返回信息201Created请求成功并且服务器创建了新的资源202Accepted服务器已接受请求,但尚未处理301MovedPermanently请求的网页已永久移动到新位置302Found临时性重定向303SeeOther临时性重定向,且总是使用GET请求新的URI304NotModified自从上次请求后,请求的网页未修改过400BadRequest服务器无法理解请求的格式,客户端不应当尝试再次使用相同的内容发起请求401Unauthorized请求未授权403Forbidden禁止访问404NotFound找不到如何与URI相匹配的资源500InternalServerError最常见的服务器端错误503ServiceUnavailable服务器端暂时无法处理请求(可能是过载或维护)]完整版1**信息类表示接收到请求并且继续处理100——客户必须继续发出请求101——客户要求服务器根据请求转换HTTP协议版本2**响应成功表示动作被成功接收、理解和接受200——表明该请求被成功地完成,所请求的资源发送回客户端201——提示知道新文件的URL202——接受和处理、但处理未完成203——返回信息不确定或不完整204——请求收到,但返回信息为空205——服务器完成了请求,用户代理必须复位当前已经浏览过的文件206——服务器已经完成了部分用户的GET请求3**重定向类为了完成指定的动作,必须接受进一步处理300——请求的资源可在多处得到301——本网页被永久性转移到另一个URL302——请求的网页被转移到一个新的地址,但客户访问仍继续通过原始URL地址,重定向,新的URL会在response中的Location中返回,浏览器将会使用新的URL发出新的Request303——建议客户访问其他URL或访问方式304——自从上次请求后,请求的网页未修改过,服务器返回此响应时,不会返回网页内容,代表上次的文档已经被缓存了,还可以继续使用305——请求的资源必须从服务器指定的地址得到306——前一版本HTTP中使用的代码,现行版本中不再使用307——申明请求的资源临时性删除4**客户端错误类请求包含错误语法或不能正确执行400——客户端请求有语法错误,不能被服务器所理解401——请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用HTTP
401.1-未授权登录失败 HTTP
401.2-未授权服务器配置问题导致登录失败 HTTP
401.3-ACL禁止访问资源 HTTP
401.4-未授权授权被筛选器拒绝HTTP
401.5-未授权ISAPI或CGI授权失败402——保留有效ChargeTo头响应403——禁止访问,服务器收到请求,但是拒绝提供服务HTTP
403.1禁止访问禁止可执行访问 HTTP
403.2-禁止访问禁止读访问 HTTP
403.3-禁止访问禁止写访问 HTTP
403.4-禁止访问要求SSL HTTP
403.5-禁止访问要求SSL128 HTTP
403.6-禁止访问IP地址被拒绝 HTTP
403.7-禁止访问要求客户证书 HTTP
403.8-禁止访问禁止站点访问 HTTP
403.9-禁止访问连接的用户过多 HTTP
403.10-禁止访问配置无效 HTTP
403.11-禁止访问密码更改 HTTP
403.12-禁止访问映射器拒绝访问 HTTP
403.13-禁止访问客户证书已被吊销 HTTP
403.15-禁止访问客户访问许可过多 HTTP
403.16-禁止访问客户证书不可信或者无效HTTP
403.17-禁止访问客户证书已经到期或者尚未生效404——一个404错误表明可连接服务器,但服务器无法取得所请求的网页,请求资源不存在eg输入了错误的URL405——用户在Request-Line字段定义的方法不允许406——根据用户发送的Accept拖,请求资源不可访问407——类似401,用户必须首先在代理服务器上得到授权408——客户端没有在用户指定的饿时间内完成请求409——对当前资源状态,请求不能完成410——服务器上不再有此资源且无进一步的参考地址411——服务器拒绝用户定义的Content-Length属性请求412——一个或多个请求头字段在当前请求中错误413——请求的资源大于服务器允许的大小414——请求的资源URL长于服务器允许的长度415——请求资源不支持请求项目格式416——请求中包含Range请求头字段,在当前请求资源范围内没有range指示值,请求也不包含If-Range请求头字段417——服务器不满足请求Expect头字段指定的期望值,如果是代理服务器,可能是下一级服务器不能满足请求长5**服务端错误类服务器不能正确执行一个正确的请求HTTP500-服务器遇到错误,无法完成请求 HTTP
500.100-内部服务器错误-ASP错误 HTTP500-11服务器关闭 HTTP500-12应用程序重新启动 HTTP500-13-服务器太忙 HTTP500-14-应用程序无效 HTTP500-15-不允许请求global.asa Error501-未实现HTTP502-网关错误HTTP503由于超载或停机维护,服务器目前无法使用,一段时间后可能恢复正常一个页面从输入URL到页面加载显示完成,这个过程中都发生了什么?(流程说的越详细越好)注这题胜在区分度高,知识点覆盖广,再不懂的人,也能答出几句,而高手可以根据自己擅长的领域自由发挥,从URL规范、HTTP协议、DNS、CDN、数据库查询、到浏览器流式解析、CSS规则构建、layout、paint、onload/domready、JS执行、JSAPI绑定等等;详细版
1、浏览器会开启一个线程来处理这个请求,对URL分析判断如果是http协议就按照Web方式来处理;
2、调用浏览器内核中的对应方法,比如WebView中的loadUrl方法;
3、通过DNS解析获取网址的IP地址,设置UA等信息发出第二个GET请求;
4、进行HTTP协议会话,客户端发送报头请求报头;
5、进入到web服务器上的WebServer,如Apache、Tomcat、Node.JS等服务器;
6、进入部署好的后端应用,如PHP、Java、JavaScript、Python等,找到对应的请求处理;
7、处理结束回馈报头,此处如果浏览器访问过,缓存上有对应资源,会与服务器最后修改时间对比,一致则返回304;
8、浏览器开始下载html文档响应报头,状态码200,同时使用缓存;
9、文档树建立,根据标记请求所需指定MIME类型的文件(比如css、js)同时设置了cookie;
10、页面开始渲染DOM,JS根据DOMAPI操作DOM执行事件绑定等,页面显示完成简洁版浏览器根据请求的URL交给DNS域名解析,找到真实IP,向服务器发起请求;服务器交给后台处理完成后返回数据,浏览器接收文件(HTML、JS、CSS、图象等);浏览器对加载到的资源(HTML、JS、CSS等)进行语法解析,建立相应的内部数据结构(如HTML的DOM);载入解析到的资源文件,渲染页面,完成部分地区用户反应网站很卡,请问有哪些可能性的原因,以及解决方法?从打开app到刷新出内容,整个过程中都发生了什么,如果感觉慢,怎么定位问题,怎么解决除了前端以外还了解什么其它技术么?你最最厉害的技能是什么?你用的得心应手用的熟练地编辑器开发环境是什么样子?SublimeText3+相关插件编写前端代码Googlechrome、MozillaFirefox浏览器+firebug兼容测试和预览页面UI、动画效果和交互功能Node.js+Gulpgit用于版本控制和CodeReview对前端工程师这个职位是怎么样理解的?它的前景会怎么样?前端是最贴近用户的程序员,比后端、数据库、产品经理、运营、安全都近
1、实现界面交互
2、提升用户体验
3、有了Node.js,前端可以实现服务端的一些事情前端是最贴近用户的程序员,前端的能力就是能让产品从90分进化到100分,甚至更好,参与项目,快速高质量完成实现效果图,精确到1px;与团队成员,UI设计,产品经理的沟通;做好的页面结构,页面重构和用户体验;处理hack,兼容、写出优美的代码格式;针对服务器的优化、拥抱最新前端技术你怎么看待WebApp、hybridApp、NativeApp?你移动端前端开发的理解?(和Web前端开发的主要区别是什么?)你对加班的看法?加班就像借钱,原则应当是------救急不救穷平时如何管理你的项目?先期团队必须确定好全局样式(globe.css),编码模式utf-8等;编写习惯必须一致(例如都是采用继承式的写法,单样式都写成一行);标注样式编写人,各模块都及时标注(标注关键样式调用的地方);页面进行标注(例如页面模块开始和结束);CSS跟HTML分文件夹并行存放,命名都得统一(例如style.css);JS分文件夹存放命名以该JS功能为准的英文翻译图片采用整合的images.pngpng8格式文件使用尽量整合在一起使用方便将来的管理如何设计突发大规模并发架构?当团队人手不足,把功能代码写完已经需要加班的情况下,你会做前端代码的测试吗?说说最近最流行的一些东西吧?常去哪些网站?ES6\WebAssembly\Node\MVVM\WebComponents\React\ReactNative\Webpack组件化知道什么是SEO并且怎么优化么知道各种metadata的含义么移动端(AndroidIOS)怎么做好用户体验清晰的视觉纵线、信息的分组、极致的减法、利用选择代替输入、标签及文字的排布方式、依靠明文确认密码、合理的键盘利用简单描述一下你做过的移动APP项目研发流程?你在现在的团队处于什么样的角色,起到了什么明显的作用?你认为怎样才是全端工程师(FullStackdeveloper)?介绍一个你最得意的作品吧?你有自己的技术博客吗,用了哪些技术?对前端安全有什么看法?是否了解Web注入攻击,说下原理,最常见的两种攻击(XSS和CSRF)了解到什么程度?项目中遇到国哪些印象深刻的技术难题,具体是什么问题,怎么解决?最近在学什么东西?你的优点是什么?缺点是什么?如何管理前端团队最近在学什么?能谈谈你未来3,5年给自己的规划吗?。