重学javascript基础-typeof

本文深入解析JavaScript中的七种数据类型,包括六种基本数据类型(Undefined、String、Number、Boolean、Symbol、Null)和一种复杂数据类型(Object)。通过实例演示了如何使用typeof操作符检测变量类型,并提供了安全防范机制来检查变量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

js 一共有六种基本数据类型(原始数据类型) 一种复杂数据类型(引用数据类型)

  • 基本数据类型:Undefined String Number Boolean Symbol Null
  • 复杂数据类型:Object

js 中变量是没有类型的,在做typeof操作时,得到的结果不是该变量的值,而是该变量持有的值的类型

typeof 操作符

  • "undefined"—— 如果这个值未定义;
  • "boolean"—— 如果这个值是布尔值;
  • "string"—— 如果这个值是字符串;
  • "number"—— 如果这个值是数值;
  • "object"—— 如果这个值是对象 或复合类型y或 null;
  • "function"—— 如果这个值是函数。
  • "symbol"——如果这个值是new Symbol()得出的
检测一个变量的类型 typeof
let foo = null;
// null 在js中是一个假值
console.log(!foo&&typeof foo === 'object'); // true
console.log(foo===null); // true 
console.log(Object.prototype.toString.call(foo)==="[object Null]"); // true
// Object.prototype可用来检测任何类型 返回值为"[object 类型(eg:NULL,Array,Number,String,Undefined,Symbol,Function,Object,Boolean)]"

// 检测函数
function fn(){
  console.log('is function')
}
console.log(typeof fn); // function

// 以声明未赋值 undefined
let a; // let 在同一作用域内不可重复声明
console.log(typeof a); // undefined;

// 检测数值
let b = 12;
console.log(typeof b); // number;

// 检测字符串
let c = "String";
console.log(typeof b);  // string;

// 检测symbol
let d = new Symbol(1);
console.log(typeof d);  // symbol;

// 检测boolean
let flag = true;
console.log(typeof flag); // boolean

复制代码
使用typeof的安全防范机制来检查变量
if(DEBUG){  // DEBUG is not defined
  console.log('debugger');
}
if(DEBUG!==undefined){
  console.log("debugger");
}
// 可以使用window.DEBUG来做这种容错,鉴于只有浏览器环境有window,故使用typeof 更为明智
复制代码

ps: typeof返回值的类型是string -----> typeof typeof s ==="string" //true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值