Bootstrap

前端面试宝典

目录

一、HTML

1.行内元素、块元素和行内块元素和特性

2. < image> 标签上title属性与alt属性的区别是什么

3.HTML5新增的标签

4.HTML5新增的那些特性,移除了哪些特性?

5.iframe的优缺点

6.设置文字居中的属性:text-align:center

7.设置标签盒子水平居中的属性:margin:0 auto;

8.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?

二、css相关知识

1.对css布局的理解

2.清除浮动的方法

3.隐藏元素的方法

4.css什么属性可以继承

5.css的选择器

6.css选择器的优先级

7.css的权重规则

8.css中link和@import的区别********

9.定位,子绝父相,弹性盒子比这个简单点

10、如何让一个盒子水平垂直居中?重中之重

11.cookie,sessionStorage,localStorage的区别

12、一个页面上两个div左右铺满整个浏览器,要保证左边的div一直为100px,右边的div跟随浏览器大小变化(比如浏览器为500,右边div为400,浏览器为900,右边div为800),写出大概的css代码

13、什么是跨域,如何解决跨域

13.1什么是跨域?

13.2.跨域实例演示

13.3.如何解决跨域问题

14、前端如何优化网站性能

14.1减少http的请求数量

14.2控制资源文件加载优先级

14.3利用浏览器缓存

14.4减少重排(Reflow)

14.5减少DOM操作

14.6图标使用IconFont替换

15、对css盒子模型的理解

15.1标准盒子模型

15.2IE盒子模型

box-sizing

16.css盒子的margin中的合并和塌陷问题如何解决?

16.1什么是margin合并?

16.2什么是margin塌陷

16.3如何解决塌陷问题

17.如何用css绘制一个实心三角?

18.css3新增属性

18.1新增边框属性

18.2新增背景属性

18.3新增文字效果

18.4新增动画效果

18.5过渡效果transition

18.6媒体查询@media

19.px,em,rem的区别

19.1定义

19.2特点

20.display:inline-block什么时候会出现间隙?及解决办法。

20.1介绍

20.2空隙产生的原因:

20.3先看例子

21.解释下 CSS sprites原理,优缺点

22.弹性盒子

23.对 BFC 规范(块级格式化上下文:block formatting context)的理解?

23.1.什么是BFC?

23.2BFC的特性

23.3形成BFC的条件

23.4.BFC形成后出现的常见问题

23.5.BFC可以解决的问题

24.css3新增的伪类有哪些?

25.如何居中div?如何居中一个浮动元素?如何让绝对定位的div居中?如何居中一个img(position定位)

26、localStorage和sessionStorage的区别?

27.常见的兼容性问题

27.1.概念

27.2.双倍浮动的bug

27.3.表单元素行高不一致

27.4.在IE6中,不能识别较小高度的容器(一般为20px)

27.5.a标签里嵌套img时,有些浏览器(例如IE浏览器)下会出现颜色的边框

27.6.在IE6中不能识别min-height属性

27.7.图片默认有空隙

27.8.IE8及以下浏览器不能识别opacity属性

27.9.鼠标指针bug

27.10.百分比bug

三、js部分面试题

1.js的数据类型有哪些?如何判断js的数据类型

2.NAN是什么?

3.JS中的数据类型转换

4.如何判断得到的结果是不是数组?

5、js的运算符都有什么?

6.js的运算符的规则

7.js语句的相关考点?

8、js中对数组的常用操作

9、JavaScript this 指针

9.1.this介绍

9.2.用法

9.3.js原生函数的this绑定规则

10、闭包

10.1概念

10.2用法

11.DOM对象的常用方法

12.什么是js的同源策略和如何解决跨域

12.1.什么是同源策略?

12.2.如何解决跨域?

13.已知ID的input输入框,希望获取这个输入框的输入值,怎么做?

14.设置一个已知id的div的HTML内容为xxxxx,字体颜色设置为黑色(不使用第三方框架)

15.当一个dom节点被点击的时候,我们希望能够执行一个函数,应该怎么做?

16、已知数组var stringArray = [“This”, “is”, “Baidu”, “Campus”],alert出”This is Baidu Campus”

