面试3
今天的事今天做,分享面筋,大家共同进步。面出了2身汗,加油。
有的部分忘记了,想起啥写啥,可能有点乱。
第一部分组长面
1.URL的结构
URI—Universal Resource Identifier通用资源标志符
Web上可用的每种资源如HTML文档、图像、视频片段、程序等都是一个来URI来定位的
URI一般由三部组成
①访问资源的命名机制
②存放资源的主机名
③资源自身的名称,由路径表示,着重强调于资源。
URL—Uniform Resource Location统一资源定位符
URL是Internet上用来描述信息资源的字符串,主要用在各种WWW客户程序和服务器程序上,特别是著名的Mosaic。
采用URL可以用一种统一的格式来描述各种信息资源,包括文件、服务器的地址和目录等。
URL一般由三部组成
①协议(或称为服务方式)
②存有该资源的主机IP地址(有时也包括端口号)
③主机资源的具体地址。如目录和文件名等
例子
URI = 作文
URL = 议论文、记叙文、诗歌……
那么
1.宏观描述时,老师会问:今天考试的“作文”大家写的都不错,而不会说大家的“议论文”写的不错,虽然指的是一种东西。
2.客观描述时,你会和同桌说:我今天写的是“诗歌”,而不会啰嗦的说我今天用了诗歌的方式写的作文。
同理
当你写一篇技术文档规范时,你会说某个参数要传递一个URI,而不必说某个参数要传递一个“URL格式的字符串”。
Scheme:// 协议部分,以:作为结束,常见的协议包含HTTP、HTTPS等
//: 层级URL标识符号 可以理解为把协议和后面的信息分开
Login:password@:身份认证 一般的协议都会使用默认的匿名形式进行数据获取
Address:服务器地址 一般是以域名的形式存在
port:服务器端口 不同协议有自己默认的端口号
/path/to/resource: 文件路径 指向唯一一个确定的资源
?query_string:查询字符串
/#fragment:片段ID 这部分内容不会被传递到服务器 一般用于页面的锚,页面下方返回顶部的按钮就是利用这个实现的
2.递归
斐波那契数列,做过笔记的呀,就是不会递归,数据结构学的不好,但是我迭代的方法没问题啊 1 1 2 3 5….
//递归的方法
function test(n){
if(n<2){
return 1;
}
return test(n-1)+test(n-2)
}
alert(test(9))
//迭代的方法
function test(n){
var num1 = 1;
var num2 = 2;
var num3 = 0;
for(var i=0;i<n-2;i++){
num3 = num1 + num2;
num1 = num2;
num2 = num3;
}
}
alert(test(9))
紧张啊,方法2写的四不像
3.浏览器发送请求到页面加载完成,发生了什么
由这个问题才引出问题1 ,自己给自己挖坑
之前总结的不到位。。再来
浏览器开启线程,根据这个www/baidu.com的域名来找DNS服务器,解析成对应的IP地址。例如解析成:http://202.108.22.5 :80/login.aspx
浏览器在解析到IP地址后,做的第二步就是对指定的URL进行HTTP封装,把URL封装成http报文浏览器把URL封装成HTTP报文后,第三步做的事情就是将这个HTTP请求报文发送到服务器
(注:浏览器是如何把http请求报文发送到服务器的呢? 答案:浏览器会在内部建立一个Socket对象,把http请求报文转变成byet[]字节,然后调用Socket.Sent()方法把这些数据发送到服务器的
这里又有一问:页面渲染过程中还会有请求发生么?我的回答:也许
我觉得也许这个回答不算错吧。万一请求的页面就是没有css和图片的‘hello world’呢
其实一般情况是一定有其他请求发生的。eg js 、css 、图片等
4.前后端分离的理解
说了下自己的情况,就是前后端协商接口,前后端协同开发,前端写挡板数据,最后调接口
现在的前后端分离, 后端服务器的角色更像是一个 API Server, 接收请求并且只是以数据的形式返回, 而怎么渲染和表现数据, 都交给更前端的表现层来做, 实现前后端的解耦
5.盒模型
说了标准盒模型和怪异盒模型,常识也不说了
6.了解或使用MV*框架
用过backbone、vue,说了angular和react。。
7.模块化
自己了解吧,不说了
8.说说你公司项目使用的打包工具(开发和用户都有什么好的体验?)
公司用的ant
说了最近其他项目用webpack,
(1)热加载
(2)文件压缩打包
问了webpack的基本配置,自己回答的:entery和output,感觉好浅薄。还是用的少,了解少的缘故吧
webpack的常用配置
entry:{} //加载模块的入口点
output:{}//打包文件的路径和名称
module:{}//那些加载器来处理那些文件
resolve:{}//设置模块的一些细节
plugins:[]//系统插件和扩展插件
9.使用的vue其他生态库
使用了 vue-router、vue-resource,了解vuex
由此引出问题10,11,12
10.说说vue-router的原理,怎么实现路由的
平时做项目能正常跳转就可以了,没有想过路由怎么路由的,没答上来。。
SPA路由实现原理不知道面试官想得到的是不是类似这样的答案。
11.vue的生命周期
12.vue组件通信
父子组件通信的机制,传递数据使用prop属性
动态Prop
用 v-bind
动态绑定 props 的值到组件的数据中。每当父组件的数据变化时,该变化也会传导给子组件。
<div>
<input v-model="parentMsg">
<br>
<child v-bind:my-message="parentMsg"></child>
</div>
<child :my-message="parentMsg"></child>
单向数据流
prop 是单向绑定的:当父组件的属性变化时,将传导给子组件,但是不会反过来。这是为了防止子组件无意修改了父组件的状态——这会让应用的数据流难以理解。
通常有两种改变 prop 的情况:
prop 作为初始值传入,子组件之后只是将它的初始值作为本地数据的初始值使用;
prop 作为需要被转变的原始值传入。
13.说说JSONP的实现原理
JSONP : JSON with Padding
(1)script标签 src属性可以访问外部资源
(2)用script标签加载资源是没有跨域问题的
在资源加载进来之前定义好一个函数,函数接受一个参数,函数中包含 实现逻辑(要做什么事)
通过script标签加载远程文件资源,当远程文件被加载进来时,执行当前定义好的函数,数据就是函数传入的参数
14.职业规划
求职定位,到底想干啥?
第二部分领导面
每一点都非常深入。
1.css盒模型
标准盒模型和怪异盒模型不再重复
box-sizing属性:content-box:标准盒模型,border-box:怪异盒模型
行内元素同样具有盒模型
A.任何元素都可以设置border
<!-- 行内元素可以设置border 设置宽高无效-->
<span style="border:10px solid red;width:100px;height:100px">haha</span>
B.行内元素设置padding,margin 上下是无效的,左右是有效的
<!-- 行内元素设置padding、margin-->
<div style="width:90px;height:100px;background:blue;">
<span style="background:yellow;padding:5px;margin:20px;">1782</span>
<div>
woshidiv
</div>
</div>![Snip20170211_5](/Users/shenyuanyuan/Desktop/Snip20170211_5.png)
行内元素的padding-top、padding-bottom从显示的效果上是增加的,但其实设置的是无效的。并不会对他周围的元素产生任何影响。
黄色内边距5px
左边黄色距离蓝色20px
上下虽然显示padding,但是padding并没有影响其他元素
2.position定位
(1)position的属性有哪些?默认的是什么?
默认值:static
属性有5个分别是:relative、absolute、fixed、inherit、static
(2)例子考察
父元素div :width:500px;height:200px;position: static|absoluta|relative|fixed。 position分别取值,子元素怎么定位?
子元素div:width:200px;height:200px;position:absolute
<!-- 父元素默认static-->
<div style="background:red;width:500px;height:60px;">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:50px;top:30px;">
</div>
</div>
<br>
<!-- 父元素默认relative-->
<div style="background:red;width:500px;height:60px;position:relative">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:50px;top:30px;">
</div>
</div>
<br/>
<!-- 父元素默认fixed-->
<div style="background:gray;width:500px;height:60px;position:fixed">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:50px;top:30px;">
</div>
</div>
<!-- 父元素默认absolute-->
<div style="background:red;width:500px;height:60px;position:absolute">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:50px;top:30px;">
</div>
</div>
发现:子元素绝对定位,按照除了属性为 static以外的第一个父元素定位。所以父元素设置为:absolute、relative、fixed,子元素定位表现一致;
(3)例子考察(事实证明,面试官这道题也错了)
如果子元素设置margin、border、padding呢?子元素左上角的点以margin、border、还是padding定位
<div style="background:red;width:500px;height:60px;position:relative">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:fixed;left:0px;top:30px;">
</div>
</div>
<br/>
<!-- 最原始-->
<div style="background:red;width:500px;height:60px;position:relative">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:10px;top:10px;">
</div>
</div>
<br/>
<!-- 最原始:添加margin-->
<div style="background:red;width:500px;height:60px;position:relative">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:10px;top:10px;margin:10px;">
</div>
</div>
<br/>
<!-- 最原始:添加padding-->
<div style="background:red;width:500px;height:60px;position:relative">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:10px;top:10px;padding:10px;">
</div>
</div>
<br/>
<!-- 最原始:添加botder-->
<div style="background:red;width:500px;height:60px;position:relative">
<div style="background:yellow;width:10px;height:10px;position:absolute;left:0px;top:0px;" >
</div>
<div style="background:blue;width:100px;height:20px;position:absolute;left:10px;top:10px;border:10px solid yellow;margin:5px;">
</div>
</div>
3.BFC(块级格式化上下文)
-
清除遮挡
<div class="left"></div> <div class="right"> </div> .left { width: 100px; height: 100px; background: red; float: left; } .right { height: 200px; background: yellow; overflow:hidden;//属性清楚遮挡 }
关闭浮动
-
解决垂直双边距问题
<div style="background:gray;width:300px;height:300px;overflow:auto"> <div style="background:green;margin-top:10px;float:left;width:20px;height:20px"> </div> <div style="background:red;width:50px;height:50px;margin-top:40px;"></div> </div>
http://runjs.cn/detail/gxpu429g
4.flex(css3新特性)
<div class="container">
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
</div>
.container {
display: flex;
flex-flow: row;
width:300px;
height:100px;
background:gray;
justify-content:space-around
}
.box {
width: 20px;
background:yellow;
height:20px;
}
在线例子:http://runjs.cn/detail/so6kkpof
5.JS原型和原型链
function Foo(){
}
var a = new Foo();//new的操作做了什么
var a = new Object()
a.__proto__ = Foo.prototype
Foo.call(a)
6.闭包
闭包:当函数a的内部函数b被函数a外的一个变量引用的时候,就创建了一个闭包。
function a(){
var i=0;
function b(){
alert(i);
}
return b;
}
var c = a();
c();
7.http
请求头字段和状态码
8.数组去重算法(时间/空间复杂度)
时间复杂度空间复杂度也不会啊。
X.说说你做前端的优势
除了技术,这个也问?感觉没啥优势,优势是移动端经验相对多一点
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。