前端面试题

1 ,什么是闭包?闭包有什么好处?使用闭包要注意什么?

闭包:函数嵌套函数,内部函数可以引用外部函数的参数和变量,变量和参数不会被垃圾回收机制所回收
好处:1)希望一个变量长期驻扎在内存之中
     2)避免全局变量的污染
     3)私有成员的存在
注意:可能会造成内存泄漏

详情可参考:http://www.jianshu.com/p/76ad6105bb8b

2,在js中通过typeof能弹出的数据类型有哪些

number,string,boolean,function,object,undefined

3,arr.pop(),arr.push()有什么区别


4,以下代码弹出结果是什么?

    alert(aSome);
    function aSome(){
        var aSome=3;
        function bSome(){
            var aSome=1;
            alert(aSome);
        }
        bSome();
    }
    aSome();

结果:
1,弹出整个aSome函数体,因为函数预解析
2,弹出1

5,以下代码执行结果是多少?


结果为NaN,因为字符串++时进行隐示类型转化,字母++结果为NaN

6,以下代码的执行结果是多少?

var a='撒旦';
a=parseFloat(a);
alert(a==a);
结果为false,a进行转化以后为NaN,NaN和任何值都不相等,包括自己。

7,常见字符串方法,数组方法,数学方法.

//字符串方法
    str.charAt()
    str.toLowerCase()
    str.toUpperCase()
    str.indexOf()
    str.laseIndexOf()
    str.substring()
    str.split()
//数组方法
    arr.push()
    arr.unshift()
    arr.pop()
    arr.shift()
    arr.join()
    arr.splice()
    arr.reverse()
    arr.concat()
    arr.sort()
//数学方法
    Math.random()
    Math.pow()
    Math.sqrt()
    Math.abs()
    Math.floor()
    Math.ceil()
    Math.round()
    Math.max()
    Math.min()

8,怎样判断浏览器类型是ie6?

if(window.navigator.userAgent.toLowerCase().indexOf('msie 6.0')!=-1){
    alert('是ie6');
}

9,以下代码的执行结果是多少?


结果:5050

10,var str='abc12 34 43av 345 abd567 98 9';写一个程序找出其中的数字

alert(str.match(/\d+/g))

11,get和post的区别

1.Post传输数据时,不需要在URL中显示出来,而Get方法要在URL中显示。
2.Post传输的数据量大,可以达到2M,而Get方法由于受到URL长度的限制,只能传递大约1024字节.
3.Post顾名思义,就是为了将数据传送到服务器段,Get就是为了从服务器段取得数据.而Get之所以也能传送数据,只是用来设计告诉服务器,你到底需要什么样的数据.Post的信息作为http请求的内容,而Get是在Http头部传输的。
get 方法用Request.QueryString["strName"]接收
post 方法用Request.Form["strName"] 接收
注意:
虽然两种提交方式可以统一用Request("strName")来获取提交数据,但是这样对程序效率有影响,不推荐使用。
一般来说,尽量避免使用Get方式提交表单,因为有可能会导致安全问题

12,cookie,localStorage和sessionStorage有什么区别?

共同点:都是保存在浏览器端,且同源的。

区别:
1)cookie数据始终在同源的http请求中携带(即使不需要),即cookie在浏览器和服务器间来回传递。而sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。
2)cookie数据还有路径(path)的概念,可以限制cookie只属于某个路径下。
3)存储大小限制也不同,cookie数据不能超过4k,同时因为每次http请求都会携带cookie,所以cookie只适合保存很小的数据,如会话标识。sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大。
4)数据有效期不同,sessionStorage:仅在当前浏览器窗口关闭前有效,自然也就不可能持久保持;localStorage:始终有效,窗口或浏览器关闭也一直保存,因此用作持久数据;cookie只在设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭。
5)作用域不同,sessionStorage不在不同的浏览器窗口中共享,即使是同一个页面;localStorage 在所有同源窗口中都是共享的;cookie也是在所有同源窗口中都是共享的。

13,以下代码的执行结果是多少?


