【备战秋招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);}
- 【备战秋招Day 10】经典面试题37-40及在线编程题28-30答案
- 【备战秋招Day 7】经典面试题25-28及在线编程题19-21答案
- 【备战秋招Day 4】经典面试题13-16及在线编程题10-12答案
- 【备战秋招Day 1】经典面试题1-4及在线编程题1-3答案
- 【备战秋招Day 2】经典面试题5-8及在线编程题4-6答案
- 【备战秋招Day 3】经典面试题9-12及在线编程题7-9答案
- 【备战秋招Day 5】经典面试题17-20及在线编程题13-15答案
- 【备战秋招Day 6】经典面试题21-24及在线编程题16-18答案
- 【备战秋招Day 8】经典面试题29-32及在线编程题22-24答案
- 【备战秋招Day 9】经典面试题33-36及在线编程题25-27答案
- C#经典面试题及答案【2009-02-10更新】
- 一些经典的面试题及答案
- SQL经典面试题及答案
- SQL经典面试题及答案
- SQL经典面试题及答案
- SQL经典面试题及答案
- 微软的面试题及答案-经典
- SQL数据库经典面试题及答案
- 异或运算的性质
- java接口和多态
- Codevs非难题汇总
- Ucloud 必读
- 解决php的session异步请求堵塞问题(采用xhprof性能分析)
- 【备战秋招Day 10】经典面试题37-40及在线编程题28-30答案
- 基于cef ceflient做二次开发在开发环境部署中遇到过的坑
- wireshark的使用
- python求解LeetCode习题Intersection of Two Linked Lists
- MYSQL优化概述
- HPU16级暑期集训练习(一)
- struct sk_buff与socket
- PAT(Basic Level)_1005_继续(3n+1)猜想
- Fibonacci数列