前言

过完元宵,就到上海找了波工作,现在已经入职好了,蹭波热点,写一波面试记录,内容包含笔试题和面试题,还有一些没有写进来,准备再开一篇,许久没写了,写的确实有些慢。如果喜欢的话可以点波赞,或者关注一下,希望大家看完本文可以有所收获。

个人博客了解一下:obkoro1.com

后续

前端笔试题面试题记录(下)


Q:什么情况下会碰到跨域问题?有哪些解决方法?

  • 跨域问题是这是浏览器为了安全实施的同源策略导致的,同源策略限制了来自不同源的document脚本,同源的意思就是两个URL的域名、协议、端口要完全相同。
  • script标签jsonp跨域、nginx反向代理、node.js中间件代理跨域、后端在头部信息设置安全域名、后端在服务器上设置cors。

Q:如何判断一个变量是对象还是数组?

判断数组和对象分别都有好几种方法,其中用prototype.toString.call()兼容性最好。

function isObjArr(value){if (Object.prototype.toString.call(value) === "[object Array]") {console.log('value是数组');}else if(Object.prototype.toString.call(value)==='[object Object]'){//这个方法兼容性好一点console.log('value是对象');}else{console.log('value不是数组也不是对象')}
}

ps:千万不能使用typeof来判断对象和数组,因为这两种类型都会返回"object"。


Q:定时器的执行顺序或机制。

这个问题还是挺经常被问到的,有一些会直接问定时器的机制,有一些是通过笔试题的方式问执行顺序然后问我为什么是这样。

长话短说,我们需要记住的是:因为js是单线程的,浏览器遇到setTimeout或者setInterval会先执行完当前的代码块,在此之前会把定时器推入浏览器的待执行事件队列里面,等到浏览器执行完当前代码之后会看一下事件队列里面有没有任务,有的话才执行定时器的代码。 所以即使把定时器的时间设置为0还是会先执行当前的一些代码。

上面是我写的一个栗子,如果还不清楚的话,大家可以找一篇关于定时器机制的详解文章来看看。


Q:html中title属性和alt属性的区别?

这个问题被问了一次,当时我只记得,alt属性是用于img标签的,当图片失效的时候会出现alt属性里面的内容,title用来标记页面的title,当时面试官问我还有没有其他的区别。我。。。

然后我就找了一篇文章来看,涨了点姿势:

1.<img src="#" alt="alt信息" />
//1.当图片不输出信息的时候,会显示alt信息 鼠标放上去没有信息,当图片正常读取,不会出现alt信息
2.<img src="#" alt="alt信息" title="title信息" />
// 2.当图片不输出信息的时候,会显示alt信息 鼠标放上去会出现title信息
//当图片正常输出的时候,不会出现alt信息,鼠标放上去会出现title信息

另外还有一些关于title属性的知识:

title属性可以用在除了base,basefont,head,html,meta,param,script和title之外的所有标签
title属性的功能是提示。额外的说明信息和非本质的信息请使用title属性。title属性值可以比alt属性值设置的更长
title属性有一个很好的用途,即为链接添加描述性文字,特别是当连接本身并不是十分清楚的表达了链接的目的。

Q:标准盒子模型与IE怪异盒子模型

这个问题主要会出现在笔试题上面,比如:

<div style="width:100px;height="100px;border:10px;padding:10px;"></div>

这个盒子在w3c标准盒子模型和IE的怪异盒子模型下面它的宽度分别是多少?

标准盒子模型:总宽度=content100px+border 10px*2+padding 10px*2 //140px
怪异盒子模型: 总宽度=content60px+ border 10px*2+padding 10px*2 //100px

ps:

box-sizing: content-box || border-box;//css3 box-sizing设置为border-box将使用怪异盒子模型
当怪异盒子的宽度小于border+padding的宽度的时候,content width将变为0,盒子的宽度会被border和padding的总宽度撑开

ES5的继承和ES6的继承有什么区别?

ES5的继承时通过prototype或构造函数机制来实现。ES5的继承实质上是先创建子类的实例对象,然后再将父类的方法添加到this上(Parent.apply(this))。

ES6的继承机制完全不同,实质上是先创建父类的实例对象this(所以必须先调用父类的super()方法),然后再用子类的构造函数修改this

具体的:ES6通过class关键字定义类,里面有构造方法,类之间通过extends关键字实现继承。子类必须在constructor方法中调用super方法,否则新建实例报错。因为子类没有自己的this对象,而是继承了父类的this对象,然后对其进行加工。如果不调用super方法,子类得不到this对象。

ps:super关键字指代父类的实例,即父类的this对象。在子类构造函数中,调用super后,才可使用this关键字,否则报错。


Q:CSS3有哪些新增的属性?

这里可以分为边框、背景,渐变,阴影、2D转换 3D转换等之类的来说。
比如:边框(border-radius、border-shadow、border-image)之类的 。

具体的可以参见菜鸟教程:链接。类似的镜像问题还有HTML5的新增属性,可以自己谷歌一下。


Q:你知道哪些http状态码?

1xx:1开头的是信息状态码
2xx:2开头的是请求成功
3xx:3开头的是重定向
4xx:4开头的是客户端错误
5xx:5开头的是服务器错误

这个问题并不难,在笔试面试都有碰到过,巧的是之前我就总结过一篇类似的文章。


Q:如何对一个数组去重?

这个问题出现了好几次,而且很多面试官不满足你只给出一两种方法。

1、Set结构去重

这是ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。

let unique= [...new Set(array)];
//es6 Set数据结构类似于数组,成员值是唯一的,有重复的值会自动去重。
//Set内部使用===来判断是否相等,类似'1'和1会两个都保存,NaN和NaN只会保存一个

2、遍历,将值添加到新数组,用indexOf()判断值是否存在,已存在就不添加,达到去重效果。

    let a = ['1','2','3',1,NaN,NaN,undefined,undefined,null,null, 'a','b','b'];let unique= arr =>{let newA=[];arr.forEach(key => {if( newA.indexOf(key)<0 ){ //遍历newA是否存在key,如果存在key会大于0就跳过push的那一步newA.push(key);}});return newA;}console.log(unique(a)) ;//["1", "2", "3", 1, NaN, NaN, undefined, null, "a", "b"]
//ps:这个方法不能分辨NaN,会出现两个NaN。是有问题的,下面那个方法好一点。

3、遍历,将数组的值添加到一个对象的属性名里,并给属性赋值,对象不能添加相同属性名,以这个为依据可以实现数组去重,然后用Object.keys(对象)返回这个对象可枚举属性组成的数组,这个数组就是去重后的数组。

    let a = ['1', '2', '3', 1,NaN,NaN,undefined,undefined,null,null, 'a', 'b', 'b'];const unique = arr => {var obj = {}arr.forEach(value => {obj[value] = 0;//这步新添加一个属性,并赋值,如果不赋值的话,属性会添加不上去})return Object.keys(obj);//`Object.keys(对象)`返回这个对象可枚举属性组成的数组,这个数组就是去重后的数组}console.log(unique(a));//["1", "2", "3", "NaN", "undefined", "null", "a", "b"]

注意:

这个方法会将 number,NaN,undefined,null,变为字符串形式,因为对象的属性名就是一个字符串,根据需求来吧,想想还是Set去重最简单也最有效。


Q:垂直居中有哪些方法?

  • 单行文本的话可以使用height和line-height设置同一高度。
  • position+margin:设置父元素:position: relative;,子元素height: 100px; position:absolute;top: 50%; margin: -50px 0 0 0;(定高)
  • position+transform:设置父元素position:relative,子元素:position: absolute;top: 50%;transform: translate(0, -50%);(不定高)
  • 百搭flex布局(ie10+),设置父元素display:flex;align-items: center;(不定高)

类似的还有很多,实际应用中,可能就会使用一两种方法,有兴趣的可以看下这篇文章


Q:翻转一个字符串

这个问题主要在笔试题碰到的多,思路就是先将字符串转成一个数组,然后用数组的reverse()+join()方法。

let str="hello word";
let b=[...str].reverse().join("");//drow olleh

后续

前端笔试题面试题记录(下)

小结

我想说的是:在找工作期间,肯定有自己发挥不好,或者不会的问题,一定要在晚上的时候自己再学习总结一下,在一个问题上面尽量不要栽倒两次,学到了的才是自己的。

以上就是近期面试遇到的一些问题记录总结,实际上还是有一些问题没有写出来,许久没有写文章了,写的很慢,有点累。先给自己立一个flag,下周再写一篇出来。希望各位大佬看了本文,能有所收获,感谢阅读。

最后:如需转载,请放上原文链接并署名。码字不易,感谢支持!本人写文章本着交流记录的心态,写的不好之处,不撕逼,但是欢迎指点。然后就是希望看完的朋友点个喜欢,也可以关注一下我。
个人blog and 掘金个人主页

以上2018.3.18

参考链接:

title与alt的区别

CSS-标准盒模型 & 怪异盒模型

常见的js算法面试题收集,es6实现

CSS垂直居中的11种实现方式

前端笔试题面试题记录(上)相关推荐

  1. 前端笔试题面试题记录(下)

    前言 接上篇前端笔试题面试题记录(上).趁清明小长假,把上篇剩下的部分也写一下,因为最近比较忙这篇已经拖了很久了.现在刚刚开始银四了,应该还是有些小伙伴在找工作,时间还不算太晚,希望本篇可以帮到这些小 ...

  2. 也许你需要点实用的-Web前端笔试题

    之前发的一篇博客里没有附上答案,现在有空整理了下发出来,希望能帮助到正在找工作的你,还是那句话:技术只有自己真正理解了才是自己的东西,共勉. Web前端笔试题 Html+css 1.对WEB标准以及w ...

  3. 前端笔试题小结(一)

    前端笔试题小结(一) 2020-03-13 题目一: 将一个js数组去重. 样例: 输入:[ 1, "apple", 3, "a", 3, 1, 5, 6, & ...

  4. 前端笔试题【1】--从字符串的第二个字符开始对数组进行排序

    前一段时间做过一个阿里的前端笔试题:从字符串的第二个字符开始对数组进行排序.当时没想到简单的方法,这几天看书才发现sort()还可以自定义一个比较函数,郁闷啊啊啊~~ 看来基础还是不够扎实啊, 赶紧记 ...

  5. 2022前端秋招面试题总结 阿里 腾讯 字节 百度 网易 京东 小红书 快手面试记录

    2022前端秋招面试题总结 阿里 腾讯 字节 百度 网易 京东 小红书 快手面试记录 等了百度三个月,终于发offer了,白菜价,92大佬们拒的薪资,我知足了. 排序挂了狠多,快手,蚂蚁,- 很绝望 ...

  6. 美团2023年春招在线前端笔试题回忆版

    提示:题目不一定完全正确,只能说给大家参考会考察哪些知识点. 文章目录 前言 一.单选(计算机基础知识) 二.专项选择 三.编程题 1. 某地有一个火车站如下图所示,小红很好奇火车是怎么驶进驶出的,然 ...

  7. sql 以a开头的所有记录_#9#猴子聊数据分析之常见的SQL笔试题和面试题(下)

    题目来源 猴子:常见的SQL笔试题和面试题(下)​zhuanlan.zhihu.com 1.SQL语言允许使用通配符进行字符串匹配的操作,其中'%'可以表示:多个字符 2.通过 SQL,如何从 &qu ...

  8. 2017网易前端笔试题总结

    整理了一下2017网易前端笔试题,附上了自己的答案,仅供参考,欢迎讨论和交流.如果有什么不对的地方,欢迎指正. 题目整理(不含答案) 网盘分享: 链接: https://pan.baidu.com/s ...

  9. html5 笔试题 选择题,2019拼多多前端笔试题

    选择.填空题: 1.IP地址,子网掩码的计算 2.Internet网络层重要协议 3.http请求方法 4.HTML中a标签的伪类 5.alert(undefined==null)的输出结果 6.ht ...

最新文章

  1. checking for C++ compiler default output file name
  2. vim ctrlp找到文件后,如何在新窗口或者新标签中打开
  3. windows共享使用linux生成的密钥
  4. LeetCode 电子书!
  5. Leetcode 534打劫房屋II python
  6. 【今日CV 视觉论文速览】 04 Dec 2018
  7. c语言 炸弹文件,炸弹超人游戏c语言简板
  8. 3-26 C++ 学习
  9. Docker下载redis镜像
  10. 海王夺回王位科学深意:杂种是怎么一步步主宰地球的
  11. PostgreSQL下载安装
  12. 这么写参数校验(validator)就不会被劝退了~
  13. 20/06/27 charles安装报【User installations are disabled via policy on the machine】解决方法
  14. 每天15min-HTML5(10)-表单(上)
  15. 【程序9】题目:要求输出国际象棋棋盘
  16. Jquery--一个form中两个submit事件如何进行区分
  17. 使用cloudflare防御假墙攻击和优化配置
  18. PHP 规则引擎 Hoa\Ruler
  19. 江敏:数据中台驱动下的企业创新升级
  20. 谈谈当代大学生学习IT技术的必要性

热门文章

  1. Redis漏洞?阿里云被攻击!
  2. (7)Zabbix分布式监控proxy实现
  3. Tomcat6 内存和线程配置
  4. ADSL的PPPOE拨号客户端上的ppp authentication pap “callin”的正确理解
  5. 实用javaScript技术-屏蔽总结
  6. 10分钟认识RAID磁盘阵列技术!!!
  7. 用VS2005打开一个.NET2.0方案,里面有几个工程和一个网站,提示网站的项目.csproj文件无法打开:“此安装不支持该项目类型”,的解决办法。...
  8. linux bin命令解释,Linux:“awk”命令的妙用
  9. 可以多次使用同一个hbitmap吗_一个部位可以多次吸脂吗?
  10. 70个Python练手项目列表 预祝大家 快乐