js 笔记

作者: nonooon | 来源:发表于2019-08-05 10:44 被阅读0次

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

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

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

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

    相关文章

      网友评论

          本文标题:js 笔记

          本文链接:https://www.haomeiwen.com/subject/lcjtdctx.html