JavaScript之JS的数据类型

前言

JavaScript一共有6中数据类型: 基本数据类型(5):字符串(String)、数字(Number)、布尔(Boolean)、数组(Array)、空(Null)、未定义(Undefined) 复杂数据类型(1):对象(Object) 注意:Array、Date、Math、Error Set(ES6).....都是属于Object中

一、JS数据类型概述

1.1 简介

原始类型(基本类型):按值访问,可以操作保存在变量中实际的值。 原始类型汇总中null、undefined比较特殊。 引用类型:引用类型的值是保存在内存中的对象。

与其他语言不同的是,JavaScript不允许直接访问内存中的位置,也就是说不能直接操作 对象的内存空间。 在操作对象时,实际上是在操作对象的引用而不是实际的对象。所以引用类型的值是按引用 访问的。

1.2 typeof 操作符

由于js中的变量是松散类型的,所以它提供了一种检测当前变量的数据类型的方法,也就是typeof关键字。

关键字

类型

typeof

123

Number

typeof

'abc'

String

typeof

true

Boolean

typeof

undefined

Undefined

typeof

null

Object

typeof

{ }

Object

typeof

[ ]

Object

typeof

console.log()

Function

null类型进行typeof操作符后,结果是object,原因在于,null类型被当做一个空对象引用。

二、原始类型

2.1 Number类型

  • Number类型包含整数和浮点数(浮点数数值必须包含一个小数点,且小数点后面至少有一位数字)两种值。
  • js不区分 整型和 浮点型

特殊值 NaN (非数字类型)

  • NaN跟任何值进行任何运算,结果仍然NaN.跟谁都不相等,包括自己。
  • 特点 ① 涉及到的 任何关于NaN的操作,都会返回NaN ② NaN不等于自身。
  • isNaN() 函数用于检查其参数是否是非数字值。 isNaN(123) //false isNaN("hello") //true

一般NaN被动产生(数据类型转为Number,不能转为正常的数字,就是NaN) 函数 isNaN() 判断是不是NaN或者能不能转换为NaN

使用实例:

         //数字
        var n1 = 10234;
        var n2 = 0x12; //十六进制
        var n3 = 2e2; //科学计数法(小学知识)

        console.log(n1,n2,n3)

        //浮点精度问题
        console.log(.1 + .2);

        //NaN  表示Not a number

        console.log(NaN)
        console.log(typeof(NaN))       //NaN的数据类型依然是number

        //NaN 跟 任何值(包括0) 进行任何运算 结果依然是NaN
        console.log(NaN * 0);          //结果是NaN

        //NaN跟谁都不相等
        console.log(NaN == NaN)       //结果是false


        var num = 2344e1000;

        console.log(typeof(num))      //结果是infinity即无穷大
        console.log(num)              //数据类型依然为number


        console.log(isNaN(NaN))       //true
        console.log(isNaN('hello'))  //true
        console.log(isNaN('123')) // false 字符串'123' 转为number 的时候 是 123 不是NaN

2.2 String类型

  • 字符串是存储字符(比如 "Bill Gates")的变量。
  • 字符串有length属性
  • 字符串可以是引号中的任意文本。您可以使用单引号或双引号(没有区别)。
  • 您可以在字符串中使用引号,只要不匹配包围字符串的引号即可。
var answer="It's alright";
var answer="He is called 'Johnny'";
var answer='He is called "Johnny"';

2.3 Boolean类型

布尔(逻辑)只能有两个值:true 或 false。

var x=true;
var y=false;

2.4 Null类型 和 Undefined类型

1) Null类型 被动产生 null类型被看做空对象指针,前文说到null类型也是空的对象引用。

2)Undefined类型 只有一个值,即undefined值。使用var声明了变量,但未给变量初始化值,那么这个 变量的值就是undefined.

Undefined 这个值表示变量不含有值。 可以通过将变量的值设置为 null 来清空变量。

cars=null;
person=null;

二、三大引用类型