17.输出今天的日期,以YYYY-MM-DD的方式,比如今天是2014年9月26日,则输出2014-09-26?

18.看代码运行结果,并说明原因。

19.js的内置对象

20.this对象的理解

21.eval是做什么的?

21.1.eval()的作用

21.2.用法

22.DOM怎样添加、移除、移动、复制、创建和查找节点

23.null和undefined的区别

23.1.null

23.2.undefined

24.new操作符具体干了什么?

25.JSON的了解

26.call()和apply()的区别和作用

26.1.区别

26.2.作用

27.如何解决跨域问题

28.ES6的了解

29.对闭包的理解

30.浏览器本地储存

30.1介绍

30.2.sessionStorage和localStorage的区别

31.javascript对象的几种创建方式

32.简述AJAX及基本步骤

32.1简述

32.2基础步骤

33.HTTP状态码

34.同步和异步的区别

35.get和post的区别,何时使用post?

35.1.get和post的区别

35.2.何时使用post

36.new操作符具体干了些什么

37.null 和 undefined 的区别?

38.JavaScript 原型,原型链 ? 有什么特点?

38.1.原型

38.2.原型链

38.3.原型链的特点


前端面试宝典

CSDN话题挑战赛第2期
参赛话题:面试宝典

众人拾柴火焰高,我们一起携手共筑面试宝典,大家可以将各语言各技术各类面试真题或者你刷过的面试题汇聚于此,金九银十之际,让我们助应聘同学一臂之力~
你可以从以下几个方面着手(不强制),或者根据自己对话题主题的理解创作,参考如下:

一、HTML

1.行内元素、块元素和行内块元素和特性

  1. display:inline;转换成行内元素
  2. display:block;转换为块状元素
  3. display:inline-block;转换成行内块元素
  • 行内元素主要有:span,strong,em,label,select,textarea

特征:margin左右有效,上下无效;padding上下左右都有效,设置宽高无效,不会自动换行

  • 块级元素主要有div ,p、nav、aside、header、footer、section、ul-li、address,article

特征:margin上下左右都有效,识别宽高,自动换行,多个块级元素写在一起,默认从上到下排列

  • 行内块元素:img 、input

    特征:结合了行内元素和块级元素的特征

    不自动换行,能够识别宽高,默认排列方式是从左到右

    对margin和padding的左右上下均有效

2. < image> 标签上title属性与alt属性的区别是什么

title属性为设置该属性的元素提供建议性的信息,(鼠标经过的时候出现的提示文字)

alt属性是为了给那些不能看到图像的浏览者提供文字说明的

3.HTML5新增的标签

section:定义文章中的一个章节

nav:定义只包含导航链接的章节

header:定义页面或者章节的头部,通常包括logo,标题,导航栏,有的还包括搜索框

footer:定义页面或者章节的底部,通常包括底部的版权,关于我们,联系客服

aside:定义页面的侧面的章节,删除之后也不会对整个页面有啥影响

4.HTML5新增的那些特性,移除了哪些特性?

HTML5主要是图像(image),位置(address),储存(storage),多任务等功能的增加

拖拽释放(Drag and drop) API

语义化标签(header、nav、footer、aside、article、section)

音频视频标签(audio,video)***

画布(Canvas)API

地理(Geolocation)API

本地离线储存localStorage长期储存数据,浏览器关闭后数据不会丢失

sessionStorage的数据会在页面会话结束后被清除

表单控件:calendar、date、time、email、url、search

移除的元素:

纯表现的元素:basefont,big,u

对可用性产生负面影响的元素:frame,frameset

5.iframe的优缺点

  • 优点:
    1. 解决了加载缓慢的第三方内容如图标和广告等的加载问题
    2. iframe无刷新文件上传
    3. iframe跨域通信
  • 缺点:
    1. iframe会阻塞主页面的Onload事件
    2. 无法被一些搜索引擎引到
    3. 页面会增加服务器的http请求
    4. 会产生很多页面,不容易管理

6.设置文字居中的属性:text-align:center

