JavaScript-比较运算符

时间:2022-02-07 02:03:17

一、概述

  • > 大于运算符
  • < 小于运算符
  • <= 小于或者等于运算符
  • >= 大于或者等于运算符
  • == 相等运算符
  • === 严格相等运算符
  • != 不相等运算符
  • !== 严格不相等运算符

二、非相等运算符:字符串的比较

先从第一个字符开始比较,比较依据(Unicode的大小)

"cat" > "dog";  // false

三、非相等运算符:非字符串的比较

如果两个运算子之中,至少有一个不是字符串,需要分成以下两种情况

  • 原始类型值:两个都是原始类型的值,则先转为数值再比较

    5 > '4' // true
    // 等同于 5 > Number('4')
    // 即 5 > 4 true > false // true
    // 等同于 Number(true) > Number(false)
    // 即 1 > 0 2 > true // true
    // 等同于 2 > Number(true)
    // 即 2 > 1
  • 对象:如果运算子是对象,会转为原始类型的值,再进行比较。

四、严格相等运算符

  • == :比较两个值是否相等
  • === : 比较两个值是否相等。通过是同一类型数据,就是True,如果不是返回false
NAN == NAN;   // false
[] === []; // false
{} === {}; // false
-----------------------
null === null; // true
undefined === undefined; // true

五、严格不相等运算符

它的算法就是先要求严格相等运算符的结果,然后返回相反值

1 !== "1";   // true

六、相等运算符

  1. 同类型的数据做比较的话,就不需要进行转换

  2. 原始类型值,转换为数值类型再进行比较

    1 == true // true
    // 等同于 1 === Number(true) 0 == false // true
    // 等同于 0 === Number(false) 2 == true // false
    // 等同于 2 === Number(true) 2 == false // false
    // 等同于 2 === Number(false) 'true' == true // false
    // 等同于 Number('true') === Number(true)
    // 等同于 NaN === 1 '' == 0 // true
    // 等同于 Number('') === 0
    // 等同于 0 === 0 '' == false // true
    // 等同于 Number('') === Number(false)
    // 等同于 0 === 0 '1' == true // true
    // 等同于 Number('1') === Number(true)
    // 等同于 1 === 1 '\n 123 \t' == 123 // true
    // 因为字符串转为数字时,省略前置和后置的空格
  3. 对象与原始类型值比较:将对象转换为原始类型值再比较

    // 对象与数值比较时,对象转为数值
    [1] == 1 // true
    // 等同于 Number([1]) == 1 // 对象与字符串比较时,对象转为字符串
    [1] == '1' // true
    // 等同于 String([1]) == '1'
    [1, 2] == '1,2' // true
    // 等同于 String([1, 2]) == '1,2' // 对象与布尔值比较时,两边都转为数值
    [1] == true // true
    // 等同于 Number([1]) == Number(true)
    [2] == true // false
    // 等同于 Number([2]) == Number(true)
  4. null,undefied

    null == undefied;  // true

七、不相等运算符

它的算法就是先求相等运算符的结果,再取相反值。

