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

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

bytes.split的用法和注意事项

当然,我很乐意详细介绍 bytes.Split 的用法和注意事项。这个函数是 Go 标准库中 bytes 包的一个重要组成部分,用于分割字节切片。 基本用法 bytes.Split 的函数签名如下: func Split(s, sep []byte) [][]byte s 是要分割的字节切片sep 是用作分隔符的字节切片返回值是一个二维字节切片,包含分割后的结果 基本使用示例: pa

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(

js异步提交form表单的解决方案

1.定义异步提交表单的方法 (通用方法) /*** 异步提交form表单* @param options {form:form表单元素,success:执行成功后处理函数}* <span style="color:#ff0000;"><strong>@注意 后台接收参数要解码否则中文会导致乱码 如:URLDecoder.decode(param,"UTF-8")</strong></span>

js react 笔记 2

起因, 目的: 记录一些 js, react, css 1. 生成一个随机的 uuid // 需要先安装 crypto 模块const { randomUUID } = require('crypto');const uuid = randomUUID();console.log(uuid); // 输出类似 '9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d'

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

UVM:callback机制的意义和用法

1. 作用         Callback机制在UVM验证平台,最大用处就是为了提高验证平台的可重用性。在不创建复杂的OOP层次结构前提下,针对组件中的某些行为,在其之前后之后,内置一些函数,增加或者修改UVM组件的操作,增加新的功能,从而实现一个环境多个用例。此外还可以通过Callback机制构建异常的测试用例。 2. 使用步骤         (1)在UVM组件中内嵌callback函