JavaScript知识复习

JavaScript

数据类型

原始数据类型:

number
string
boolean
null
undefined
对象:object:
Function
Array
Date...
共有六种数据类型,五种原始数据类型,一种对象类型。
弱类型的表现,字符与数字做加法,数据的取整等。

隐式转换

字符串与数字使用会以拼接的方式计算结果。

=》字符串与数字之间的转换:巧用+-,字符串数字减0得到数字,数字加空字符串可以转换成字符。

        var str = '37';
        var num = 37;
        str = str - 0;
        num = num + '';
        console.log(str);
        console.log(typeof str);
        //37
        //number

        console.log(num);
        console.log(typeof num);
        //37
        //string
//如果符号使用相反不能发生变换

a == b情况

'1.23' == 1.23
0 == false
null == undefined
new Object() == new Object()
[1,2] == [1,2]

a === b 判断类型

null === null
undefined === undefined
NaN != NaN//NaN 不等于任何包括自己
new Object() != new Object()//对象的比较是对象的引用

在==时发生隐式转换。

包装对象:

string-->String
number-->NUmber
boolean-->Boolean

var a = "assassin";
console.log(a.length);
//8, ?为何有length属性,
a.t = 3;
console.log(a.t);
//undefined 

当基本类型视图以对象的方式访问时,JavaScript回把基本类型转化为包装类型对象,可以使用对象的方法。eg:a.t = 3;这样的操作,会创建临时对象,赋值完成后临时对象马上销毁。

类型检测:

typeof 基本类型,函数对象
instanceof
Object.prototype.toString
constructor
duck type

typeof: 判断基本类型,函数对象,null失效

typeof 100   number
typeof true  boolean
typeof function  function

typeof (undefined)  undefined
typeof new Object  object
typeof [1,2,3]  object
typeof NAN  number
typeof null  object //有特殊的原因

instanceof: 判断对象类型,基于原型连的判断

obj instanceof Object
//左操作数的对象的原型链上是否有右边构造函数的prototype属性。
//注意:不同的window,iframe间的对象雷响检测不能使用instanof

Object.prototype.toString.appley():

Object.prototype.toString.appley([]) === "[object Array]";
...

IE6,7,8用这种方法判断null时还是返回[object object],其他返回[object null]

constructor:
duck type

运算符

特殊运算符

? : 条件运算符

var val = true ? 1 : 2;

, 逗号运算符

var val = (1,2,4);//val = 4

delete 删除对象的属性
in

window.x = 1;
x in window;//true

new 运算符 创建构造器的实例

语句

for...in

1.顺序不确定
2.enumerable为false时不会出现
3.for in遍历对象属性时受原型链影响

对象

对象中包含一系列属性,这些属性是无序的,每个属性都有一个字符串key和对应的value.

创建

字面量:

var obj1 = {x: 1, y: 2};

使用构造器:

function foo() {}
foo.prototype.z = 3;
var obj = new foo();
obj.x = 1;
obj.y = 2;

obj.z;//3
typeof obj.toString;//function obj的原型prototype访问到foo上的原型,在访问到Object的原型,prototype是Object上的一个函数
'z' in obj;//true
obj.hasOwnProperty('z');//false,z是foo上的属性

使用Object.create(),传递对象格式创建

var obj = Object.create({x: 1});
//它的原型基于Object

对象的操作

delete删除属性
delete obj.x;
查看对象的描述器:

var descriptor = Object.getOwnPropertyDescriptor(Object, 'prototype');
descriptor.configurable;//false 他是描述对象的原型是否可以被修改,true可以被修改

delete方法不能删除全局变量,函数等,只有变量在隐式转换后可以删除。

属性枚举:

var o = {
    x: 1,
    y: 2
}
var key;
for(key in o) {
    if(o.hasOwnProperty(key)) {
        console.log(key);
    }
    //x,y
}

序列化