7.设置标签盒子水平居中的属性:margin:0 auto;

8.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?

IE:trident内核

Firefox:gecko内核

Safari:webkit内核

Opera:以前是presto内核,Opera现已改用GoogleChrome的Blink内核

Chrome:Blink(基于webkit,Google与OperaSoftware共同开发)

二、css相关知识

1.对css布局的理解

固定布局,流式布局,弹性盒子,浮动,定位,margin,padding,响应式布局

2.清除浮动的方法

(1)添加新的元素,应用clear:both

<style>
    .clear{
        clear:both; 
        height: 0; 
        line-height: 0; 
        font-size: 0
    }
</style>
<div class="outer">    
    <div class="div1">1</div>    
    <div class="div2">2</div>    
    <div class="div3">3</div>    
    <div class="clear"></div>
</div>

(2)给父级元素定义overflow

<style>
    .over-flow{    
        overflow: auto; //也可以设置hidden    
        zoom: 1; 
        //zoom: 1; 处理兼容性问题
    }
</style>
<div class="outer over-flow"> //这里添加了一个class    
    <div class="div1">1</div>    
    <div class="div2">2</div>    
    <div class="div3">3</div>    
    <!--<div class="clear"></div>-->
</div>

(3):after方法(注意:作用于浮动元素的父级)

利用:after和:before来在元素内部插入两个元素块,从而达到清除浮动的效果。其实现原理类似于clear:both方法,只是区别在于:clear在html插入一个div.clear标签,而clearfix利用其伪类:after在元素内部增加一个类似于div.clear的效果

<style>
    .clearfix {
        zoom:1;
    }    /*==for IE6/7 Maxthon2==*/
    .clearfix:after {    
        clear:both;    
        content:'';    
        display:block;    
        width: 0;    
        height: 0;    
        visibility:hidden;
    }   /*==for FF/chrome/opera/IE8==*/
</style>
<div class="clearfix">    
    <div class="div1">1</div>    
    <div class="div2">2</div>    
    <div class="div3">3</div>
</div>

3.隐藏元素的方法

  1. visibility:hidden; 只是简单的隐藏某个元素,但是元素占用的空间仍然存在
  2. opacity:0;一个css3属性,设置0可以使一个元素完全人透明,制作出和visibility一样。 与visibility相比,它可以被transition和animate
  3. display:none;元素会变得不可见,并且不会再占用文档的空间
  4. position:absolute;是元素脱离文档流,处于普通文档之上,给它设置一个很大的left负值定位,使元素定位在可见区域之外。

4.css什么属性可以继承

字体属性:

font-family,font-weight,font-size,font-style,

文本属性:

text-indext文本缩进

text-align文本水平对齐

line-height行高

word-spacing:单词之间的间距

letter-spacing:中文或者字母之间的间距

text-transform:控制文本大小写(就是uppercase、lowercase、capitalize这三个)

color颜色

注:字体以及文本相关的属性可以继承

5.css的选择器

元素选择器:标签选择器,id选择器,类选择器

关系选择器:子集选择器,后代选择器

属性选择器:E[att]、E[att="val"]等等

伪类选择器:E:link、E:visited、E:hover、E:active E:first-child、E:last-child等

伪对象选择器:E:before和E:after等

6.css选择器的优先级

!important>id>类>标签选择器

7.css的权重规则

一个行内样式+1000,一个id—+100,一个属性选择器/class类/伪类选择器+10,一个元素名/伪对象选择器+1。

8.css中link和@import的区别********

两者都是外部应用css样式,但是存在一定的区别
(1)link:
HTML标签,加载css,定义RSS等其他事务,
引用css时,在页面载入同时加载
XHTML标签,无兼容问题
支持使用JavaScript控制DOM改变样式
(2)@import:
属于css范畴,只可以加载css
页面完全载入以后再加载
在css2.1提出的,低版本的浏览器不支持,所有以兼容性问题
不支持使用JavaScript控制DOM改变样式

9.定位,子绝父相,弹性盒子比这个简单点

