javaScript高级程序设计笔记(一)

最近开始倒回去看js红宝书啦。这篇是1-5章的一些笔记。对于我这种之前只看了w3school和自己摸索了一下函数的人来说还有细节需要补全~

1.当变量赋值为null时,typeof返回为object,如果变量未赋值,返回undefined
2.对浮点数进行算数运算的时候会产生精度不准。如0.1+0.2=0.300...00004这样会导致0.1+0.2==0.3判别式失效。(但0.15+0.25不会出现此问题)。故避免使用0.1+0.2==0.3这样的判别式
3.NaN与任何值都不相等,包括NaN自身。对应函数isNaN(),当处理对象为NaN和不能转化为数值的参数(如字符串)时,返回true
4.非字符转换为数值:
①Number():将内容非数字的字符串转化为NaN,null返回0,undefined返回NaN,空时返回0
②parseInt():在Number的基础上,面对数字开头的字符串例如'123abc',转化为“123”,否则为NaN。面对“22.5”时转为22(小数点被作为不可识别的内容)。且可以为parseInt()指定第二个参数,即转换时使用的进制
③parseFloat():在②的基础上。当面对“22.5.6”时转为22.5(第二个小数点后被视为不可识别),且只能转化十进制。因而始终忽略先导的0.
5.除了null和undefined,其他的数据类型都有.toString()方法。方法内可以设定参数来指定转换时使用的进制。当不知道数据类型是不是null或者undefined时,可以使用.String()方法。转换后得到"null"与“undefined”
6.对于&&:

javaScript高级程序设计笔记(一)_第1张图片

对于||
javaScript高级程序设计笔记(一)_第2张图片

7. =====的区别在于,前者会将等号两边的内容进行转化再比较,如‘55’==55为true,后者不经过转化直接比较,则为false;类似的还有null==undefined为true,但是===则为false
8.使用for in函数时,循环的顺序是不一定的,而且当遍历的内容为null或者undefined时会自动结束循环。
9.break和continue都会导致从循环中立即跳出。但是break会结束循环。continue只是跳出此次循环,继续下一次循环
10.一种switch的用法,给switch传递表达式true,因为每个case都会返回一个布尔值。这样每个case都会执行,知道找到匹配的值或者遇到default为止

javaScript高级程序设计笔记(一)_第3张图片

11.定义函数的时候关于传递参数的问题,定义时可以不写参数,通过arguements数组调用。arguements数组还具有一个length属性用来判断输入的参数个数
如定义:
function a(){
alert('aaa'+arguements[0]+arguements[1]);
}
调用时可以用 a(1,2);使用
12.对于基本类型值的复制,一个变量的改变不会影响复制后的变量的值。但是对于引用类型值的复制来说,一个对象的改变对复制后的对象造成改变。因为他们两个变量引用的是同一个对象。
13.instanceof用于表示变量是个什么类型的对象,用法如
xxx instanceof Array,当xxx为Array类型时返回true。但是instanceof对于基本类型值的检测无效,会返回false,因为他们不是对象
14.由于一般的sort函数的比较结果会因为字符比较而得不到我们想要的结果。当我们需要获得排序结果时可以这样使用:
function compare(value1,value2){
return value1-value2;
}
array.sort(compare);
15.concat()函数:复制当前数组并添加内容,生成新数组。slice()函数:slice(1)表示从位置1开始复制,slice(1,4)表示从位置1开始复制,到3结束。16.splice()函数:可以往数组的中部插入项。
splice(0,2):分别代表起始位置和删除的项数;
splice(2,0,‘yellow’,‘red’):分别代表起始位置、要删除的项数、要插入的项。
splice方法会返回一个数组,是从原始数组里删除的项。
17.indexOf()方法从头部返回项的位置,lastIndexOf()从尾部开始查找,找不到都返回-1。查找过程会使用===操作符。方法内包含两个参数,一个是查找的内容,一个是从哪个位置查找(可选)
18.迭代方法有5种,每种方法接受两个参数:要在每一项上运行的函数和(可选的)运行该函数的作用域对象——影响this的值。传入这些方法的函数会接受三个参数:数据项的值,在数组中的位置和这个数组对象本身:function(item,index,array){}

javaScript高级程序设计笔记(一)_第4张图片

19.reduce方法和reduceRight方法都是遍历数组,一个从头一个从尾。reduce(function(prev,cur,Index,array){ }),四个参数分别代表了前一项,现在项,索引值和数组对象。
20.个人理解apply()与call():修改函数的外部环境,设置函数体内this对象的值。call与apply的区别在于传入的参数数目不同。call必须将参数一个个列出来。当你传的是数组是用apply比较好
21.如果使用var num=false,这构建的是一个基本数据类型。如果使用的var num = new Boolean(false),这构建的是一个对象,当判断if(num)时会返回true,因为任何对象转换为布尔型都是true
22.toFixed(*)根据传入的数字对数字进行处理返回指定的小数点后位数

你可能感兴趣的:(javaScript高级程序设计笔记(一))