JavaScript中各种引用类型的常用操作方法小结

Object类型

Array类型

重排序方法: compare

升序:

rush:js;"> function compare(value1,value2){ if (value1value2){ return 1; } else{ return 0; } } var values = [0,1,5,10,15]; values.sort(compare); console.log(values); // [0,15]

降序:

rush:js;"> function compare(value1,value2){ if (value1value2){ return -1; } else{ return 0; } }

slice:

slice(start,end); slice()方法返回从参数指定位置开始到当前数组末尾的所有项。如果有两个参数,该方法返回起死和结束位置之间的项,但不包括结束位置的项。

rush:js;"> var colors = ["red","green","blue","yellow","purple"]; var colors2 = colors.slice(1); var colors3 = colors.slice(1,4);

console.log(colors2); // green,blue,yellow,purple
console.log(colors3); // green,yellow

splice:

splice()有删除,插入,替换的功能

删除

需要两个参数,要删除的第一项的位置和要删除的项数。

rush:js;"> var colors = ["red","blue"]; var removed = colors.splice(0,1); console.log(colors); // greeen,blue console.log(removed); // red

插入:

需要三个参数:起始位置、0(要删除的项数)和要插入的项

rush:js;"> var colors = ["red","blue"]; var removed = colors.splice(1,"orange"); console.log(colors); // ["red","orange","blue"] console.log(removed); // 返回空

替换:

需要三个参数:起始位置、要删除的项数和要插入的任意数量的项。

rush:js;"> var colors = ["red","blue"] console.log(removed); // ["green"]

Date类型 RegExp类型

rush:js;"> var pattern1 = /[bc]/i; var pattern2 = new RegExp("[bc]at","i");

pattern1和pattern2是两个完全等价的正则表达式。要注意的是,传递给RegExp构造函数的两个参数都是字符串(不能把正则表达式字面量传递给RegExp构造函数)。由于RegExp构造函数的模式参数是字符串,所以在某些情况下要对字符串进行双重转义。

rush:js;"> var pattern1 = /[bc]/i; var pattern2 = new RegExp("\\[bc\\]at","i");

RegExp实例方法 exec

exec接收一个参数,即要应用模式的字符串,然后返回包含第一个匹配信息的数组。

rush:js;"> var text = "cat,bat,sat,fat"; var pattern1 = /.at/;

var matches = pattern1.exec(text);
console.log(matches); // ["cat"]

match

match是字符串执行匹配正则表达式规则的方法,他的参数是正则表达

rush:js;"> var text = "cat,fat"; var pattern1 = /.at/;

var matches2 = text.match(pattern1);
console.log(matches2); // ["cat"]

test

test()接收一个字符串参数

rush:js;"> var text = "000-00-0000"; var pattern = /\d{3}-\d{2}-\d{4}/;

if (pattern.test(text)){
console.log("The pattern was matched"); // The pattern was matched
}

Function类型 函数内部属性

把arguments转为数组

rush:js;"> (function() { var slice = Array.prototype.slice,aArguments = slice.apply(arguments);
console.log(aArguments);

})(10,20,30);
arguments.callee

属性一个指针,指向拥有这个arguments对象的函数。当函数在严格模式下运行时,访问arguments.callee会导致错误

函数属性方法 length

length属性表示函数希望接收的命名参数的个数。

rush:js;"> function sayName(name){ alert(name); }

function sum(num1,num2){
return num1 + num2;
}

function sayHi(){
alert("hi");
}

console.log(sayName.length); //1
console.log(sum.length); //2
console.log(sayHi.length); //0

prototype

call,apply

rush:js;"> function sum(num1,num2){ return num1 + num2; }

function callSum1(num1,num2){
return sum.apply(this,arguments);
}

function callSum2(num1,[num1,num2]);
}

console.log(callSum1(10,10)); // 20
console.log(callSum2(10,10)); //20
window.color = "red";
var o = {color:"blue"};

function sayColor(){
console.log(this.color);
}

sayColor(); // red

sayColor.call(this); // red
sayColor.call(window); // red
sayColor.call(o); // blue

基本包装类型

rush:js;"> var value = "25"; var number = Number(value); console.log(typeof number); console.log(number instanceof Number);// false

var obj = new Number(value);
console.log(typeof obj);
console.log(obj instanceof Number);// true

Boolean类型

rush:js;"> var falSEObject = new Boolean(false); var result = falSEObject && true; // true

//布尔表达式中的所有对象都会被转换为true,因此falSEObject对象在布尔表达式中代表的是true

