indexOf、instanceOf、typeOf、valueOf详解

1、indexOf()

该方法用来返回某个指定的字符串值在字符串中首次出现的位置。

语法:indexOf(searchvalue,fromindex);两个参数,参数一表示查询的字符串值,参数二可选表示开始查询的起始位置,若不写默认从首字符开始查询

1 var string = "abcdeADhu390u09";
2 console.log(string.indexOf("d"));//3  注意下标值从0开始
3 console.log(string.indexOf("D"));//6 

上面代码都只有一个参数分别打印出"d"、"D"字符串值首次出现的位置,发现输出的值不同,说明indexOf()方法对大小写有区分。

下面这段代码传入两个参数,根据前面说的参数二表示查询的起始位置,所以从第五位开始查询"d"首次出现的位置,查询不到返回-1

console.log(string.indexOf("d",4));//-1

indexOf()方法还常用来判断浏览器的类型,其用法如下:

1 if(navigator.userAgent.indexOf("Firefox")>0){
2     return "Firefox";
3 }else if(navigator.userAgent.indexOf("Chrome")>0){
4     return "Chrome";
5 }else if(navigator.userAgent.indexOf("Opera")>0){
6     return "Opera";
7 }
以navigator.userAgent.indexOf("Opera")查询来讲,若打开的浏览器是欧朋则返回一个大于0的值,否则返回-12、instanceOf该运算符用来检测对象的类型语法:object instanceof constructor   参数object表示要检测的对象,参数constructor表示某个构造函数
function Person(){}
var Dave = new Person();//Object.prototypeOf(Dave)===Person.prototype
console.log(Dave instanceof Person);//true

可以这样理解:instanceof检测constructor.prototype是否存在于参数object原型链上。若存在返回true上面说的是较常规的用法,现在来看看在继承中的用法
1 function Person(){};
2 function Student(){};
3 Student.prototype = new Person();//js中的原型继承
4 var Dave = new Student();
5 console.log(Dave instanceof Student);//true
6 console.log(Dave instanceof Person);//true

上面一段代码判断Dave是否是Student的实例,并且是否是其父类型的实例

3、typeof

该运算符用来检测基本数据类型

1 console.log(typeof("Json"));//string
2 console.log(typeof(2));//number
3 console.log(typeof(true));//boolean
4 console.log(typeof({a:1}));//object
5 console.log(typeof(function(){}));//function6 console.log(typeof(undefined));//undefined

在ES6之前typeof返回值就是上面列出的六种:string、number、bollean、object、function、undefined;ES6出来后又增加了一种symbol

console.log(typeof(Symbol()));//symbol

4、valueOf()

该方法返回Boolean对象的原始值

语法:booleanObject.valueOf()

1 var boo = new Boolean(true);
2 console.log(boo.valueOf());

补充下与本章不相关的小知识点:

这里穿插一点"=="与"==="的小知识点

1 var a = undefined;
2 var b = null;
3 console.log(a==b);//true
4 console.log(a===b);//false

null与undefined在"=="情况下返回true,因为他们是类似的值,在"==="情况下返回false,因为他们不是相同类型的值。

特殊的还有

1 console.log(NaN==NaN);//false
2 console.log(3==NaN);//false

若有一个操作符是NaN,在"=="情况下返回false,即使两个操作数都是NaN,在"=="情况下也返回false

1 console.log(false==0);//true
2 console.log(true==1);//true
3 console.log(true==2);//false

在操作符为"=="时,true与1返回true

1 console.log(null==0);//false
2 console.log(undefined==0);//false
 
时间: 2025-01-12 03:43:34

indexOf、instanceOf、typeOf、valueOf详解的相关文章

原生JS:delete、in、typeof、instanceof、void详解