结果:
1,整个函数体aSome
2,1
3,undefined 因为函数没有返回值

14,以下代码的执行结果是多少?


结果:
1,undefined 变量预解析
2,1

15, 字符串转数字的方法有哪些,怎么进行转换的?

//转化成整数
parseInt('12')=>12
parseInt('12abc')=>12
parseInt('12.5abc')=>12
//保留小数
parseFloat('12')=>12
parseFloat('12abc')=>12
parseFloat('12.5abc')=>12.5

//转化纯数字
Number('12')=>12
Number('12abc')=>NaN
Number('12.5abc')=>NaN

16,封装一个获取随机整数的函数


17.javascript是面向对象的,怎么体现javascript的继承关系?

1.属性
    父级构造函数.apply(this,arguments);
2.方法
    子级构造函数.prototype=new 父级构造();
    子级构造函数.prototype.constructor=子级构造;

18,怎样创建,添加(2种)和删除元素

//创建元素ele表示创建元素的标签名
document.createElement(ele);
//添加
//从后面添加
oParent.appendChild(要添加的元素)
//从前面添加
oParent.insertBefore(要添加的元素,添加到谁的前面);
//要删除的元素
oParent.removeChild(要删除的元素)

19,设置属性的方法有哪些?

1)"." 操作已存在的属性
2)"[]"可以接收变量,"."能操作的,"[]"都可以操作
3)setAttribute(name,value)设置自定义属性

20.列举for/for in 二种循环方法的区别和优缺点。

for
for(初始化; 条件; 自增){
    语句
}
快
不能遍历对象的属性
for in
    for(初始化 in object){
        语句
}
慢
可以遍历对象的属性

21,描述typeof与instanceof,constructor的区别是什么?

typeof
    检测基本数据类型
Instanceof
    检测复合类型
constructor
    检测构造函数

22,javascript中出现undefined的情况有哪些?

1,函数没有返回值,或者返回值为空,出现undefined
2,变量定义了未赋值;
3,引用没有提供实参函数形参的值,出现undefined
4,查询一个对象属性或者数组元素的值不存在,出现undefined

可参考:http://www.jianshu.com/p/b0700cce78c8
23,“=”,“==”,“===”有什么区别?

"="表示赋值 例如a=1;相当于把1赋值给a
"=="表示比较,会做类型转化,然后再进行比较
"==="表示严格比较,不会做类型转化
注:关于具体区别,后续文章会继续跟进

24,数组和字符串如何进行相互转换?

arr.join()将数组转化成字符串
str.plit()将字符串转化成数组

25,你知道的排序方法有哪些?

归并排序,快排,冒泡排序,选择排序
注:关于具体代码,后续文章会继续跟进

26,以下代码alert的结果是什么?

alert(1&&2);
结果为2

27,call和apply的作用什么,区别是什么?

Object.call(this,obj1,obj2,obj3)
Object.apply(this,arguments)

相同点:两个方法产生的作用是完全一样的

不同点:方法传递的参数不同

foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments)==this.foo(arg1, arg2, arg3)

在JavaScript中,代码总是有一个上下文对象,代码处理该对象之内. 上下文对象是通过this变量来体现的, 这个this变量永远指向当前代码所处的对象中。

一、方法的定义
call方法:
语法:call(thisObj,Object)
定义:调用一个对象的一个方法,以另一个对象替换当前对象。
说明:
call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

apply方法:
语法:apply(thisObj,[argArray])
定义:应用某一对象的一个方法,用另一个对象替换当前对象。
说明:
如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。
如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。

28,什么是事件委托?

利用事件冒泡原理,将子级的事件加给父级,使用事件委托,可节省性能,也可以给js动态创建的元素加事件

29,解释一下jsonp的原理,为什么不是真正的ajax?

动态创建script标签,回调函数
Ajax是页面无刷新请求数据操作

30,以下代码的执行结果是多少?

var User = {
 count: 1,

 getCount: function() {
  return this.count;
 }
};

console.log(User.getCount()); // what?

var func = User.getCount;
console.log(func()); // what?
结果为
1,1
2,undefined

