js比较运算符

JavaScript 一共提供了8个比较运算符。

  • > 大于运算符

  • < 小于运算符

  • <= 小于或等于运算符

  • >= 大于或等于运算符

  • == 相等运算符

  • === 严格相等运算符

  • != 不相等运算符

  • !== 严格不相等运算符
    这八个比较运算符分成两类:相等比较和非相等比较。
    非相等的比较,算法是先看两个运算子是否都是字符串,如果是的,就按照字典顺序比较(实际上是比较 Unicode 码点);否则,将两个运算子都转成数值,再比较数值的大小

    着重说下-非相等的运算符—非字符串的比较
    (1)string boolean number的比较的话,
    首先,将运算符俩边转换为数值,然后进行比较

     		需要注意一点,NaN与任何东西比较都为false哪怕是**他自己
     		undefined和null与自身严格相等。
     
     (2)Object 的话,会转为原始类型的值,再进行比较。’
     
     首先valueOf() 然后还是对象的时候,toString在进行对比
    

例如
string number boolean 与对象的对比

var x = [2];
x > '11' // true
// 等同于 [2].valueOf().toString() > '11'
// 即 '2' > '11'

x.valueOf = function () { return '1' };
x > '11' // false
// 等同于 [2].valueOf() > '11'
// 即 '1' > '11'
俩个对象的对比,同样适用
	[2] > [1] // true
// 等同于 [2].valueOf().toString() > [1].valueOf().toString()
// 即 '2' > '1'

[2] > [11] // true
// 等同于 [2].valueOf().toString() > [11].valueOf().toString()
// 即 '2' > '11'

{ x: 2 } >= { x: 1 } // true
// 等同于 { x: 2 }.valueOf().toString() >= { x: 1 }.valueOf().toString()
// 即 '[object Object]' >= '[object Object]'
  • === 运算符
    会先比较类型是否相同,然后对比值是否相同
    1===’1‘ false number 不等于 string类型
    1===[1] false number 不等于Object
    [1]===[1,2] 都是Object 类型,但是俩个数组使用地址的形式来存放,这俩个数组的在堆中的地址不一样,false

== 运算符
会首先将运算符俩边进行类型变换成同一类型然后对比值
string number boolean Object
自己跟自己比较不再说,
其余三个相互对比值都会先转换成数字进行对比,
true 是1 false是0 就可以很随意的对比了
跟Object对比,均需要valueOf().toString()

undefined和null只有与自身比较,或者互相比较时,才会返回true;
与其他类型的值比较时,结果都为false。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值