JavaScript类型系统之基本数据类型与包装类型

yizhihongxing

JavaScript类型系统之基本数据类型与包装类型

在JavaScript中,数据类型可以分为两类:基本数据类型和引用数据类型。其中,基本数据类型(primitive data type)包括:NumberStringBooleannullundefined,而引用数据类型(reference data type)则包括:ObjectArrayDateRegExp等。

除了基本数据类型以外,JavaScript还提供了对应的包装类型(wrapper object),即用于包装基本数据类型的引用类型。包装类型有NumberStringBoolean三种,其余的基本数据类型没有对应的包装类型。

基本数据类型

Number

Number类型用于表示数字,包括整数和浮点数。JavaScript的数字没有区分整型和浮点型,二者都使用Number类型来表示,同时也没有对数字范围的限制,即可以表示任意大小和精度的数字。

示例:

let a = 10;
let b = 3.14;
console.log(typeof a); // 输出:"number"
console.log(typeof b); // 输出:"number"

String

String类型用于表示文本字符串,可以包含任意字符,包括空格、标点符号和特殊字符等。字符串可以通过单引号、双引号或反引号来表示,其中反引号可以用于形成模板字符串。

示例:

let str1 = 'hello world';
let str2 = "it's a beautiful day today";
let str3 = `the result is ${a + b}`;
console.log(typeof str1); // 输出:"string"
console.log(typeof str2); // 输出:"string"
console.log(typeof str3); // 输出:"string"

Boolean

Boolean类型用于表示逻辑值,包括truefalse两个值。通常用于控制程序的流程或进行条件判断。

示例:

let flag1 = true;
let flag2 = false;
console.log(typeof flag1); // 输出:"boolean"
console.log(typeof flag2); // 输出:"boolean"

null

null表示一个空对象引用,常用于初始化变量或对象属性,表示这个变量或属性暂时未被赋值。

示例:

let obj = null;
console.log(typeof obj); // 输出:"object"

undefined

undefined表示一个未定义的变量或对象属性,通常表示该变量或属性还未被声明或赋值。

示例:

let x;
console.log(typeof x); // 输出:"undefined"

包装类型

Number

Number类型的包装类型提供了一些实用的方法,例如转换数字为字符串、获取数字的小数部分、判断数字是否为有限数等。

示例:

let num = 123.456;
console.log(num.toFixed(2)); // 输出:123.46
console.log(num.toString()); // 输出:"123.456"
console.log(Number.isFinite(num)); // 输出:true

String

String类型的包装类型同样提供了一些实用的方法,例如将字符串转换为数字、获取字符串长度、提取字符串中的子串等。值得注意的是,字符串的每个字符都可以看作是一个长度为1的字符串,因此可以通过下标来访问字符串中的每个字符。

示例:

let str = 'hello world';
console.log(str.length); // 输出:11
console.log(parseInt('123')); // 输出:123
console.log(str.charAt(0)); // 输出:h
console.log(str.substring(0, 5)); // 输出:hello

Boolean

Boolean类型的包装类型没有提供太多的实用方法,只有一个valueOf方法用于返回布尔值的原始值。

示例:

let flag = new Boolean(false);
console.log(flag.valueOf()); // 输出:false

总结

基本数据类型和包装类型在使用时有一些细微的差别,例如在比较两个基本数据类型时,只需使用=====运算符,而不需要调用它们的方法。但是,包装类型与基本数据类型的自动转换确实方便了我们的编程,可以在某些情况下减少代码复杂度。因此,在实际编程中,需要根据实际需求和编程习惯选择使用基本数据类型或包装类型。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript类型系统之基本数据类型与包装类型 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • TreeNodeCheckChanged事件触发方法代码实例

    对于.NET平台中的TreeView控件,其中的节点是否被勾选的状态会影响到整棵树的结构和数据,为此,TreeView提供了一个名为TreeNodeCheckChanged的事件,可以监听节点是否被勾选或者取消勾选的状态变化。以下是详细的介绍和示例说明。 TreeNodeCheckChanged事件简介 事件说明 TreeNodeCheckChanged是T…

    JavaScript 2023年6月11日
    00
  • getElementByIdx_x js自定义getElementById函数

    自定义getElementById函数是指我们自己编写一个函数来实现与原生document.getElementById相同的功能,该功能就是获取HTML文档中指定id属性的元素节点。 以下是一个示例的自定义getElementById函数: function getElementByIdx_x(id) { var docEl = document.docu…

    JavaScript 2023年6月10日
    00
  • JavaScript利用Immerjs实现不可变数据

    针对“JavaScript利用Immerjs实现不可变数据”的完整攻略,我为大家提供以下详细讲解。 什么是Immerjs Immerjs是一个JavaScript库,可以让您使用不可变数据避免更改源数据。它通过提供一种易于使用的机制来撰写交错对象更新(Immerjs的核心)。 Immerjs通过使用JavaScript Proxy API来实现这些功能,而P…

    JavaScript 2023年6月10日
    00
  • JavaScript内置对象之Array的使用小结

    JavaScript内置对象之Array的使用小结: 1. 概述 JavaScript内置对象之Array是一种可以保存多个值的可变长度的列表,可以通过下标获取或修改其中的某个元素。 2. 声明数组 可以使用字面量的方式声明一个空数组和非空数组,如下所示: var arrEmpty = []; // 空数组 var arr1 = [1, 2, 3]; // …

    JavaScript 2023年5月27日
    00
  • JS 文件本身编码转换 图文教程

    下面为您详细讲解“JS 文件本身编码转换 图文教程”的完整攻略。 背景 当我们在编写JavaScript文件时,有时候文件的编码格式与我们所需要的格式不一致,这时就需要进行编码转换,以确保文件在不同平台和浏览器中的正确展示。 方法 文件编码转换有多种方法,本文将主要介绍两种方法。 方法一:使用VSCode 在VSCode中,我们可以通过如下步骤进行文件编码转…

    JavaScript 2023年5月20日
    00
  • js鼠标及对象坐标控制属性详细解析

    JS鼠标及对象坐标控制属性详细解析 在JavaScript中,有很多属性可以用来控制对象的位置,本文主要讲解与鼠标有关的一些属性,以及如何利用这些属性来控制对象的位置。 鼠标相关属性 event.clientX && event.clientY event.clientX表示鼠标相对于浏览器窗口可视区域的水平位置,event.clientY表…

    JavaScript 2023年6月11日
    00
  • JavaScript中Array的filter函数详解

    JavaScript中的Array对象提供了一个filter方法,该方法可以用于在数组中过滤出符合条件的元素。本文将详细介绍该方法的使用方法。 Array的filter函数详解 语法 array.filter(function(currentValue, index, arr), thisValue) 参数 function(currentValue, in…

    JavaScript 2023年5月27日
    00
  • js实现登陆与注册功能

    实现登录和注册功能是实现网站用户系统非常重要的一部分。下面是一个基本的js实现登陆与注册的攻略: 1.设计数据库 数据库是用来保存用户信息和验证用户身份的主要存储介质,需要提前设计好数据库的结构并使用相关的数据库技术(如MySQL)进行实现,至少包含用户信息表和用户登录信息表。常见的用户信息表包含加密后的用户名、加密后的密码、用户邮箱、注册时间等字段,示例:…

    JavaScript 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部