console.log(result); // true

var falseValue = false;
result = falseValue && true;
console.log(result); //false

console.log(typeof falSEObject); //object
console.log(typeof falseValue); // Boolean
console.log(falSEObject instanceof Boolean); //true
console.log(falseValue instanceof Boolean); // false

Number类型

rush:js;"> var numberObject = new Number(10); var numberValue = 10; console.log(typeof numberObject); // Object console.log(typoef numberValue); // number console.log(numberObject instanceof Number); // true console.log(numberValue instanceof Number); // false

String类型 字符方法 charat() charCodeAt()

charat()方法以单字符字符串的形式返回给定位置的那个字符串。

charCodeAt()返回的是字符编码。

rush:js;"> var stringValue = "hello world"; console.log(stringValue.charat(1)); // e console.log(stringValue.charCodeAt(1)); // 101

字符串操作方法 concat()

concat()用于将一或多个字符串拼接起来。

rush:js;"> var stringValue = "hello "; var result = stringValue.concat("world"); console.log(result); // hello world console.log(stringValue); // hello

slice(start,end)

end 表示字符串到哪里结束。 如果传入的是负数,slice()方法会将传入的负值与字符串长度相加。

rush:js;"> var str="Hello happy world!"; console.log(str.slice(6)); // happy world! console.log(str.slice(6,11));// happy console.log(str.slice(-3)); // ld! console.log(str.slice(3,-4)); //lo happy wo

substring(start,end)

如果传入的是负数,substring()会把所有字符参数都转换为0

rush:js;"> var str="Hello happy world!"; console.log(str.substring(6)); // happy world! console.log(str.substring(6,11));// happy console.log(str.substring(-3)); // Hello happy world! console.log(str.substring(3,-4)); //Hel

substr(start,length)

如果传入的是负数,substr()方法将负的第一个参数加上字符串的长度,而将负的第二个参数转换为0

rush:js;"> var str="Hello World!"; console.log(str.substr(3)); //lo world! console.log(str.substr(3,7)); //lo worl console.log(str.substr(-3)); // ld! console.log(str.substr(3,-3)); // 空字符串

字符串位置方法

rush:js;"> indexOf() lastIndexOf()

var stringValue = "hello world";
console.log(stringValue.indexOf("o")); // 4
console.log(stringValue.lastIndexOf("o")); //7

这两个方法都可以接收可选的第二个参数,表示从字符串中的哪个位置开始搜索

rush:js;"> var stringValue = "hello world"; console.log(stringValue.indexOf("o",6)); // 7 console.log(stringValue.lastIndexOf("o",6)); //4

字符串的模式匹配方法 match()

rush:js;"> var text = "cat,fat"; var pattern = /.at/;

var matches = text.match(pattern);
console.log(matches.index); //0
console.log(matches[0]); // cat
console.log(pattern.lastIndex); //0

search()

rush:js;"> var text = "cat,fat"; var pos = text.search(/at/); console.log(pos); // 1

replace()

rush:js;"> var text = "cat,fat"; var result = text.replace("at","ond"); console.log(result); // cond,fat

var result = text.replace(/at/g,bond,sond,fond

Global对象 URI编码方法

Global对象的encodeURI()和encodeURIComponent()方法可以对URI(Uniform Resources Identifiers,通用资源标识符)进行编码,以便发送给浏览器。

rush:js;"> var url = "http://www.baidu.com/"; console.log(encodeURI(url)); console.log(encodeURIComponent(url)); encodeURI()和encodeURIComponent()方法对象的两个方法分别是decodeURI()和decodeURIComponent()

Math对象 random()方法

Math.random()方法返回介于0和1之间一个随机数,不包含0和1。对于某些站点来说,这个方法非常实用,因为可以利用它来随机显示一些名言和新闻事件。套用下面的公式,就可以利用Math.random()从某个整数范围内随机选择一个值。

rush:plain;"> 值=Math.floor(Math.random()*可能值的总数+第一个可能的值)

例如:如果想选择一个1到10之间的数值,可以像下面这边编写代码

rush:js;"> var num = Math.floor(Math.random()*10+1); function selectFrom(lowerValue,upperValue){ var choice = upperValue - lowerValue + 1; return Math.floor(Math.random()*choice+lowerValue); } var num = selectFrom(2,10); console.log(num); var colors = ["red","black","purple","brown"]; var color = colors[selectFrom(0,colors.length-1)]; console.log(color);

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...