笔记放在Github上,点击访问下载
1.基本类型包装器 2.Object与基本包装器的关联 3.String包装器
Math对象
Date对象
为了便于操作基本类型的值,ECMAScript提供了三种基本包装类型对象,分别是Number、String、Boolean。
每读取一个基本类型的值时,后台就会自动创建一个对应的基本包装类型对象,从而让这个基本类型值可以调用基本包装类型对象中的属性和方法来操作这些基本类型值。
var s = "briup"; s.substring(2);如上述代码片段,后台会自动完成以下操作 (1).创建String类型的一个实例----装箱 (2).在实例上调用指定方法 (3).销毁这个实例----拆箱
Object构造函数会根据传入值的类型(number/boolean/string)返回相应的包装器类型
var o = new Object(123); console.log(o);//[Number:123] console.log(o instanceof Number);//true console.log(o instanceof Object);//true使用new调用包装器类型的构造函数,与直接调用同名的转换类型函数或者直接给变量赋值不一样 使用new关键字创建出来的变量是对象,而后者则是普通的变量。
var n = new Number(123); console.log(n);//[Number: 123] Number的实例 console.log(typeof n);//object console.log(n instanceof Number);//true console.log(n instanceof Object);//true var m = 123; var m = Number('123'); console.log(m);//123 console.log(typeof m);//number console.log(m instanceof Number);//false console.log(m instanceof Object);//falseBoolean,Number不建议直接使用这两种包装器类型 举个例子,比如1.toString()这样在程序执行时是会报错的,因为程序默认把1后面的小数点看成了小数,而后面又碰到一个非数字的t,所以才报错。 解决办法:(1).toString()给1加个圆括号,相当于调用了Number()把1封装成了一个对象,这么写虽然解决问题,但是在日常开发中这么写太麻烦了,完全没有必要。
String的属性和方法
length属性 表示字符个数charAt(index) 获取index位置上的字符charCodeAt(index) 获取index位置上的字符的ASCII码值indexOf('x',index) 从前往后查找指定字符所在位置,可以有第二个参数,代表从字 符串中哪个位置开始查找。找到指定字符返回其索引,没有找到返回-1。lastIndexOf('x',index) 从后往前查找字符串所在位置,也有第二个参数。找到指定字符返回其索引,没有找到返回-1。 例: var str = 'abcdefg'; for(var i=0;i<str.length;i++){ console.log(str.charAt(i),'---',str.charCodeAt(i)); } console.log(str.indexOf('a',2)); console.log(str.lastIndexOf('a',3));结果为:
a --- 97 b --- 98 c --- 99 d --- 100 e --- 101 f --- 102 g --- 103 -1 0 trim() 去除前置和后置的空格,返回结果 var str = ' hel lo '; console.log(str.trim());//'hel lo'想要去除字符串中所有的空格可以使用split与join组合的方法 str.split(' ').join('') 首先使用split方法把字符串按照空格分割成数组,然后使用join将得到的数组按空字符串有序列化为字符串格式。
concat() 字符串拼接,返回拼接得到的新字符串,大多使用"+"拼接slice() 截取字符串 (开始位置,结束位置但不包括结束位置)substring() 截取字符串 (开始位置,结束位置但不包括结束位置)substr() 截取字符串 (开始位置,字符个数) //四种均不改变原字符串 var s = "helloworld"; console.log(s.concat(132));//helloworld132 console.log(s.slice(3,7)); //lowo console.log(s.substring(3,7));//lowo console.log(s.substr(3,7)); //loworld console.log(s);//helloworld toUpperCase() 转成全大写toLowerCase() 转成全小写 console.log('hello'.toUpperCase());//HELLO console.log('HELLO'.toLowerCase());//helloMath.ceil() 向上舍入 Math.floor() 向下舍入 相当于parseInt parseInt(num) Math.round() 四舍五入 Math.min() 求一组数中的最小值 Math.max() 求一组数中的最大值 Math.random()返回大于0小于1的一个随机数 包含0,但不包含1 生成一个0-9的随机整数 Math.floor(Math.random()*10 获取一个m-n的随机数:
function randomRange(Max,Min){ return Math.floor(Math.random()*(Max - Min + 1) + Min); }Date.prototype.getTime() 返回时间戳 将JS的date转变为时间戳,传递给后台:console.log((new Date()).getTime());