js 笔记

2019-08-05  本文已影响0人  nonooon

参考自:https://wangdoc.com/

1.switch语句后面的表达式,与case语句后面的表示式比较运行结果时,采用的是严格相等运算符(===),而不是相等运算符(==),这意味着比较时不会发生类型转换

2.JavaScript 语言允许,语句的前面有标签(label),相当于定位符,用于跳转到程序的任意位置,标签的格式如下。label:  语句

3.判断变量是否存在 // 正确的写法if(typeof v ==="undefined") {// ...}

4.如果 JavaScript 预期某个位置应该是布尔值,会将该位置上现有的值自动转为布尔值。转换规则是除了下面六个值被转为false,其他值都视为true。undefined null false 0 NaN   ""或''(空字符串)

5.ASCII 码转base64

btoa():任意值转为 Base64 编码

atob():Base64 编码转为原来的值

6.非 ASCII 码字符转为 Base64 编码,必须中间插入一个转码环节

```

functionb64Encode(str){returnbtoa(encodeURIComponent(str));}

functionb64Decode(str){returndecodeURIComponent(atob(str));}

```

7.遍历对象属性最好使用obj["p"]

8对于赋值操作 x=y;对于对象是引用指向统一对象,对于原始类型,是进行值拷贝。

9.引用对象obj的foo属性时,如果使用点运算符,foo就是字符串;如果使用方括号运算符,但是不使用引号,那么foo就是一个变量,指向字符串bar;数值键名不能使用点运算符(因为会被当成小数点),只能使用方括号运算符。;所以属性名最好符合标识符规定。

10.查看一个对象本身的所有属性,可以使用Object.keys方法。

11.delete命令只能删除对象本身的属性,无法删除继承的属性;toString是对象obj继承的属性,虽然delete命令返回true,但该属性并没有被删除,依然存在。这个例子还说明,即使delete返回true,该属性依然可能读取到值

12.in和hasOwnProperty。in运算符的一个问题是,它不能识别哪些属性是对象自身的,哪些属性是继承的;可以使用对象的hasOwnProperty方法判断一下,是否为对象自身的属性。

13.for...in循环用来遍历一个对象的全部属性。

for...in循环有两个使用注意点。

它遍历的是对象所有可遍历(enumerable)的属性,会跳过不可遍历的属性。

它不仅遍历对象自身的属性,还遍历继承的属性

所以使用for...in的时候,遍历对象自身的属性,应该结合使用hasOwnProperty方法

```

varperson = {name:'老张'};

for(varkeyinperson) {if(person.hasOwnProperty(key)) {console.log(key); }}

```

14.with语句,它的作用是操作同一个对象的多个属性时,提供一些书写的方便.但是建议不要使用with语句。

with(对象) { 语句;}

varobj = {p1:1,p2:2,};with(obj) { p1 =4; p2 =5;}

15.如果同一个函数被多次声明,后面的声明就会覆盖前面的声明

16.函数的name属性返回函数的名字。name属性的一个用处,就是获取参数函数的名字

```

functionf1(){}f1.name// "f1"

```

17.函数的toString方法返回一个字符串,内容是函数的源码

18.对于var命令来说,局部变量只能在函数内部声明,在其他区块中声明,一律都是全局变量。

19.与全局作用域一样,函数作用域内部也会产生“变量提升”现象。var命令声明的变量,不管在什么位置,变量声明都会被提升到函数体的头部。

```

functionfoo(x){if(x >100) {vartmp = x -100; }}// 

等同于

functionfoo(x){vartmp;if(x >100) { tmp = x -100; };}

```

20.函数执行时所在的作用域,是定义时的作用域,而不是调用时所在的作用域

21.函数参数不是必需的,JavaScript 允许省略参数。函数f定义了两个参数,但是运行时无论提供多少个参数(或者不提供参数),JavaScript 都不会报错。省略的参数的值就变为undefined。需要注意的是,函数的length属性与实际传入的参数个数无关,只反映函数预期传入的参数个数。而且没有办法只省略靠前的参数,而保留靠后的参数。如果一定要省略靠前的参数,只有显式传入undefined或者null

22.arguments。由于 JavaScript 允许函数有不定数目的参数,所以需要一种机制,可以在函数体内部读取所有参数。这就是arguments对象的由来。

虽然arguments很像数组,但它是一个对象。数组专有的方法(比如slice和forEach),不能在arguments对象上直接使用;

arguments对象带有一个callee属性,返回它所对应的原函数。

23.闭包的最大用处有两个:

一个是可以读取函数内部的变量;

另一个就是让这些变量始终保持在内存中,即闭包可以使得它诞生环境一直存在;

闭包的另一个用处,是封装对象的私有属性和私有方法;

上一篇下一篇

猜你喜欢

热点阅读