相对定位:positive:relative;它是参照它在页面中原来的位置进行移动的。
绝对定位:position:absolute;它是相对于距离它最近的有定位的父元素进行移动的
固定定位:position:fixed;它是相对于页面的位置进行移动的
注意:只有添加了定位的元素才可以设置z-index属性,后面的值代表层级,没有px等单位。

10、如何让一个盒子水平垂直居中?重中之重

//已知宽高
<div class="div1"></div>
<style>    
    .div1{        
        width:400px;        
        height:400px;        
        position:absolute;        
        left:50%;        
        top:50%         
        margin:-200px 0 0 -200px;        
        background-color:red;    
    }   
</style>//未知宽高
<!DOCTYPE html>
<html lang="en">
    <head>    
        <meta charset="UTF-8">    
        <title>Document</title>    
        <style>        
            .div1{            
                position: absolute;            
                left: 0;            
                top: 0;            
                bottom: 0;            
                right: 0;            
                margin: auto;            
                border: 1px solid #000;            
                width: 400px;            
                height: 400px;        
            }    
        </style>
    </head>
    <body>    
        <div class="div1"></div>
    </body>
</html>
//未知宽高方法二:
<!DOCTYPE html>
<html lang="en">
    <head>    
        <meta charset="UTF-8">    
        <title>Document</title>    
        <style>        
            .div1{            
                position: absolute;            
                left: 50%;            
                top: 50%;            
                transform: translate(-50%,-50%);            
                border: 1px solid #000;            
                width: 400px;            
                height: 400px;        
            }    
        </style>
    </head>
    <body>    
        <div class="div1"></div>
    </body>
</html>

//未知宽高方法三:

css3的伸缩盒子

11.cookie,sessionStorage,localStorage的区别

①cookie,session的区别

cookie和session都是用来跟踪浏览器用户身份的会话方式。

区别:

1、保持状态:cookie保存在浏览器端,session保存在服务器端

2、使用方式:

(1)cookie机制:如果不在浏览器中设置过期时间,cookie被保存在内存中,生命周期随浏览器的关闭而结束,这种cookie简称会话cookie。如果在浏览器中设置了cookie的过期时间,cookie被保存在硬盘中,关闭浏览器后,cookie数据仍然存在,直到过期时间结束才消失。

Cookie是服务器发给客户端的特殊信息,cookie是以文本的方式保存在客户端,每次请求时都带上它

(2)session机制:当服务器收到请求需要创建session对象时,首先会检查客户端请求中是否包含sessionid。如果有sessionid,服务器将根据该id返回对应session对象。如果客户端请求中没有sessionid,服务器会创建新的session对象,并把sessionid在本次响应中返回给客户端。通常使用cookie方式存储sessionid到客户端,在交互中浏览器按照规则将sessionid发送给服务器。如果用户禁用cookie,则要使用URL重写,可以通过response.encodeURL(url) 进行实现;API对encodeURL的结束为,当浏览器支持Cookie时,url不做任何处理;当浏览器不支持Cookie的时候,将会重写URL将SessionID拼接到访问地址后。

3、存储内容:cookie只能保存字符串类型,以文本的方式;session通过类似与Hashtable的数据结构来保存,能支持任何类型的对象(session中可含有多个对象)

4、存储的大小:cookie:单个cookie保存的数据不能超过4kb;session大小没有限制。

5、安全性:cookie:针对cookie所存在的攻击:Cookie欺骗,Cookie截获;session的安全性大于cookie。

原因如下:(1)sessionID存储在cookie中,若要攻破session首先要攻破cookie;

(2)sessionID是要有人登录,或者启动session_start才会有,所以攻破cookie也不一定能得到sessionID;

(3)第二次启动session_start后,前一次的sessionID就是失效了,session过期后,sessionID也随之失效。

(4)sessionID是加密的

(5)综上所述,攻击者必须在短时间内攻破加密的sessionID,这很难。

6、应用场景:

cookie:(1)判断用户是否登陆过网站,以便下次登录时能够实现自动登录(或者记住密码)。如果我们删除cookie,则每次登录必须从新填写登录的相关信息。

(2)保存上次登录的时间等信息。