var obj = {
    x: 1,
    y: true,
    z: [1,2,3],
    nullVall: null
};
JSON.stringify(obj);
//"{"x": 1,"y": true,"z":[1,2,3],"nullVal": null}"
// 如果对象的值为undefined,则此属性但是不会序列化的
var obj = {
    x: 1,
    y: true,
    z: [1,2,3],
    nullVall: null,
    value: undefined
};
JSON.stringify(obj);
//"{"x": 1,"y": true,"z":[1,2,3],"nullVal": null}"
//值如果为NaN,Infinity则会转化为null,时间会自动转换格式。

JSON.parse();解析成对象格式

数组

js 中的数组是动态的
delete删除数组中的某一项时,这一项被赋值undefined,但长度没有变化。
arr.push <=> arr[arr.length] = xxx;每次在数组末尾添加一个元素。
unshift(0):头部添加元素
arr.length -= 1 <=> arr.pop(); 删除尾部的元素
shift();头部删除一个元素

迭代

for循环,for in 不保证顺序

数组中的方法

[] => Array.prototype,数组及与数组原型链上的方法。
join: 将数组转换成字符串

var arr = [1,2,3];
arr.join();
//arr "1,2,3"
arr.join('_');
//arr "1_2_3"
//实现一个字符串的重复输出函数
function repeatString(str, n) {
    return new Array(n+1).join(str);
    //join会根据数组中的个数拼接字符串,创建n+1大小的数组,以传进来的参数作为拼接的单个字符拼接
}
repeatString("a",3);
//aaa

revsese:顺序的逆秩,原数组也会发生变化
sort对数组排序
默认是按照字母顺序排序,原来的数组也会被修改。要传入一个比较函数。

arr.sort(function(a,b) {
    return a - b;
})

concat()合并数组
并未修改原来的数组。
slice() 返回数组的一个片段

var arr = [1,2,3,4,5];
arr.slice(1,3);//从第一个到第三个
arr.slice(1);//[2,3,4,5]
arr.slice(1,-1);//[2,3,4]负数表示从末尾开始

splice()数组的拼接
对原数组进行修改

//删除
var arr = [1,2,3,4,5];
arr.splice(2);//return [3,4,5]
arr;//1,2

arr = [1,2,3,4,5];
arr.splice(2,2);//return [3,4]
arr;//[1,2,5]

//删除添加
arr = [1,2,3,4,5];
arr.splice(1,1,'a','b');//return [2]删除的元素,第二个元素删除,删除一个元素,在删除的位置添加元素
arr;//[1,'a','b',3,4,5]

forEach对数组的遍历

var arr = [1,2,3,4,5];
arr.forEach(function(x, index, a) {
    console.log(x + '|' +index + '|' + (a === arr));
});
//1 | 0 | true
//x:数组元素,index索引,a数组本身
//Ie9以上

map()对函数进行映射

var arr = [1,2,3];
arr.map(function(x) {
   return x+10;
});//[11,12,13]
arr;//[1,2,3]
//原数组并未改变

filter对数组进行过滤筛选

var arr = [1,2,3,4,5,6,7,8,9,10];
arr.filter(function(x,index) {
    return index % 3 === 0 || x > 8;
});// return [1,4,7,8,9,10]
arr;//未改变

every&some 数组的判断

//每一项都要满足
var arr = [1,2,3,4,5];
arr.every(function(x) {
    return x < 10;
})//true 


//只有一项即可
arr.some(function(x) {
    return x === 3;
});
// true 

indexOf()&lastIndexOf()查找

var arr = [1,2,3,2,1];
arr.indexOf(2);//1
arr.indexOf(99);//-1
arr.indexOf(1,1);//4,返回第二个1的索引
arr.indexOf(1,-3);//从-3的位置开始查找1

//从右往左查找
arr.lastIndexOf(2);//3 
arr.lastIndexOf(2,-2);//3
arr.lastIndexOf(2,-3);// 1

一个对象是否是数组

Array.isArray([]);//true
[] instanceof Array;//true
({}).toString.apply([]) === '[object Array]';
[].constructor === Array;//true

猜你喜欢

转载自www.cnblogs.com/intelwisd/p/9127164.html