javascript 数据类型

admin1年前 (2023-07-31)it知识228

在Javascript中有8种基本的数据类型(译注:7种原始类型和1种引用类型)。

我们可以将任何类型的值存入变量。例如,一个变量可以在前一刻是字符串,

下一刻就存储一个数字:

let message = "hello";
message = 123456;

允许这种操作的编程语言,例如javascript,被称为“动态类型”的编程语言,

意思是虽然编程语言种有不同的数据类型,但是你定义的变量并不会在定义后,

被限制为某一数据类型。

Number 类型

let n = 123;
n = 12.345;

number 类型代表整数和浮点数。

数字可以有很多操作,比如,乘法*,除法 /,加法 +,减法 -等等。

BingInt 类型

在Javascript 中,“number”类型无法安全地表示大于(253-1)

(即 9007199254740991),或小于 -(253-1) 的整数。

更准确的说,“number” 类型可以存储更大的整数

(最多 1.7976931348623157 * 10308),但超出安全整数范围 ±(253-1)

 会出现精度问题,因为并非所有数字都适合固定的 64 位存储。

因此,可能存储的是“近似值”。

例如,这两个数字(正好超出了安全整数范围)是相同的:

console.log(9007199254740991 +1); // 9007199254740992
console.log(9007199254740991 +2); // 9007199254740992

也就是说,所有大于 (253-1) 的奇数都不能用 “number” 类型存储。

在大多数情况下,±(253-1) 范围就足够了,但有时候我们需要整个范围非常大的整数,

例如用于密码学或微秒精度的时间戳。

BigInt 类型是最近被添加到 JavaScript 语言中的,用于表示任意长度的整数。

可以通过将 n 附加到整数字段的末尾来创建 BigInt 值。

// 尾部的 "n" 表示这是一个 BigInt 类型
const  bigInt = 1234567890123456789012345678901234567890n;

string类型

javascript 中地字符串必须被括在引号里。

let str = "Hello";
let str2 = 'Single quotes are ok too';
let phrase = `can embed another ${str}`;

在JavaScript 中,有三种包括字符串地方式。

  1. 双引号: "Hello";

  2. 单引号:'Hello';

  3. 反引号: `Hello`;

双引号和单引号都是简单引号,在Javascript 中两者几乎没有什么差别。

反引号是功能扩展引号。它们允许我们通过将变量和表达式包装

在${...}中,来将它们嵌入字符串中。例如:

let name = "John";
alert(`Hello`,${name}!`);
alert(`the result is ${1 + 2}`);

${...} 内的表达式会被计算,计算结果会成为字符串的一部分。可以在${...}

内放置任何东西:诸如名为name的变量,或者诸如1+2的算数表达式,

或则其它一些更复杂的。

需要注意的是,这仅仅在反引号内的有效,其他引号不允许这种嵌入。

alert("the result is ${1 + 2}");

Boolean 类型(逻辑类型)

boolean类型仅包含两个值: true 和 false 。

这种类型通常用于存储表示yes 或no 的值: true 意味着"yes, 正确,

 false 意味着 "no ,不正确"。

比如: 

let nameFieldChecked = true; // yes, name field is checked
let ageFieldChecked = false; // no, age field is not checked

布尔值也可做为比较的结果:

let isGreater = 4 > 1;
alert(isGreater); // true(比较的结果是 "yes")

null值

特殊的null 值不属于上述任何一种类型。

它构成一个独立的类型,只包含null 值:

let age = null;

相比较于其他编程与语言,Javascript 种null 不是一个”对不存在的Object 

的引用或者null 指针。

Javascript 种的null 仅仅是一个代表"无","空"或"值未知"的特殊值。

上面的代码表示age 是未知的。

undefined 值

特殊值undefined和null 一样自成类型。

undefuned的含义是未被赋值。

如果一个变量已被声明,单违背赋值,那么它的值就是undefined:

let age;
alert(age);

从技术上讲,可以显式地将 undefined 赋值给变量:

let age = 100;
age = undefined;
alert(age);  //"undefined"

……但是不建议这样做。通常,使用 null 将一个“空”或者“未知”的值写入

变量中,而 undefined 则保留作为未进行初始化的事物的默认初始值。

Object 类型和Symbol 类型

object 类型是一个特殊的类型。

其他所有的数据类型都被成为原始类型,因为它们的值只包含一盒单独的

内容(字符串,数字或其他)。相反,object 则用于储存数据集合和更复杂的实体

symbol 类型用于创建对象的唯一标识符。我们这里提到symbol 类型是为了完整性

typeof 运算符

typeof 运算符返回参数的类型。当我们想要分别处理不同类型值得时候,

或者想快速进行数据类型检验时,非常有用。

对typeof x 得调用会以字符串的形式返回数据类型:

typeof undefined // "undefined"
typeof 0 // "number"
type 10n //"bigint"
typeof true // "boolean"
typeof "foo" //"string"
typeof Symbol("id") //"symbol"
typeof Math // "object" (1)
typeof null // "object" (2)
typeof alert // "function" (3)

总结

javascript 中有八种基本的数据类型

七种原始数据类型:

number 用于任何类型的数字:整数或浮点数,在±(253-1) 范围内的整数。

bigint 用于任意长度的整数。

string 用于字符串:一个字符串可以包含0个或多个字符,没有单独的单字符类型。

boolean用于true 和false。

null 用于未知的值 ---只有一个null 值得独立类型。

undefined 用于未定义得值 --- 只有一个undefined 值得独立类型。

symbol 用于唯一得标识符。

以及一种非原始数据类型:

object 用于更复杂的数据结构。

我们可以通过typeof  运算符查看存储在变量中的数据类型。

通常用作typeof  x, 但typeof (x) 也可以。

已字符串的形式返回类型名称,例如 "string"。

typeof null  会返回"object" --- 这是javascript 编程语言的一个错误,

实际上它并不是一个object。

标签: JavaScript
返回列表

上一篇:长轮询

下一篇:前端定时器代码

相关文章

JavaScript 数组迭代

数组迭代方法对每个数组项进行操作Array.foreach()方法为每个数组元素调用一次函数(回调函数)var txt = ""; var ...

JavaScript 对象构造器

function Person(first, last, age) {       this.fi...

JavaScript Map

Map 保存键值对,其中键可以是任何数据类型。Map会记住键的原始插入顺序。Map提供表示映射大小的属性。如何创建Map 可以通过以下方式创建Javascript 映射:将数组传递给new...

关于Javascript

JavaScript是一种广泛使用的编程语言,用于在网页上添加交互性和动态性。它是一种高级,动态类型的脚本语言,常常与HTML和CSS一起使用,以创建丰富的用户体验。JavaScript具有以下优美的...

Vue 报错error:0308010C:digital envelope routines::unsupported 解决方案

Error: error:0308010C:digital envelope routines::unsupported出现这个错误是因为 node.js V17版本中最近发布的OpenSSL3.0,...

vue-router导航守卫

vue-router的导航守卫可以用来在路由跳转过程中添加自定义逻辑,例如验证、权限控制、重定向等。导航守卫可以分为三种:全局导航守卫、路由独享守卫和组件内的守卫1。全局导航守卫可以使用router....

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。