前端面试js部分
一、变量类型
1.值类型
data:image/s3,"s3://crabby-images/571b6/571b6b1c380a0ddf10dc88071afc25e328e83ca3" alt=""
2.引用类型
1)包括:对象,数组,函数。
2)特点:1.无限扩展属性(为了与内存共用空间)
2.都具有对象特性(null除外)
3.都有__proto__属性(隐式原型)
4.所有函数都有 prototype(显示原型)
5.__proto__属性指向它的构造函数的prototype值( var obj={}; obj.__proto__===Object.prototype //true)
6.当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性,那么会去它的__proto__(即它的构造函数的prototype)中寻找。
data:image/s3,"s3://crabby-images/912a7/912a7389c975f9fc1e3aa12481caa83430494f21" alt=""
二、typeof运算符
1.undefined
2.string
3.number
4.booleans
5.object
6.function
data:image/s3,"s3://crabby-images/759ad/759adb4a586e733bbee734e86a97c56274777f68" alt=""
三、“==”运算符
100=="100"//true;
0==' '//true;
null==undefined//true;
注:几个特殊
0,NaN,' ',null,undefined,false 均返回false
data:image/s3,"s3://crabby-images/72dbf/72dbf20e0c4a61955268a3acfd8fad9691843010" alt=""
四、原型规则例子
//构造函数
funciton Foo(name,age){
this.name = name;
}
Foo.prototype.alertName = function(){
alert(this.name);
}
//创建示例
var f = new Foo('zhangsan')
f.printName = function(){
console.log(this.name)
}
//test
f.printName();
f.alertName();
f.toString();
data:image/s3,"s3://crabby-images/ab695/ab695515ae866e428b58553e76c8ba4c5298e93f" alt=""
data:image/s3,"s3://crabby-images/2d1c1/2d1c15cf79a141a3e5f35b749cb93caf4eb6f02d" alt=""
五、函数声明和函数表达式
1、函数声明和函数表达式
data:image/s3,"s3://crabby-images/25af3/25af39229fa3e19766719f230d507c8e4e4937f4" alt=""
2、this的用法:this要在执行时才能确认值,定义时无法确认
data:image/s3,"s3://crabby-images/6ce67/6ce672b5913e2b36a015483316d34f8f4902d2cb" alt=""
1)this作为构造函数来执行
data:image/s3,"s3://crabby-images/c4d72/c4d727da0222439fbebdb48f26350a787fd030a4" alt=""
2)this作为对象属性来执行
data:image/s3,"s3://crabby-images/57732/5773288a420d40323ec1451a70ec2835a0cec1d7" alt=""
3)this作为普通函数执行
data:image/s3,"s3://crabby-images/dab42/dab42003c1da9f8c8c260f0d1dc2a606bd0fd18d" alt=""
4)call apply bind方式
data:image/s3,"s3://crabby-images/c0297/c0297eea14b5279950698c3b428234f5258ea42a" alt=""