JavaScript-比较运算符的更多相关文章

  1. JavaScript instanceof 运算符深入剖析

    简介: 随着 web 的发展,越来越多的产品功能都放在前端进行实现,增强用户体验.而前端开发的主要语言则是 JavaScript.学好 JavaScript 对开发前端应用已经越来越重要.在开发复杂产 ...

  2. javascript算术运算符详解

    算术运算符 +.-.*./.%.++.-- ++.--分为前缀形式和后缀形式 前缀形式先加减1在执行 后缀形式先执行再加减1 注意 +号用来连接两个字符串 只要+连接的操作数中有一个是字符串型,JS就 ...

  3. JavaScript instanceof 运算符深入剖析【转载】

    http://www.ibm.com/developerworks/cn/web/1306_jiangjj_jsinstanceof/   instanceof 运算符简介 在 JavaScript ...

  4. JavaScript instanceof 运算符

    instanceof运算符简介 在 JavaScript 中 判断一个变量的类型常常会用 typeof 运算符 判断一个实例是否属于某种类型会使用instanceof 与 typeof 方法不同的是, ...

  5. (4)javascript的运算符以及运算符的优先级

                                    运算符的使用方法 在javascript的程序中要完成各种各样的运算,是离不开运算符的. 在javascript中,按运算符类型可以分为 ...

  6. javaScript常用运算符和操作符总结

    javaScript常用运算符和操作符总结 类别 操作符 算术操作符 +. –. *. /. %(取模) 字符串操作符 + 字符串连接   +=字符串连接复合 布尔操作符 !. &&. ...

  7. javascript&lpar;六&rpar;运算符

    运算符概述 JavaScript中的运算符用于算术表达式. 比较表达式. 逻辑表达式. 赋值表达式等.需要注意的是, 大多数运算符都是由标点符号表示的, 比如 "+" 和&quot ...

  8. JavaScript 算术运算符

    处理数值的典型情景是数值计算. ㈠JavaScript 算术运算符 算术运算符对数值(文字或变量)执行算术运算. ㈡算术运算符 典型的算术运算会操作两个数值. ⑴这两个数可以是字面量: var x = ...

  9. JavaScript多元运算符

    JavaScript多元运算符   JavaScript多元运算符 **实例:**` function test(9){ var a=4,b=11; return p > 1 ? p<b ...

  10. javascript中运算符的优先级

    运算符优先级 JavaScript中的运算符优先级是一套规则.该规则在计算表达式时控制运算符执行的顺序.具有较高优先级的运算符先于较低优先级的运算符执行.例如,乘法的执行先于加法. 下表按从最高到最低 ...

随机推荐

  1. Firefox默认英文修改中文

    对于firefox,中文还是看着顺眼,为了自己的顺心.动起手来,自力更生,丰衣足食! 01.确定Linux的firefox版本 firefox -v 02.下载对应版本的中文语言包 http://ft ...

  2. mysql小结

    1.使用密码登录mysql mysql -u root -p 2.查看所有的数据库 show databases; 3.创建数据库 create database <数据库名>; 4.创建 ...

  3. 单元测试中如何配置log4net

    按道理来说,单元测试中基本没有对于日志的需求,这是由于单元测试的定位来决定的. 因为单元测试的思想就是针对的都是小段代码的测试,逻辑明确,如果测试运行不通过,简单调试一下,就能很容易地排查问题.但是单 ...

  4. Python 前端之JS

    JavaScript由浏览器编译运行 JS的导入方式有两种,一种直接定义,第二种通过src引入:可以存放在<head>头部,但是强烈建议放在<body>的最下面,因为如果你引入 ...

  5. Wechat4j之Hello world——使用wechat4j快速开发java版微信公众号

    Wechat4j是一个开源的java微信开发框架,是目前最简单易用的java微信开发框架. 项目地址:https://github.com/sword-org/wechat4j Wechat4j.ja ...

  6. 微信公众平台开发&lpar;112&rpar; 自动更新微信access token

    关键字:Memcache access_token 更新 存储 7200 本文介绍如何存储及更新 access token的方法. 一.Access Token access_token是公众号的全局 ...

  7. GWT&plus;CodeTemplate&plus;TableCreate快速开发

    刚进一家新公司,公司表示让我们几个新人写页面联系熟悉 怎么快速开发,进入正题: 1.根据设计规范设计页面excel 2.CodeTemplate根据excel生成属性类和对应方法(文本框,下拉框等等单 ...

  8. python学习笔记14(多态、封装、继承)

    创建自已的对象(尤其是类型或者被称为类的对象)是python非常核心的概念. 多态: 可对不同类的对象使用同样的操作. 封装:对外部世界隐藏对象的工作细节. 继承:以普通的类为基础建立专门的类对象. ...

  9. 添加标签2 jquery 和JS

    TAG添加标签 做了个方法方便调用 一.JS版本 <!DOCTYPE html> <html lang="en"> <head> <met ...

  10. kuangbin专题一 简单搜索

    弱菜做了好久23333333........ 传送门: http://acm.hust.edu.cn/vjudge/contest/view.action?cid=105278#overview A ...