(3)保存上次查看的页面

(4)浏览计数

session:Session用于保存每个用户的专用信息,变量的值保存在服务器端,通过SessionID来区分不同的客户。

(1)网上商城中的购物车

(2)保存用户登录信息

(3)将某些数据放入session中,供同一用户的不同页面使用

(4)防止用户非法登录

7、缺点:cookie:(1)大小受限

(2)用户可以操作(禁用)cookie,使功能受限

(3)安全性较低

(4)有些状态不可能保存在客户端。

        (5)每次访问都要传送cookie给服务器,浪费带宽。

(6)cookie数据有路径(path)的概念,可以限制cookie只属于某个路径下。

session:(1)Session保存的东西越多,就越占用服务器内存,对于用户在线人数较多的网站,服务器的内存压力会比较大。

(2)依赖于cookie(sessionID保存在cookie),如果禁用cookie,则要使用URL重写,不安全

(3)创建Session变量有很大的随意性,可随时调用,不需要开发者做精确地处理,所以,过度使用session变量将会导致代码不可读而且不好维护。

二、localStorage和sessionStorage区别

  • localStorage和sessionStorage一样都是用来存储客户端临时信息的对象。

  • 他们均只能存储字符串类型的对象(虽然规范中可以存储其他原生类型的对象,但是目前为止没有浏览器对其进行实现)。

  • localStorage生命周期是永久,这意味着除非用户显示在浏览器提供的UI上清除localStorage信息,否则这些信息将永远存在。

    sessionStorage生命周期为当前窗口或标签页,一旦窗口或标签页被永久关闭了,那么所有通过sessionStorage存储的数据也就被清空了。

  • 不同浏览器无法共享localStorage或sessionStorage中的信息。相同浏览器的不同页面间可以共享相同的 localStorage(页面属于相同域名和端口),但是不同页面或标签页间无法共享sessionStorage的信息。这里需要注意的是,页面及标 签页仅指顶级窗口,如果一个标签页包含多个iframe标签且他们属于同源页面,那么他们之间是可以共享sessionStorage的

浅总结一下:

cookie是网站为了标示用户身份而储存在用户本地终端(Client Side)上的数据(通常经过加密)。
cookie数据始终在同源的http请求中携带(即使不需要),也会在浏览器和服务器间来回传递。
sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。

存储大小:
    cookie数据大小不能超过4k。
    sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大。

有期时间:
    localStorage    存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;
    sessionStorage  数据在当前浏览器窗口关闭后自动删除。
    cookie          设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭

12、一个页面上两个div左右铺满整个浏览器,要保证左边的div一直为100px,右边的div跟随浏览器大小变化(比如浏览器为500,右边div为400,浏览器为900,右边div为800),写出大概的css代码

方法一:
<!DOCTYPE html>
<html lang="en">
    <head>    
        <meta charset="UTF-8">    
        <meta http-equiv="X-UA-Compatible" content="IE=edge">    
        <meta name="viewport" content="width=device-width, initial-scale=1.0">        <title>Document</title>    
        <style>        
            .left{            
                width: 100px;            
                height: 200px;            
                background-color: #000;            
                float: left;        
            }        
            .right{            
                background-color: red;            
                margin-left: 100px;            
                height: 200px;        
            }    
        </style>
    </head>
    <body>    
        <div class="left"></div>    
        <div class="right"></div>
    </body>
</html>

浮动效果:

<!DOCTYPE html>
<html lang="en"><head>    
    <meta charset="UTF-8">    
    <meta http-equiv="X-UA-Compatible" content="IE=edge">    
    <meta name="viewport" content="width=device-width, initial-scale=1.0">  
    <title>Document</title>    
    <style>        
        .big{            
            display: flex;            
            flex-direction: row;            
            align-items: center;        
        }        
        .left{            
            flex-basis: 100px;//初始长度            
            background-color: blue;            
            height: 300px;        
        }        
        .right{            
            background-color: green;            
            height: 300px;            
            flex-grow: 1;        
        }    
    </style>
    </head>
    <body>    
        <div class="big">        
            <div class="left"></div>        
            <div class="right"></div>    
        </div>
    </body>
