js 笔记

参考自: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.闭包的最大用处有两个:

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

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

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容