javaScript 数据类型

    xiaoxiao2025-01-19  9

    数据类型分类

    基础数据类型

    undefined

    Undefined 类型只有一个值,即特殊的 undefined。在使用 var 声明变量但未对其加以初始化时,这个变量的值就是 undefined

    /* 在未申明的请求下直接使用会报错, 在使用未声明的变量时, 可以使用typeof,这样操作是安全的 */ console.log(a); // undefined 因为var 声明会出现变量提升 var a; console.log(b); // 报错 因为const声明会产生一个暂时性死区,不可以在申明前调用 let b;

    null

    类似于空指针(typeof null 返回 object),值为null,更多的情况下来表示这个变量为空,语义上跟undefined有明显区别。

    /* null 在值判断时候跟undefined 是相等的,是因为,都转成了number,值均为0。 尽管 null 和 undefined 有这样的关系,但它们的用途完全不同。无论在什么情况下 都没有必要把一个变量的值显式地设置为 undefined(因为如果使用typeof 返回 undefined,没法判断是未定义还是未赋值),可是同样的规则对 null 却不适用。换句话说, 只要意在保存对象的变量还没有真正保存对象,就应该明确地让该变量保存 null 值。这样做不仅可以 体现 null 作为空对象指针的惯例,而且也有助于进一步区分 null 和 undefined。 */ null == undefined // true null === undefined // false

    Boolean

    据类型转发为true的值转换为falsede zhiBooleantruefaseString任何非空字符串“”Number任何非零数字(包含Infinity)0 和 NaNObject任何对象nullundefined无undefined

    Number

    // 二进制 8进制 十进制 16进制 var a = 010; // 8 var b = 0x12 // 18 // 浮点数 由于浮点数存储的空间比整数大 ECMA 会适机将浮点转换为整数 // 关于浮点数值计算会产生舍入误差的问题,感兴趣可以查一下 JavaScript 浮点进度问题 var c = 10.0 // 会变成整数10 // 科学计数法 var d = 3e2; // 3 * 10的2次方即为300 // 数字中的特殊类型 NaN not a number NaN === NaN // false window.isNaN(NaN) // true Number.isNaN(NaN) // true window.isNaN('a') // true 因为 会先将`a`执行Number(a) Number.isNaN('a') // false 只有NaN才是ture // 常用的数值转换方法Number parseInt parseFloat var num1 = Number("Hello world!");// NaN var num2 = Number(''); // 0 var num3 = Number("000011"); // 11 var num4 = Number(true); // parseInt 跟看开头是否为数字如果是那么取到数字最后一位 var num1 = parseInt("1234blue"); // 1234 var num2 = parseInt(""); // NaN var num3 = parseInt("0xA"); // 10 16进制 var num4 = parseInt(22.5); // 22 var num5 = parseInt("070"); // 56 8进制 var num6 = parseInt("70"); // 70 // parseInt 第二个参数为进制 var num1 = parseInt("AF", 16); //175 var num1 = parseInt("AF"); // NaN // parsefloat 同上 不同点在于可以取浮点数

    String

    字符串的内容是不可以变的,一旦创建,它的值就不能改变,要改变的话需要先销毁当前的,再创建

    var lang = "Java"; lang = lang + "Script"; // 首先创建一个能容纳 10 个字符的 新字符串,然后在这个字符串中填 充"Java"和"Script", // 最后一步是销毁原来的字符串"Java"和字 符串"Script",因为这两个字符串已经没用了。

    引用数据类型

    Object

    存储的为地址的引用

    // 实例化 var person = new Object; person.name = 'javascript'; // 对象字面量表示法 var person2 = { name: 'javascript' }; var obj1 = { x:2 } var obj2 = obj1; obj2.x = 3; console.log(obj1, obj2); // { x:3 } { x:3 }

    使用defineProperty 来定义对象属性

    Object.defineProperty(obj, prop, descriptor)

    value 值writable 为true 才可以赋值,默认为falseconfigurable 当且仅当该属性的 configurable 为 true 时,该属性描述符才能够被改变,同时该属性也能从对应的对象上被删除。默认为 falseenumerable 当且仅当该属性的enumerable为true时,该属性才能够出现在对象的枚举属性中。默认为 false。get 一个给属性提供 getter 的方法,如果没有 getter 则为 undefined。当访问该属性时,该方法会被执行,方法执行时没有参数传入,但是会传入this对象set 一个给属性提供 setter 的方法,如果没有 setter 则为 undefined。当属性值修改时,触发执行该方法。该方法将接受唯一参数,即该属性新的参数值。

    Array

    常见的数组方法参见 数组方法

    Date

    时间对象

    var date = new Date(); // 日期格式化方法 // toDateString()——以特定于实现的格式显示星期几、月、日和年; date.toDateString(); // Sun May 26 2019 // toTimeString()——以特定于实现的格式显示时、分、秒和时区; date.toTimeString(); // 15:27:53 GMT+0800 (中国标准时间) // toLocaleDateString()——以特定于地区的格式显示星期几、月、日和年; date.toLocaleDateString(); // 2019/5/26 // toLocaleTimeString()——以特定于实现的格式显示时、分、秒; date.toLocaleTimeString(); // 下午3:27:53 // toUTCString()——以特定于实现的格式完整的 UTC 日期。 date.toUTCString(); // Sun, 26 May 2019 07:27:53 GMT

    RegExp

    模式 g:表示全局(global)模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即 停止 i:表示不区分大小写(case-insensitive)模式,即在确定匹配项时忽略模式与字符串的大小写; m:表示多行(multiline)模式,即在到达一行文本末尾时还会继续查找下一行中是否存在与模式匹配的项。

    Function

    函数实际 上是对象。每个函数都是 Function 类型的实例,而且都与其他引用类型一样具有属性和方法。由于函 数是对象,因此函数名实际上也是一个指向函数对象的指针,不会与某个函数绑定。

    问题

    关于数据类型的深拷贝操作,给定一个输入,将输入的内容深拷贝一份返回 ?

    最新回复(0)