js中对象是一组属性与方法的集合。这里就要说到引用类型了,引用类型是一种数据结构, 用于将数据和功能组织在一起。引用类型有时候也被称为对象定义,因为它们描述的是一类 对象所具有的属性和方法。

2.1 Object类型

我们看到的大多数类型值都是Object类型的实例,创建Object实例的方式有两种: 1)第一种是使用new操作符后跟Object构造函数

var person = new Object();
person.name = "Micheal";
person.age = 24; 

2)第二种方式是使用对象字面量表示法 对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式 (name : value) 来定义。 属性由逗号分隔

var person = {
  name : "Micheal",
  age : 24
};

寻址的两种方式:

name=person.name;
name=person["name"];

2.2 Array类型

数组的每一项可以用来保存任何类型的数据,也就是说,可以用数组的第一个位置来 保存字符串,第二个位置保存数值,第三个位置保存对象....另外,数组的大小是可 以动态调整的。

创建数组的基本方式有两种: 1)第一种是使用Array构造函数

var colors = new Array("red","blue","yellow");
 var cars=new Array();
 cars[0]="Saab";
 cars[1]="Volvo";
 cars[2]="BMW";

2)第二种是使用数组字面量表示法

var colors = ["red","blue","yellow"];

2.3 Function类型

每个函数都是Function类型的实例,而且都与其他引用类型一样具有属性和方法。 函数通常是使用函数声明语法定义的,如下所示

function sum(num1,num2){
  return num1 + num2;
};

这和使用函数表达式定义函数的方式相差无几

var sun = function (){
  return sum1 + sum2;
};

注意: 当您声明新变量时,可以使用关键词 "new" 来声明其类型:

 var carname=new String;
 var x=      new Number;
 var y=      new Boolean;
 var cars=   new Array;
 var person= new Object;

JavaScript 变量均为对象。当您声明一个变量时,就创建了一个新的对象。 提示:JavaScript具有隐含的全局概念,意味着你不声明的任何变量都会成为一个全局对象属性。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏逆向技术

C语言第八讲,指针*

            C语言第八讲,指针* 一丶简单理解指针 说到指针,很多人都说是C语言的重点. 也说是C语言的难点. 其实指针并不是难.而是很多人搞不清地...

38560
来自专栏陈树义

《JavaScript程序设计》第2课:JS类型系统

JS类型系统可以分为标准类型和对象类型,进一步标准类型又可以分为原始类型和引用类型,而对象类型又可以分为内置对象类型、普通对象类型、自定义对象类型。 ? 1. ...

34370
来自专栏派森公园

Scala中的闭包

除此之外,Scala还支持引用其他地方定义的变量:(x: Int) => x + more,这个函数将more也作为入参,不过这个参数是哪里来的?从这个函数的角...

5710
来自专栏ACM算法日常

leetcode 41| 缺失的第一个正数

难点分析:是不是和笔者一样,刚看完一遍题目都不知道它在问什么~经过多次揣摩之后,笔者终于懂了这道题目到底在问什么。其实它就是给定一个数组,然后看看数组中是否包含...

21120
来自专栏WindCoder

Java漫谈-数组

在Java语言中,数组是对象(An object is a class instance or an array.),而且是动态创建的。

19710
来自专栏转载gongluck的CSDN博客

python笔记:#013#高级变量类型

高级变量类型 目标 列表 元组 字典 字符串 公共方法 变量高级 知识点回顾 Python 中数据类型可以分为 数字型 和 非数字型 数字型 整型 (in...

35290
来自专栏柠檬先生

python基础 面向对象编程

面向对象编程的基本思想   类和实例     类用于定义抽象类型     实例根据类的定义创建出来 python 定义类并创建实例   在python 中,通过...

27840
来自专栏塔奇克马敲代码

第 14 章 重载运算与类型转换

24960
来自专栏黑泽君的专栏

java基础学习_基础语法(下)01_day05总结

============================================================================= ==...

9810
来自专栏python学习之旅

JS笔记(二):对象

18530

扫码关注云+社区

领取腾讯云代金券