1.比较运算符in

in运算符希望它的左侧操作数是一个字符串或可以转换为字符串,希望它的右操作数是一个对象,

如果右侧的对象拥有一个名为左侧操作数值的属性名,那么表达式返回true,

eg:var arr = {x:1,y:2};

    "x" in arr  ==>true

    "toString" in arr ==>对象继承了toString()方法

  var data = [1,2,3];

    "0" in data ===>true

    3 in data ===>false 数组的下标是以0开始的,下标只到2

2.比较运算符instanceof

instanceof运算符希望左侧操作数是一个对象,右操作数标识对象的类

如果左侧的对象是右侧类的实例则返回true,js中对象的类是通过初始化他们的构造函数来定义的

  var a = [];

  function f(){};

  var o = new f();

  o.constructor == f; o.__proto__.constructor == f; //true

  f instanceof Function;//true

  f instanceof Object;//true

  a instanceof Array;//true

3.typeof运算符

  typeof是一元运算符,放在其单个操作数前面,操作数可以是任意类型,返回值为表示操作数类型的一个字符串,

  任意值在typeof运算后的返回值

x typeof x||typeof(x)
undefined "undefined"
null "object"
true或false "boolean"
任意数字或NaN "number"
任意字符串 "string"
任意函数 "function"
任意内置对象(非函数) "object"
任意宿主对象 "由编译器各自实现的字符串"

4.逻辑表达式

  4.1 && 表达式

    1.当操作数都是布尔值的时候,"&&"对两个值执行布尔与(and)操作,只有在第一个操作和第二个操作都是true的时候,它才返回true

    2."&&"可以对假值(false、null、undefined、0、-0、NaN、"")和真值(除假值外的都是真值)进行布尔与(and)操作,

     先会对"&&"的左侧进行操作,如果左侧是假值,整个表达式肯定也是假值,因此这个表达式就简单的返回左侧的这个值,不会对右侧计算,

       反之如果左侧是真值,则整个表达式的计算结果依赖于右侧,右侧是真值这个结果就是真值,否则就是假值,并返回右侧的值作为整个表达式的结果

    "&&"的这种特性称为"短路",也经常利用这种特性来有条件的执行代码

    eg: if(a==b) start();

      (a==b) start();//同上

    一般当"&&"的右侧有副作用是要小心如(赋值、递增、递减等),因为这些操作的执行与否都依赖与"&&"的左侧   false&&a++(a++就不会执行)

  4.2 ||表达式

    "||"对两个操作做 布尔或(or)运算,只要有一个操作时真值,则返回真值,当且仅当所有操作都是假值是才会返回假值;

    先会对"||"的左侧进行操作,如果左侧是真值,整个表达式肯定也是真值,因此这个表达式就简单的返回左侧的这个值,不会对右侧计算,

       反之如果左侧是假值,则整个表达式的计算结果依赖于右侧,右侧是真值这个结果就是真值,否则就是假值,并返回右侧的值作为整个表达式的结果