delete.in.typeof.instanceof.void详解 本文参考MDN做的详细整理,方便大家参考[MDN](https://developer.mozilla.org/zh-CN/docs/Web/JavaScript) delete delete 运算符用来删除对象的自有属性. 语法:delete expression expression 的计算结果应该是一个对象的属性引用,如果不是一个对象的属性引用,那么,delete不会起任何作用,直接返回true. 在严格模式中,如果属性

详解js中typeof、instanceof与constructor

详解js中typeof.instanceof与constructor typeof返回一个表达式的数据类型的字符串,返回结果为js基本的数据类型,包括number,boolean,string,object,undefined,function.语法为typeof(data) 或 typeof data instanceof则为判断一个对象是否为某一数据类型,或一个变量是否为一个对象的实例;返回boolean类型 语法为 o instanceof A 以下为综合实例: 1<script type

原生JS:String对象详解

@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css); String对象 本文参考MDN做的详细整理,方便大家参考[MDN](https://developer.mozilla.org/zh-CN/docs/Web/JavaScript) JavaScript中的 String 类型用于表示文本型的数据. 它是由无符号整数

JavaScript经典面试题详解

以下是我遇到的一些经典的JS面试题,结合我自己的理解写的详解,主要参考高程一书,欢迎大家批评指正 1. var a; console.log(a); 答:运行结果为打印undefined. 首先,以上代码完全运行的话需要引擎,编译器,作用域的配合操作,(引擎负责整个JavaScript程序的编译及执行过程,编译器负责词法分析及代码生成等,作用域负责收集并维护由所有声明的标识符(变量)组成的一系列查询,并实施一套非常严格的规则,确定当前执行的代码对这些标识符的访问权限.)首先遇到var a,编译器

【Android】RecyclerView详解(一)

1.介绍 RecyclerView是比 ListView 更高级且更具灵活性的组件. 此组件是一个用于显示庞大数据集的容器,可通过保持有限数量的视图进行非常有效的滚动操作. 如果您有数据集合,其中的元素将因用户操作或网络事件而发生改变,请使用 RecyclerView 小组件. RecyclerView使用起来很方便因为它: 提供了一种插拔式的体验,高度的解耦,异常的灵活使用; 显示的样式更丰富包括水平,竖直,Grid,瀑布显示方式; 可以通过ItemDecoration自定义Item间的间隔;

1-json详解

简介 该风格指南是对在Google创建JSON APIs而提供的指导性准则和建议.总体来讲,JSON APIs应遵循JSON.org上的规范.这份风格指南澄清和标准化了特定情况,从而使Google的JSON APIs有一种标准的外观和感觉.这些指南适用于基于RPC和基于REST风格的API的JSON请求和响应. 定义 为了更好地实现这份风格指南的目的,下面几项需要说明: 属性(property) - JSON对象内的键值对(name/value pair) 属性名(property name)

测试框架mochajs详解

测试框架mochajs详解 章节目录 关于单元测试的想法 mocha单元测试框架简介 安装mocha 一个简单的例子 mocha支持的断言模块 同步代码测试 异步代码测试 promise代码测试 不建议使用箭头函数 钩子函数 钩子函数的描述参数 异步的钩子函数 全局钩子 延迟启动测试 测试用例TODO 仅执行一个用例集/用例 跳过哪些用例集/用例 重新执行用例 动态生成用例 测试时间 测试超时 用例集执行超时 用例执行超时 钩子函数超时 diff差异比较功能 mocha使用命令和参数 mocha

JS表格组件神器bootstrap table详解(基础版)

这篇文章主要介绍了JS表格组件神器bootstrap table,bootstrap table界面采用扁平化的风格,用户体验比较好,更好兼容各种客户端,需要了解更多bootstrap table的朋友可以参考下 一.Bootstrap Table的引入 关于Bootstrap Table的引入,一般来说还是两种方法: 1.直接下载源码,添加到项目里面来.由于Bootstrap Table是Bootstrap的一个组件,所以它是依赖Bootstrap的,我们首先需要添加Bootstrap的引用.

深入Java基础(四)--哈希表(1)HashMap应用及源码详解

继续深入Java基础系列.今天是研究下哈希表,毕竟我们很多应用层的查找存储框架都是哈希作为它的根数据结构进行封装的嘛. 本系列: (1)深入Java基础(一)--基本数据类型及其包装类 (2)深入Java基础(二)--字符串家族 (3)深入Java基础(三)–集合(1)集合父类以及父接口源码及理解 (4)深入Java基础(三)–集合(2)ArrayList和其继承树源码解析以及其注意事项 文章结构:(1)哈希概述及HashMap应用:(2)HashMap源码分析:(3)再次总结关键点 一.哈希概