【备战秋招Day 10】经典面试题37-40及在线编程题28-30答案

来源:互联网 发布:python insert怎么用 编辑:程序博客网 时间:2024/06/06 15:35

这里写图片描述

转载自IMWeb团队,知乎地址:https://zhuanlan.zhihu.com/p/27980518

经典面试题

37.哪些地方会出现css阻塞,哪些地方会出现js阻塞?

js 的阻塞特性:所有浏览器在下载 JS 的时候,会阻止一切其他活动,比如其他资源的下载,内容的呈现等等。直到 JS 下载、解析、执行完毕后才开始继续并行下载其他资源并呈现内容。为了提高用户体验,新一代浏览器都支持并行下载 JS,但是 JS 下载仍然会阻塞其它资源的下载(例如.图片,css文件等)。

由于浏览器为了防止出现 JS 修改 DOM 树,需要重新构建 DOM 树的情况,所以就会阻塞其他的下载和呈现。嵌入 JS 会阻塞所有内容的呈现,而外部 JS 只会阻塞其后内容的显示,2 种方式都会阻塞其后资源的下载。也就是说外部样式不会阻塞外部脚本的加载,但会阻塞外部脚本的执行。

CSS 怎么会阻塞加载了?CSS 本来是可以并行下载的,在什么情况下会出现阻塞加载了(在测试观察中,IE6 下 CSS 都是阻塞加载)当 CSS 后面跟着嵌入的 JS 的时候,该 CSS 就会出现阻塞后面资源下载的情况。而当把嵌入 JS 放到 CSS 前面,就不会出现阻塞的情况了。

根本原因:因为浏览器会维持 html 中 css 和 js 的顺序,样式表必须在嵌入的 JS 执行前先加载、解析完。而嵌入的 JS 会阻塞后面的资源加载,所以就会出现上面 CSS 阻塞下载的情况。

38.CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级高?

标签选择符 类选择符 id选择符

继承不如指定 Id>class>标签选择

后者优先级高

39.在JavaScript我们会遇到闭包,请你们根据自己的理解分析一下什么是闭包?闭包有什么好处?使用闭包要注意什么?

闭包:函数嵌套函数,内部函数可以引用外部函数的参数和变量,变量和参数不会被垃圾回收机制所回收

好处:(1)希望一个变量长期驻扎在内存之中

(2)避免全局变量的污染

(3)私有成员的存在

注意:可能会造成内存泄漏

40.如何阻止事件冒泡和默认事件(程序)

//禁止事件冒泡function stopBubble(e) {//如果提供了事件对象,则这是一个非IE浏览器if ( e && e.stopPropagation )    //因此它支持W3C的stopPropagation()方法    e.stopPropagation();else    //否则,我们需要使用IE的方式来取消事件冒泡    window.event.cancelBubble = true;}//阻止浏览器的默认行为function stopDefault( e ) {    //阻止默认浏览器动作(W3C)    if ( e && e.preventDefault )        e.preventDefault();    //IE中阻止函数器默认动作的方式    else        window.event.returnValue = false;    return false;}

前端思考题

19.谈谈垃圾回收机制方式及内存管理.

20.开发过程中遇到的内存泄露情况,如何解决的?

在线编程题

28.检查重复字符串

要求:

给定字符串 str,检查其是否包含连续重复的字母(a-zA-Z),包含返回 true,否则返回 false

思路:

在正则表达式中,利用()进行分组,使用斜杠加数字表示引用,\1就是引用第一个分组,\2就是引用第二个分组。将[a-zA-Z]做为一个分组,然后引用,就可以判断是否有连续重复的字母。

function containsRepeatingLetter(str) {     return /([a-zA-Z])\1/.test(str); }

29.获取指定字符串

要求:

给定字符串 str,检查其是否包含 连续3个数字
1、如果包含,返回最新出现的 3 个数字的字符串
2、如果不包含,返回 false

思路:

题目描述有问题,实际考察的是字符串中是否含有连续的三个任意数字,而不是三个连续的数字。依题,若存在连续的三个任意数字,则返回最早出现的三个数字,若不存在,则返回false。因此需要用到match方法,match()返回的是正则表达式匹配的字符串数组,连续的三个任意数字用正则表达式表示为/\d{3}/。

function captureThreeNumbers(str) {     //声明一个数组保存匹配的字符串结果  var arr = str.match(/\d{3}/);     //如果arr存在目标结果,则返回第一个元素,即最早出现的目标结果     if(arr)         return arr[0];     else return false; }

30.判断是否符合指定格式

要求:

给定字符串 str,检查其是否符合如下格式
1、XXX-XXX-XXXX
2、其中 X 为 Number 类型

思路:

本题需要注意格式,开头^和结尾$必须加上限定字符串,3个数可表示为\d3,4个数可表示为\d4,有相同
的部分\d{3}-

function matchesPattern(str) {    return/^(\d{3}-){2}\d{4}$/.test(str);}
阅读全文
0 0
原创粉丝点击