</html>

13、什么是跨域,如何解决跨域

13.1什么是跨域?

跨域是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript实施的安全限制。

什么是同源策略呢?

同源策略是浏览器最核心也是最基本的安全功能,它是由Netscape提出的一个著名的安全策略。现在所有支持JavaScript的浏览器都会只用这个策略,所谓同源是指:域名,协议,端口相同,有一个不一样就是非同源策略

同源策略限制的情况:

1、Cookie、LocalStorage 和 IndexDB 无法读取

2、DOM 和 Js对象无法获得

3、AJAX 请求不能发送

注意:对于像 img、iframe、script 等标签的 src 属性是特例,它们是可以访问非同源网站的资源的。

13.2.跨域实例演示

13.3.如何解决跨域问题

  1. response添加header
  2. JSONP方式
  3. CORS
  4. HttpClient请求转发
  5. nginx转发
总结:
JSONP、CORS、通过修改document.domain来跨子域、使用window.name来进行跨域、HTML5中新引进的window.postMessage方法、在服务器上设置代理页面 
1、JSONP  原理是:动态插入script标签,通过script标签引入一个js文件,这个js文件载入成功后会执行我们在url参数中指定的函数,并且会把我们需要的json数据作为参数传入。  由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源,为了实现跨域请求,可以通过script标签实现跨域请求,然后在服务端输出JSON数据并执行回调函数,从而解决了跨域的数据请求。  优点是兼容性好,简单易用,支持浏览器与服务器双向通信。缺点是只支持GET请求。 
2、CORS  服务器端对于CORS的支持,主要就是通过设置Access-Control-Allow-Origin来进行的。如果浏览器检测到相应的设置,就可以允许Ajax进行跨域的访问。  
3、通过修改document.domain来跨子域  将子域和主域的document.domain设为同一个主域.前提条件:这两个域名必须属于同一个基础域名!而且所用的协议,端口都要一致,否则无法利用document.domain进行跨域  主域相同的使用document.domain  
4、使用window.name来进行跨域  window对象有个name属性,该属性有个特征:即在一个窗口(window)的生命周期内,窗口载入的所有的页面都是共享一个window.name的,每个页面对window.name都有读写的权限,window.name是持久存在一个窗口载入过的所有页面中的

14、前端如何优化网站性能

14.1减少http的请求数量

在浏览器与服务器进行通信时,主要是通过http进行通信。浏览器与服务器需要通过三次握手,每次握手需要花费大量时间。而且不同浏览器对资源文件并发请求数量有限(不同浏览器允许并发数),一旦HTTP请求数量达到一定数量,自愿请求就存在等待状态,这是很致命的,因此减少http的请求数量可以很大程度上对网站性能进行优化。

14.1.1css Sprite

又称精灵图,雪碧图,将多张图片弄成一张图片,减少http请求的一种解决方案,可以通过css的background属性来访问图片内容。这种方案同时还可以减少图片总字节数。

使用雪碧图的优点:

  • 将多张图片合并到一张图片中,可以减少图片的总大小
  • 将多长图片合并成一张后,下载全部所需的资源,只需要一次请求,可以减小建立连接的消耗。

如何生成雪碧图?

这个有很多软件可以使用,Firework,首先新建文件夹,宽度一般为100像素,高度可以根据图片的大小来设定,画布颜色为透明色,点击确定。再返回图片,点击裁剪工具,再点击指针工具,Ctrl+c复制,Ctrl+v粘贴。

Photoshop也可以

如何使用雪碧图?

(1)确定在哪里引入精灵图,并为其设置大小

(2)在样式css中插入背景图,background-image:url("路径");

(3)利用background-position:x,y;属性和background-size:cover;background-repeat:no-repeat;等属性的组合进行定位。

在使用精灵图过程中可能会遇到的问题?

  • 雪碧图太大,安放到指定位置只会显示一部分???

    两个解决办法:

    1. 上传雪碧图是就按照需要的大小上传
    2. 使用background-size:属性缩放整块背景图,这里要注意下缩放了背景图的
;