一元运算符:

1.递增++递减--


var userAge = 25
console.log(
    // 25 - 保持原样
    userAge,
    // 26 - 在原来的基础上加1并返回
    ++userAge,
    // 25 - 在原来的基础上减1并返回
    --userAge,
    // 25 - 先返回再在原来的基础上减一
    userAge++,
    // 26 - 线返回再在原来的基础上减一
    userAge--
)


2.前置后置区别

说明: 在没有赋值操作,前置和后置一样,但在赋值操作时,前置会先加后返回,后置会先返回在加


3.其它类型效果


// String - 可以转换为数值,返回90
var testValue = '89'; testValue++;console.log(testValue)
// String - 无法转换为数值,返回NaN
var testValue = 'ff'; testValue++;console.log(testValue)
// Boolean - 可以返回为数值, 返回1
var testValue = false; testValue++;console.log(testValue)
// Number - 可以转换为数值, 返回3.15
var testValue = '3.14'; testValue++;console.log(testValue)
// Object - 支持转换为数值, 返回2
var testValue = {
    valueOf: function(){
        return 1
    }
}; testValue++;console.log(testValue)


正负运算符:


// String - 自动隐式转换为数值型,失败返回NaN
var testValue = '89';console.log(+testValue, -testValue)
var testValue = 'ff';console.log(+testValue, -testValue)
// Boolean - 可转换为数值1,返回1, -1
var testValue = true;console.log(+testValue, -testValue)
// Number - 可以转换为数值3.14,返回3.14, -3.14
var testValue = true;console.log(+testValue, -testValue)
// Object - 支持转换为数值,返回1314, -1314
var testValue = {
    toString: function(){
        return 1314
    }
};console.log(+testValue, -testValue)


算术运算符:

1.加法

说明: +在数值运算时表示加法,在字符串拼接时表示拼接,所以从左到右加字符串时会自动拼接字符串


// Number + Number 返回数值
var testValue = 1 + 2;console.log(testValue)
// 任意值 + NaN 返回NaN
var testValue = 1 + NaN; console.log(testValue)
//  Infinity + Infinity 返回Infinity
var testValue = Number.POSITIVE_INFINITY + Number.POSITIVE_INFINITY;console.log(testValue)
// - Infinity + -Infinity 返回 -Infinity
var testValue = Number.NEGATIVE_INFINITY + Number.NEGATIVE_INFINITY;console.log(testValue)
// Infinity + -Infinity 返回NaN
var testValue = Number.POSITIVE_INFINITY + Number.NEGATIVE_INFINITY;console.log(testValue)
// Number + Boolean 返回数值
var testValue = 100 + true;console.log(testValue)
// Number + String 返回字符串
var testValue = 100 + '100';console.log(testValue)
// Number + Number + String 先计算数值然后转为字符串
var testValue = 100 + 100 + '100';console.log(testValue)
// Number + 对象 返回依赖对象的valueOf()和toString()的方法
var testValue = 100 + {
    toString: function(){
        return 100
    }
};console.log(testValue)


2.减法

说明: -没有歧义,所以会自动转换两边操作数为数值然后再运算,运算原理同上


3.乘法

说明: -没有歧义,所以会自动转换两边操作数为数值然后再运算,运算原理同上


3.除法

说明: -没有歧义,所以会自动转换两边操作数为数值然后再运算,运算原理同上


4.取模

说明: -没有歧义,所以会自动转换两边操作数为数值然后再运算,运算原理同上


关系运算符:

说明: 用于比较的运算符作为关系运算符(< <= < >= == != === !==)运算符


var userName = {}
var userAge = {}
console.log(
    // 两个操作数都是数值,则数值比较,返回布尔值
    2 > 1,
    // 两个操作数都是字符串,则按照顺序字符串的ascii值比较,返回布尔值
    'limanman' > 'liuzhenzhen',
    // 其中有一个操作数是数值,而另一个操作数是非纯数字的字符串则会转换为NaN,所以与任何数值比较都为false
    '1314A' > 1314,
    // 其中有一个操作数是对象,则先调用valueOf()方法或toString()方法,再用结果比较
    '521' > {
        toString: function(){
            return 520
        },
    },
    // 在不需要转换的任何情况下,null和undefined是相等的,因为undefined继承自null
    null == undefined,
    // 其中一个操作数为NaN时,无论另一个操作数是什么都返回false
    NaN == NaN,
    // 在值相等的基础上类型也要相等判断可使用===
    null == undefined,
    /* 每个新建的对象引用的是不同的地址,可通过==来判断是否引用自同一个地址
     * 可使用var userAge = userName 保证他们引用的是同一个对象地址
     */
    userName == userAge
)


逻辑运算符:

说明: 逻辑运算符通常用于布尔值的操作,一般和关系运算符配合使用,有三个逻辑运算符(AND/OR/NOT),逻辑运算属于短路操作,返回值为最终判定值

1.逻辑运算两边的操作数如果是对象的话,则对象永久返回为真,所以与运算时返回另一个操作数,或运算时返回对象本身

2.逻辑运算两边的操作数如果有一个为NaN或null或undefined则返回NaN/null/undefined

3.逻辑非可以用于任何值,无论值是什么类型的,这运算都会返回一个布尔值,对于NaN/null/undefined返回都是true,逻辑非可以使用多次,多之前次的结果取反


// 逻辑运算符 - 对象横为真
var userInfo = {
    toString: function(){
        // 即使return null时逻辑运算也为true
        return null
    }
}
console.log(
    // 注意: 返回的是&&两边表达式的值不是布尔值,这里返回1314
    userInfo && 1314,
    // 注意: &&时,只判断false,即知道结果,所以直接返回false
    false && userInfo,
    // 注意: ||时,需要判断到userInfo才知道结果,所以返回userInfo
    false || userInfo,
    // 注意: 操作数中第一个为NaN或null或undefined,返回NaN/nall/undefined
    null && undefined,
    null && NaN,
    undefined && null,
    undefined && NaN,
    NaN && undefined,
    NaN && null,
    // 注意: 取反可以对任意数据类型取反,而且支持二次取反,!null, !NaN, !undefined返回true
    !null,
    !NaN,
    !undefined
)


位的运算符:

说明: 位运算比较基于底层,性能和速度都非常好,但是难度比较大,位运算包括非(~),位与(&),位或(|),位异或(^),左移(<<),右移(>>),无符号右移(>>>)

拔高: http://www.zhihu.com/question/38206659, 位运算的奇技淫巧


赋值运算符:


// 普通赋值
var testValue = 100
// 复合赋值
testValue += 100
testValue -= 100
testValue *= 100
testValue /= 100
testValue %= 100
testValue <<= 100
testValue >>= 100
testValue >>>=100


其它运算符:

1.字符串运算符,字符串运算符只有一个,'+',作用是将两个字符串相加,至少一个操作数为字符串

2.逗号运算符,可以在一条语句中执行多个操作

3.三元条件运算符,其实就是if语句的简写形式


// 字符串运算符
var testValue = 100 + '100'
console.log(testValue)
// 逗号运算符
var i = 10, j = 20
console.log(i, j)
// 三元运算符
var testValue = 2>1?"对":"错误"
console.log(testValue)