JS中关于in运算符的问题

转自:http://bbs.bccn.net/thread-412608-1-1.html

in运算符

in运算符虽然也是一个二元运算符,但是对运算符左右两个操作数的要求比较严格。in运算符要求第1个(左边的)操作数必须是字符串类型或可以转换为字符串类型的其他类型,而第2个(右边的)操作数必须是数组或对象。只有第1个操作数的值是第2个操作数的属性名,才会返回true,否则返回false。

简单通俗的in的使用规范代码:

<html>
<head>
  <title>in运算符</title>
  <script language="javascript" type="text/javascript">
   <!--
    //定义一个box对象
    var box = {box_length:200,box_width:100};
    //定义一个数组
    var arr = ["box_length",200,"200"];
    //定义变量
    var x = "box_length";
    var y = 2;
    if (x in box)
    {
     document.write("变量x包含在对象box之中<br>");
    }
    else
    {
     document.write("变量x不包含在对象box之中<br>");
    }
    if (y in box)
    {
     document.write("变量y包含在对象box之中<br>");
    }
    else
    {
     document.write("变量y不包含在对象box之中<br>");
    }
    if (x in arr)
    {
     document.write("变量x包含在数组arr之中<br>");
    }
    else
    {
     document.write("变量x不包含在数组arr之中<br>");
    }
    if (y in arr)
    {
     document.write("变量y包含在数组arr之中<br>");
    }
    else
    {
     document.write("变量y不包含在数组arr之中<br>");
    }
   -->
  </script>
</head>
<body>
</body>
</html>

运算结果:

变量x包含在对象box之中
变量y不包含在对象box之中
变量x不包含在数组arr之中
变量y包含在数组arr之中
时间: 2024-08-30 08:27:18

JS中关于in运算符的问题的相关文章

js中的instanceof运算符

js中的instanceof运算符 概述 instanceof运算符用来判断一个构造函数的prototype属性所指向的对象是否存在另外一个要检测对象的原型链上 语法 obj instanceof Object;//true 实例obj在不在Object构造函数中 描述 instanceof 运算符用来检测 constructor.prototype 是否存在于参数 object 的原型链上. 实例 1.instanceof的普通的用法,obj instanceof Object 检测Objec

JS中的加号+运算符详解

加号+运算符 在 JavaScript 中,加法的规则其实很简单,只有两种情况: 把数字和数字相加 把字符串和字符串相加 所有其他类型的值都会被自动转换成这两种类型的值. 为了能够弄明白这种隐式转换是如何进行的,我们首先需要搞懂一些基础知识. 让我们快速的复习一下. 在 JavaScript 中,一共有两种类型的值: 原始值(primitives) undefined null boolean number string 对象值(objects):除了原始值外,其他的所有值都是对象类型的值,包括

JS 中的布尔运算符 &amp;&amp; 和 ||

布尔运算符 && 和 ||的返回结果不一定是布尔值!由此来展开一定的研究及理解. 1.首先先介绍下常见的数据类型转化为bool后的值. (常用地方)在if表达式中,javascript先把条件表达式转换成bool值再进行判断 2.下面来介绍下逻辑与&& 逻辑非|| 的运算后的返回结果 逻辑与 && var i="真值" && "任意值" ;=> i结果为任意值 var i="假值&quo

js中的 || 与 &amp;&amp; 运算符 的使用

&&和||总是傻傻分不清,在这里详细记录一下吧.也给你们分享一下. 表达式a && 表达式b :  计算表达式(或者函数)a的运算结果, 如果为 True, 执行表达式b(或函数),并返回b的结果: 如果为 False,返回a的结果: 表达式a || 表达式b :    计算表达式(或者函数)a的运算结果, 如果为 Fasle, 执行表达式b(或函数),并返回b的结果: 如果为 True,返回a的结果: 简而言之, &&的计算为前面为true就返回后边,前面

js中的三元运算符? :

//快速设置表单底部默认的按钮:保存.取消 LG.setFormDefaultBtn = function (cancleCallback, savedCallback) { //表单底部按钮 var buttons = []; if (cancleCallback) { buttons.push({ text: '取消', onclick: cancleCallback }); } if (savedCallback) { buttons.push({ text: '保存', onclick:

关于JS中涉及的常用类型转换及运算符表达式

JS中的常用类型转换(一般用强制转换):1.强制转为整数:parseInt:写法:x = parseInt(x); 2.强制转换位小为:parseFloat:写法:x = parseFloat(x); 3.检测类型:x = parseInt(x);       alert(typeof(true)); JS中常用的运算符表达式:1.逻辑运算符(布尔型):&& 并 :|| 或 :! 非 : 2.比较运算符:==(等于) :!=(不等于) : > :< :>=(大于等于) :

从零开始的JS生活(二)——BOM、DOM与JS中的事件

上回书说道,JS中变量.运算符.分支结构.循环和嵌套循环等内容.本回就由本K给大伙唠唠JS中的BOM.DOM和事件. 一."花心大萝卜"--BOM 1.震惊,FFF团为何对BOM举起了火把--BOM简介 BOM(Browser Object Model) 是指浏览器对象模型,在JS中BOM是个不折不扣的花心大萝卜,因为它有很多个对象,其中代表浏览器窗口的Window对象是BOM的"正室".也就是最重要的,其他对象都是正室的下手.或者叫侧室也不足为过. 2.细数BOM

JS中的运算符&amp;JS中的分支结构

一.JS中的运算符 1.算术运算(单目运算符) + 加.- 减.* 乘./ 除.% 取余.++ 自增.-- 自减 >>> +:有两种作用,连接字符串/加法运算.当+两边全为数字时,进行加法运算: 当+两边有任意一边为字符串时,起连接字符串的作用,连接之后的结果为字符串 除+外,其余符号运算时,会先尝试将左右变量用Number函数转为数字 >>> /: 结果会保留小数点 >>> ++: 自增运算符,将变量在原有基础上+1: --: 自减运算符,将变量在原

js中的运算符和条件语句

js中的运算符大体上可以分为4类:1算术运算符.2一元操作符.3比较运算符.4逻辑运算符. 算术运算符一般指的是加减乘除求余这五种操作符:+,-,*,/,%.通过算术运算符可以对js中的变量进行操作.如: var a=100,b,c,d,e,f; b= a+10; //110 c=a-10; //90 d=a*10; //1000 e=a/10; //10 f=a%3; //1 一元操作符指的是只能操作一个值的操作符:如i++,i--,++i,--i;在这里要注意区别i++与++i: var a