31,回答以下代码,alert的值分别是多少


结果为
1,100
2,10
3,10

32,new操作符具体干了什么呢?

1、创建一个空对象,并且 this 变量引用该对象,同时还继承了该函数的原型。
2、属性和方法被加入到 this 引用的对象中。
3、新创建的对象由 this 所引用,并且最后隐式的返回 this 。

33,ajax原理是什么?

(1)创建对象
var xhr = new XMLHttpRequest();
(2)打开请求
xhr.open('GET', 'example.txt', true);

(3)发送请求
xhr.send(); 发送请求到服务器

(4)接收响应
xhr.onreadystatechange =function(){}
 (1)当readystate值从一个值变为另一个值时,都会触发readystatechange事件。
 (2)当readystate==4时,表示已经接收到全部响应数据。
 (3)当status ==200时,表示服务器成功返回页面和数据。
 (4)如果(2)和(3)内容同时满足,则可以通过xhr.responseText,获得服务器返回的内容。

34,程序中怎样捕获异常?

try{}catch(e){}

35,以下代码的执行结果是多少?

var uname = 'jack'
function change() {
    alert(uname) // ?
    var uname = 'lily'
    alert(uname)  //?
}
change()
结果:
1,undefined
2,lily

36,怎样获取浏览器的滚动距离?

scrollTop=document.documentElement.scrollTop||document.body.scrollTop

37,offsetWidth offsetHeight和clientWidth clientHeight的区别

(1)offsetWidth (content宽度+padding宽度+border宽度)
(2)offsetHeight(content高度+padding高度+border高度)
(3)clientWidth(content宽度+padding宽度)
(4)clientHeight(content高度+padding高度)

38,获取本月一共有多少天,怎么获取?


39,什么叫引用?

把一个对象,赋值给新的对象,这个新的对象添加的属性,之前的对象也具备

40,什么是事件对象?

事件对象描述了事件更加详细的信息

41,window.onload和domReady有什么区别?

window.onload是需要html,css,img等页面加载完毕才开始加载js
domReady只需要dom树加载完毕就可以加载js

42,列举css清除浮动的方法

1,为浮动元素父级加overflow:hidden
2,在浮动元素下面加
3,为浮动元素父级加height 4,为浮动元素父级加.clearfix .clearfix:after{display:block; content:'';clear:both;} .clearfix{zoom:1;}

43,如何让一个元素垂直水平居中?


44,你知道的css选择器有哪些?

id选择器( # myid)
类选择器(.myclassname)
标签选择器(div, h1, p)
相邻选择器(h1 + p)
子选择器(ul > li)
后代选择器(li a)
通配符选择器( * )
属性选择器(a[rel = “external”])
伪类选择器(a: hover, li: nth – child)

45,介绍一下css盒子模型?

有两种, IE 盒子模型、标准 W3C 盒子模型;
IE的content部分包含了 border 和 pading;
w3c盒模型: 内容(content)、填充(padding)、边界(margin)、 边框(border).
影响盒子模型大小的包括content+padding+border

46,谈谈This对象的理解。

this是js的一个关键字,随着函数使用场合不同,this的值会发生变化。
但是有一个总原则,那就是this指的是调用函数的那个对象。
this一般情况下:是全局对象Global。 作为方法调用,那么this就是指这个对象

47,以下代码的执行结果是


结果
1,0
2,30

48,css3中transform可以设置哪些样式?

transform:rotate(9deg) scale(0.85,0.90) translate(0px,-30px) skew(-9deg,0deg);//旋转,缩放,定位,倾斜

49,简述对‘use strict’怎么理解?

好处:
1,定义变量,必须加var
2,if,for等语句里不能加函数
3,干掉了with

作用域
1,作用在script标签内部
2,可以作用在函数内部
3,放在整个js文件开头

50,getStyle(obj,‘width’)和obj.offsetWith有什么区别

function getStyle(obj,name){
    return (obj.currentStyle?obj.currentStyle[name]:getComputedStyle(obj,false))[name];
}
getStyle.png

你可能感兴趣的:(前端面试题)