弱类型的隐式转换:

32 + 32  // 64
“32” + 32 // “3232”
“32” – 32 // 0



#### 巧用+/-规则转换类型:
```
num – 0 // 把变量转换成数字
num + '' // 把变量转换成字符串型
```


#### ==:
```
"1.23" == 1.23 // true;
0 == false // true
null == undefined // true;
new Object() == new Object() // false;
[1,2] == [1,2] // false
```


#### ===:
1.先比较类型,类型不同,返回false
2.再比较值
```
null === null // true
undefined === undefined // true
NaN ≠ NaN // == === 均不等

</br>
#### 类型检测

typeof function // "function"

typeof undefined // "undefined"

typeof new Object // "object"

typeof [1,2] // "object"

typeof NaN // "number"

typeof null // "object" 约定俗成


instanceof 主要判断Object类型
判断左操作数的原型链上 <br/>
<br/> ###三、语句
####1 block语句、var语句
1. 函数有作用域,但是for,if之类的循环是没有块级作用域的
2. `var a = b = 1 // b在这里相当于创建了一个全局变量`
&nbsp;正确的写法:`var a = 1, b = 1;`

function foo() {

var a = b = 1;

}

foo();

console.log(typeof a); // 'undefined';

console.log(typeof b); // 'number';

</br>

####2 函数、switch、循环
1.函数声明会被前置、函数表达式不会
例如:

f1(); // true

function f1() {

// do sth

return true;

}

f2(); // TypeError

var f2 = function() {

// do sth

};


2.for..in循环:
&nbsp;1、顺序不确定
&nbsp;2、enumerable为false时不会出现
&nbsp;3、for in会受原型链的影响(原型链上属性的enumerable为true的话,是会被显示出来的) 3.with语句会修改作用域
&nbsp;缺点:让Js引擎优化更难;可读性差;可被变量定义代替;严格模式下会被禁用
</br> ####3 严格模式
严格模式是一种特殊的运行模式,它修复了部分语言撒谎那个的不足,提供更强的错误检查,并增强安全性。
>1. 不允许是用with语句
>2. 不允许未声明的变量被赋值
>3. arguments变为参数的静态副本
>4. delete参数、函数名会报错
>5. delete不可配置的属性会报错
>6. 对象字面量重复属性名报错
>7. 禁止八进制字面量
>8. eval,arguments变为关键字,不能作为变量、函数名
>9. eval会独立作用域
>10. 一般函数调用this(不是对象的方法调用,也不使用apply/call/bind等修改this)指向null,而不是全局对象。若使用apply/call,当传入null或undefined时,this指向null或undefined,而不是全局对象。
>11. arguments.caller,arguments.callee被禁用
</br>

深入浅出javascript学习笔记的更多相关文章

  1. Java程序猿的JavaScript学习笔记(汇总文件夹)

    最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...

  2. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  3. Java程序猿JavaScript学习笔记(2——复制和继承财产)

    计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...

  4. Java程序猿的JavaScript学习笔记(3——this/call/apply)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  5. Java程序猿JavaScript学习笔记(4——关闭/getter/setter)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  6. Java程序猿JavaScript学习笔记(14——扩大jQuery UI)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  7. javascript学习笔记(四) Number 数字类型

    数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数  toExponential() 方法 用科学 ...

  8. JavaScript学习笔记之数组(二)

    JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...

  9. JavaScript学习笔记[0]

    JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...

随机推荐

  1. Objective-C的面向对象特性(一)

    Objective-C在c语言的基础上增加了面向对象特性,都有哪些面向对象特性呢? 其中第一个最重要的特性是类和对象的实现. Objective-C软件由许多对象构成,形成一个对象网络,对象之间通过发 ...

  2. obj-c编程12:复制对象

    好吧,上一篇我怎么也没想到会写那么多字那么少的代码,希望这一篇不会如此哦. 言归正传,对象的复制分为浅复制和深复制,前者只是复制对象的引用,当原对象的内容发生变化时,复制对象的内容也会发生变化,毕竟他 ...

  3. MOOS学习笔记3——命令行

    MOOS学习笔记3--命令行 例程 /** * @code A simple example showing how to use a comms client问问怎么样 */ #include &q ...

  4. AngularJs 学习笔记(一)作用域

    AngularJs采用了注重时效的MVC方式,是基于MVW模式. 1.$scope和作用域的概念. AngularJs中的$scope对象是模板的域模型,也称作作用域实例,通过为其属性赋值,可以传递给 ...

  5. 【读书笔记】C++Primer---第一章

    1.标准库的头文件用尖括号<>括起来,非标准库的头文件用双引号“”括起来:

  6. JSPWiki安装配置及FCKEditor的集成

    版本:JSPWiki-2.8.2 FCKeditor_2.6.3     安装方法我参照:http://doc.jspwiki.org/2.4/wiki/InstallingJSPWiki FCKEd ...

  7. pymongo "ServerSelectionTimeoutError: No servers found yet" 错误的解决

    系统转移过程中,擅自把aptitude安装的mongoengine换成了pip安装,系统启动以后,报这个错误 报错提示: File "/usr/local/lib/python2.7/dis ...

  8. ssh运行环境搭建及测试

    一.运行环境 1.Spring环境 Spring是一站式开发框架,在SSH中主要有以下作用,就像一个大管家: 控制反转(Inversion of Control):类不再自己进行类创建,而是交给Spr ...

  9. 手把手教你全家桶之React(二)

    前言 上一篇已经讲了一些react的基本配置,本遍接着讲热更新以及react+redux的配置与使用. 热更新 我们在实际开发时,都有用到热更新,在修改代码后,不用每次都重启服务,而是自动更新.并而不 ...

  10. leetCode刷题(找到最长的连续不重复的字符串长度)

    Given a string, find the length of the longest substring without repeating characters. Examples: Giv ...