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.闭包的最大用处有两个:
一个是可以读取函数内部的变量;
另一个就是让这些变量始终保持在内存中,即闭包可以使得它诞生环境一直存在;
闭包的另一个用处,是封装对象的私有属性和私有方法;