比较运算符in/instanceof/typeof 逻辑表达式||/&&的更多相关文章

  1. javascript特殊运算符(in,instanceof,typeof,delete,void,逗号)

    in运算符                 in运算符要求其左边的运算数是一个字符串,或可以被转换为字符串,右边的运算数十一个对象或数组.如果该 运算符左边的值是右边对象的一个属性名,则返回true, ...

  2. 关系运算符:instanceof

    关系运算符:instanceof a instanceof Animal;(这个式子的结果是一个布尔表达式) a为对象变量,Animal是类名. 上面语句是判定a是否可以贴Animal标签.如果可以贴 ...

  3. JavaScript中“typeof”运算符与“instanceof”运算符的差异

    在JavaScript中,运算符“typeof”和“instanceof”都可以用来判断数据的类型,那么这两个运算符有什么不同之处呢? 差异一:使用方式不同. 最明显的差异就是这两个运算符的使用方式了 ...

  4. instanceof typeof

    //清单 6. JavaScript instanceof 运算符代码 function instance_of(L, R) {//L 表示左表达式,R 表示右表达式 var O = R.protot ...

  5. javascript instanceof,typeof的区别

    区分string 与 String的区别 为什么结果会是false呢? <script type="text/javascript"> var aColors = [& ...

  6. instanceof, typeof, & Object.prototype.toString

    /** * * @authors Your Name (you@example.org) * @date 2016-11-18 09:31:23 * @version $Id$ */instanceo ...

  7. js的in运算符与instanceof运算符

    in运算符:希望他的左操作数是一个字符串或可以转换为字符串,希望他的右操作数是一个对象.如果右操作数的对象拥有一个名为左操作数值的属性名,那么表达式返回true. var point= {x:1,y: ...

  8. JavaScript中instanceof与typeof运算符的用法及区别详细解析

    JavaScript中的instanceof和typeof常被用来判断一个变量是什么类型的(实例),但它们的使用还是有区别的: typeof 运算符 返回一个用来表示表达式的数据类型的字符串. typ ...

  9. typeof和instanceof

    JavaScript 中 typeof 和 instanceof 常用来判断一个变量是否为空,或者是什么类型的.但它们之间还是有区别的: typeof typeof 是一个一元运算,放在一个运算数之前 ...

随机推荐

  1. sql duplicate key

    本文来自:高爽,转载请注明. 向数据库插入记录时,有时会有这种需求,当符合某种条件的数据存在时,去修改它,不存在时,则新增,也就是saveOrUpdate操作.这种控制可以放在业务层,也可以放在数据库 ...

  2. hoj 2543 (费用流 拆边)

    http://acm.hit.edu.cn/hoj/problem/view?id=2543 1.将原图中的每条边(u, v)拆成两条:(u, v, Ci, 0), (u, v, ∞, Ei) 2.购 ...

  3. poj1742

    Coins Time Limit: 3000MS   Memory Limit: 30000K Total Submissions: 33998   Accepted: 11554 Descripti ...

  4. 《从零开始学Swift》学习笔记(Day 38)——构造函数与存储属性初始化

    原创文章,欢迎转载.转载请注明:关东升的博客 构造函数的主要作用是初始化实例,其中包括:初始化存储属性和其它的初始化.在Rectangle类或结构体中,如果在构造函数中初始化存储属性width和hei ...

  5. UESTC 485 Game(康托,BFS)

    Today I want to introduce an interesting game to you. Like eight puzzle, it is a square board with 9 ...

  6. 巨蟒python全栈开发django11:ajax&&form表单上传文件contentType

    回顾: 什么是异步? 可以开出一个线程,我发出请求,不用等待返回,可以做其他事情. 什么是同步? 同步就是,我发送出了一个请求,需要等待返回给我信息,我才可以操作其他事情. 局部刷新是什么? 通过jq ...

  7. discuz X3 门户定制

    为了实现门户的定制,在本机全新的安装了discuzX3,现在只想使用其门户功能(即文章CMS管理).但是论坛功能是不能关闭的可能论坛是discuz的核心功能吧. 全新安装的discuzx3,主导航上只 ...

  8. JVM 的 Xms 和 Xmx 设置一样大小的内存容量

    4. [推荐]在线上生产环境,JVM 的 Xms 和 Xmx 设置一样大小的内存容量,避免在 GC 后调整堆 大小带来的压力. 现在,我们知道了Elasticsearch所公开的缓存和缓冲区,可以尝试 ...

  9. xenserver 模板导出导入

    由于业务需求,新增一台xenserver,需要将原先创建好的模板环境导入到新的母机上面,此处记录一下 1.导出模板 # 获取需要导出的模板uuid [root@localhost ~]# xe tem ...

  10. (1)虚拟机的安装与使用,linux系统安装

    一.百度下载 VMware workStation 二.新建虚拟机 在这里分为典型和自定义,典型及许多磁盘类型及接口类型为默认,自定义高级则可以都做选择设置. 三.自定义(高级)安装 (1)点击下一步 ...