猫眼娱乐前端面经(10.24)

电话面试+石墨文档写代码(1小时)
1、自我介绍
2、对网络了解吗?说一下OSI七层模型?TCP协议在哪一层?HTTP协议在哪一层?
3、HTTP和HTTPS的区别是什么?HTTPS是如何建立信息安全通道的?
4、HTTP状态码了解吗?说几个
5、302状态码是什么情况下会出现?我提了ETag和Last-modified
6、ETag是客户端设置还是服务端设置的?
7、队列和栈的区别是什么?
8、问flex布局用过没?答没有。问我的项目里用到的布局是什么布局?我说两列布局,让说一下怎么实现
9、问除了两列布局还有什么?说三列布局,怎么实现?
10、清除浮动?提到了overflow:hidden,为什么overflow可以清楚浮动?提到了BFC布局
11、什么是BFC布局?触发条件有哪些?BFC布局有什么作用?
12、提到了margin重叠,如何防止margin重叠?
13、合并有序数组(使用的石墨文档链接)
let a = [2,6,10,12]
let b = [4,6,12,78]
fucntion merge(a,b){
    var arr = [];
    var i = 0;
    var j = 0;  while(i < a.length && j < b.length){  if(a[i] <= b[j]){  arr.push(a.slice(i,i+1)[0]);  i++;  } else {  arr.push(b.slice(j,j+1)[0]);  j++;  }  }  while(i < a.length){  arr.push(a.slice(i,i+1)[0]);  i++;  }  while(j < b.length){  arr.push(b.slice(j,j+1)[0]);  j++;  }  return arr;
}

这里为什么要用slice?
14、获取下面url中的参数转化成下面的queryObj对象:

var url = "https://shimo.im/docs/YhI6qCOxvWo3ORtq?a=123&b=qwe"

var queryObj = {

a: 123,

b: qwe

}

function getUrl(url){  var obj = new Object();  if(url.indexOf("?") != -1){  var def = url.split("?");  strs = def[1].split("&");  for(var i = 0; i < strs.length; i++){  var args = strs[i].split("=");  obj[args[0]] = args[1];  }  }  return obj;
}
15、跳转链接,一个url中包含另一个url链接的样子是什么

举例:var url ="https://shimo.im/docs/YhI6qCOxvWo3ORtq?redirectUrl=https://shimo.im/docs/YhI6qCOxvWo3ORtq&b=123"

这样的格式是正确的吗?

16、如下所示:定义了一个函数Parent,child是Parent的实例,要怎么获取到Parent的方法

function Parent(){}

var child = new Parent()

答:

Parent.prototype.sayName = function(){

console.log(this.name);

}

又问:

var p = Parent.prototype

child.xxxxx == p

xxxxx是什么的时候等于p?

答:child.prototype.prototype == p 是不对的

17、排序算法有哪些?又问快速排序的时间复杂度是什么?最坏时间复杂度是什么?
18、vue渲染页面中的key值是什么意思?如果没有key会发生什么?
19、vue中初始化定义了vm.data(赋了初值),会不会立即渲染到页面上?为什么?
#面经##猫眼##秋招##前端工程师#
全部评论
16 __proto__,浏览器是这个.其实不准确。更精确的是[[Prototype]],
点赞 回复 分享
发布于 2018-10-24 15:43

相关推荐

1、页面白屏可能是什么原因?1.&nbsp;JS&nbsp;执行报错代码出现错误、空值异常、变量未定义等问题,导致渲染中断,页面无法正常显示。2.&nbsp;静态资源加载失败JS、CSS&nbsp;等关键资源加载超时、404&nbsp;或路径错误,造成页面渲染失败。3.&nbsp;接口请求异常关键数据接口报错、跨域或无返回内容,页面因缺少数据无法渲染。4.&nbsp;路由与打包配置错误路由匹配失败、发布路径配置不正确。5.&nbsp;状态管理数据丢失Vuex&nbsp;/&nbsp;Pinia&nbsp;存储在内存中,页面刷新后数据清空,可能引发白屏。6.&nbsp;渲染压力过大数据量过大、死循环或大量计算导致页面阻塞。2、刷新页面数据丢失原因及解决办法原因:Vuex、Pinia&nbsp;这类状态管理工具是将数据存储在内存中的,页面刷新后,内存数据会被重置清空,从而导致数据丢失。解决办法:给状态管理开启持久化,使用对应的持久化插件,将数据存入&nbsp;localStorage&nbsp;或&nbsp;sessionStorage,刷新页面后重新读取数据,即可避免丢失。3、你知道哪些前端组件?我常用的组件主要包括&nbsp;Vue&nbsp;内置组件、UI&nbsp;组件以及自己封装的组件:1.&nbsp;Vue&nbsp;内置组件KeepAlive、Transition、Teleport、Suspense2.&nbsp;常用&nbsp;UI&nbsp;组件Table、Pagination、Form、Input、Button、Dialog、Menu、Card、Select、Checkbox、Radio、Tooltip、Message3.&nbsp;自己封装的通用组件公共表格组件、分页组件、搜索组件、弹窗组件、权限相关组件
查看3道真题和解析
点赞 评论 收藏
分享
评论
5
63
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务