JS中typeof和instanceof的用法小解

2024-04-20 10:32

本文主要是介绍JS中typeof和instanceof的用法小解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

javascript中,测试数据类型用到typeof 和 instanceof.


1. typeof一般测试基本类型(Undefined、Null、Boolean、Number、String),对引用类型一律返回object(Function引用类型返回Function

测试基本类型:

	var a="oo";var b=true;var c="";var d=null;var e=10;alert(typeof(o));//undefinedalert(typeof(a)); //stringalert(typeof(b)); //booleanalert(typeof(c));//stringalert(d==null); //truealert(typeof(e)); //number

测试引用型:

	var obj1=new Object();var obj2=new Array();var obj3=new Date();var obj4=new Function();var obj5=new Boolean(); var obj6=new Number();var obj7=new String(); alert("obj1  "+typeof(obj1)); //objectalert("obj2  "+typeof(obj2)); //objectalert("obj3  "+typeof(obj3));//objectalert("obj4  "+typeof(obj4));//functionalert("obj5  "+typeof(obj5));//objectalert("obj6  "+typeof(obj6));//objectalert("obj7  "+typeof(obj7));//objectalert(obj4 instanceof Function);//truealert(obj4 instanceof Object);//true


 


2. instanceof测试引用类型(Object、Array、Date、RegExp、Function、基本包装类型(Boolean、Number、String))

2.1 基本包装类型

基本类型值拥有方法操作  和 基本包装类型的出现,前者促进了后者,后者实现了前者。

	var s1="some clothes";var s2=s1.substring(2);alert(s2);//me clothes

在后台自动实现以下过程:

<1>自动创建String类型的一个实例 (中间出现的一个人物,任务是 暗中替s1调用方法)

<2>在实例上调用方法 ,返回值给s2

<3>销毁实例(完成使命就销毁了)


普通的引用类型和基本包装类型的主要区别就是 对象的生存期。自动创建的普通包装类型的实例存在一会就被销毁了,而手动new的一个平常的引用类型的实例,只要执行流还在当前作用域,它就一直保存在内存中。


2.2 测试

例子1  instanceof 可判断对象是不是另一个对象的实例,进一步判断继承关系

	function Fa(){}function Son(){}Son.prototype=new Fa();var obj=new Son();alert("obj是否是Son的实例?  "+(obj instanceof Son));//truealert("obj是否是Fa的实例?  "+(obj instanceof Fa));//true


例子2  寄生构造函数模式下,测试o是不是people的实例 

  function people(name,age,job){o=new Object();o.name=name;o.age=age;o.job=job;o.sayName=function(){alert(this.name);};return o;}var person=new people("zhang","19","student");person.sayName();alert(o instanceof people);//返回的对象o不是people的实例,但是是Object的实例


例子3  字符串传入Object构造函数,自动创建String实例

 var obj=new Object("one day");alert("obj instanceof String");//true

后台自动为"one day" 创建一个String实例,赋值给obj后销毁

3. 需要补充的以后想到了再补吧,写了这么多,除了一丝丝疲劳就是成就感啦


这篇关于JS中typeof和instanceof的用法小解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/920017

相关文章

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

Java序列化之serialVersionUID的用法解读

《Java序列化之serialVersionUID的用法解读》Java序列化之serialVersionUID:本文介绍了Java对象的序列化和反序列化过程,强调了serialVersionUID的作... 目录JavChina编程a序列化之serialVersionUID什么是序列化为什么要序列化serialV

python3中正则表达式处理函数用法总结

《python3中正则表达式处理函数用法总结》Python中的正则表达式是一个强大的文本处理工具,用于匹配、查找、替换等操作,在Python中正则表达式的操作主要通过内置的re模块来实现,这篇文章主要... 目录前言re.match函数re.search方法re.match 与 re.search的区别检索

MySQL 中的 JSON_CONTAIN用法示例详解

《MySQL中的JSON_CONTAIN用法示例详解》JSON_CONTAINS函数用于检查一个JSON文档中是否包含另一个JSON文档,这篇文章给大家介绍JSON_CONTAINS的用法、语法、... 目录深入了解 mysql 中的 jsON_CONTAINS1. JSON_CONTAINS 函数的概述2

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

Java8 Collectors.toMap() 的两种用法

《Java8Collectors.toMap()的两种用法》Collectors.toMap():JDK8中提供,用于将Stream流转换为Map,本文给大家介绍Java8Collector... 目录一、简单介绍用法1:根据某一属性,对对象的实例或属性做映射用法2:根据某一属性,对对象集合进行去重二、Du

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的