javascript 数据类型

admin2年前 (2023-07-31)it知识452

在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中‘+‘号和‘-‘的区别

1.在js里,'-'操作只能数值进行,如果出现字符串就会将字符串转变为数值。2.'fgfg'这个字符串是不可以转为数值的所以结果是NaN(非数值型),'100&...

JavaScript 数据类型

javascript 变量可以保存多种数据类型:数值、字符串值、数组、对象var x;   // x是undefined var leng...

JavaScript 对象定义

在JavaScript 中,对象是王。如果你理解了对象,就理解了javascript。在Javascript 中,几乎所有事物都是对象。 布尔是对象(如果用new 关键词定义)数字是对象(如...

JavaScript 对象原型

前面有一章提到无法为已有的对象构造器添加新属性Person.nationality = "English";  //得到的是undefine...

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

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

前端定时器代码

写一个mySetInterVal(fn, a,b), 每次间隔啊,a, a+b,a+2b 的时间,然后写一个myClear,停止上面的mySetInterValfunction mySetI...

发表评论

访客

看不清,换一张

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