js的数据类型有哪些?[通俗易懂]

js的数据类型有哪些?[通俗易懂]数据类型一、数据类型:基本数据类型(值类型):字符串(String)、数字(Number)、布尔(Boolean)、对空(Null)、未定义(Undefined)。引用数据类型(对象类型):对象(Object)、数组(Array)、函数(Function)。特殊的对象:正则(RegExp)和日期(Date)。特殊类型:underfined未定义、Null空对象、Infinate无穷、NAN非数字基本数据类型的值直接在栈内存中存储,值与值之间独立存在,修改一个变量不会影响.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

数据类型

一、数据类型:

基本数据类型(值类型):字符串(String)、数字(Number)、布尔(Boolean)、对空(Null)、未定义(Undefined)。

引用数据类型(对象类型):对象(Object)、数组(Array)、函数(Function)。

特殊的对象:正则(RegExp)和日期(Date)。

特殊类型:underfined 未定义、Null  空对象、Infinate 无穷、NAN 非数字

基本数据类型的值直接在栈内存中存储,值与值之间独立存在,修改一个变量不会影响到其他变量。

对象是保存在堆内存中的,每创建一个新对象,就会在堆内存中开辟出一个新空间,而变量保存的是对象的内存地址(对象的引用),如果两个变量保存的是同一个对象引用,当其中一个通过变量修改属性时,另一个也会受到影响。

当比较两个基本数据类型的值时,就是比较值。

而比较两个引用数据类型时,它是比较的对象的内存地址,如果两个对象是一样,但是地址不同,也会返回false.

typeof 检测变量的数据类型

Var str = “string” ;

Var type  =  typeof str; //string

//type 这个变量在这里我们称为【返回值】

【返回值】:由函数(系统内置函数、自定义函数它执行后的返回的结果)

//js中如何判定一个数组是一个真数组??

Var obj = {}; //对象 json 对象

Console.log(typleof obj);//object 类型

Var fn = function(){};//函数

Console.log(typeof(fn)); //function 类型

//null 特殊类型:代理空

Console.log(typeof(null)); //object类型

String字符串

  1. 在js中字符串需要使用引号引起来,单引号和双引号不能混用
  2. 引号不能嵌套,可以使用\进行转义。

Number类型:

  1. Number类型包括整数和浮点数(小数)
  2. JS进行浮点元素运算可能得到一个不精确的值0.1+0.2=0.300000004,不能进行精确度要求比较高的运算
  3. NaN表示Not A Number,检查时返回number
  4. JS中可以表示的数字最大值:Number.MAX_VALUE:1.79769….e+308(1.79..的308次方)如果使用Number表示的数字超过了最大值,则会返回Infinity(正无穷);最小值-Number.MIN_VALUE,(5e-324,5*10的-324次方,大于0的最小值),如果使用Number表示的数字超过了最小值返回-Infinity(负无穷),Infinity为number数据类型

Boolean布尔

  1. 布尔值只有两个true/false,主要做逻辑判断。
  2. 使用typeof检查一个布尔值时返回boolean

Undefined未定义

  1. js中输出未被赋值的被定义变量结果是Undefined;Undefined类型的值只有一个。
  2. 使用typeof检查时值时返回undifined

Null空对象:

  1. Null(空值)类型的值只有一个,null,用来表示一个为空的对象,使用typeof检查时值时返回object,因为null表示空对象NaN、infanity、undefined

Object对象

二、强制类型转换:parseInt() parseFloat() typeof()

将一个数据类型强制转换为其他的数据类型,String,Number,Boolean

转为String:

方法一:

-调用被转换数据类型的toString()方法

-该方法不会影响到原变量,它会将转换的结果返回

-null和undifined这两个值没有toString()方法,调用会报错。

var a = 123; a = a.toString();console.log(a)//”string”

方法二:

   -使用String()函数,将被转换的数据作为参数传递给函数;

   -对于Number和Boolean实际上就是调用toString()方法;

-对于null和underfined,就不会调用toString()方法,它会将null直接转换为“null”,将underfined直接转换为“underfined”。

   a = String(a); console.log(a)//”string”

转换为Number:

方法一:使用Number()函数

  -字符串–> 数字

  1. 纯数字的字符串,直接转为数字
  2. 如果字符串中含有非数字内容,则转换为NaN
  3. 如果字符串是一个空串或者全是空格的字符串,则转换为0

  -布尔 –> 数字

true转成1;false转成0

  -null–> 数字 0

  -undefined–>数字 NaN

方法二:专门用于来对付字符串

  1. paresInt();//字符串转化为整数(小数点省略)

可以将字符串中的有效整数内容取出来,转为Number类型

var a =”123px”; a = paresInt(a); console.log(a)  //123

var a =”123.456”; a = paresInt(a); console.log(a)  //123取整

  1. paresFloat();//字符串转化为浮点数,可以获得有效小数

var a =”123.456”; a = paresInt(a); console.log(a)  //123.456

  1. 如果对非String使用paresInt()或paresFloat(),会将其转换为String.然后在操作

var a =true; a = paresInt(a); console.log(a)  //NaN

转换为Boolean:

  1. 调用Boolean()函数,除了0和NaN,其余的都是true,  数字–>布尔.

var a =123; a =Boolean(a); console.log(a)  //true

var a =-123; a =Boolean(a); console.log(a)  //true

var a =0; a =Boolean(a); console.log(a)  //false

var a =Infinity; a =Boolean(a); console.log(a)  //true

var a =NaN; a =Boolean(a); console.log(a)  //false

2、字符串–>布尔,除了空串,其余的都是true

3、null和underfined,都会转为false

4、对象也会转换为true

其他进制的数字:

  1. 在js中,如果需要表示16进制的数字,则需要以0x开头

var a =”0x10”; console.log(a)  //16

var a =”0xff”; console.log(a)  //255

  1. 8进制,以0开头

var a =”070”; console.log(a)  //56

  1. 2进制,以0b开头,并非所有浏览器都支持

var a =”0b10”; console.log(a)  //2

  1. “070”这种特殊字符串,有些浏览器会当成8进制解析,有些会当成10进制解析;可以在paresInt()中传递参数来指定数字的进制

var a =”070”; a = paresInt(a,10) ;console.log(a)  //70,十进制解析

2、数据类型:堆内存

普通类型、标量类型:

string

number (int+ float)

引用类型:存储在栈内存

object ( array {})

array  

function 函数类型

特殊类型:

null (计算机的一块虚拟内存)

隐式转换:

“100”+200

“a” > “b”

….

弱数据类型语言:定义变量、参数传递 无需指定数据类型

js

php

python

var a = 123|“serewr”|[];

强数据类型语言:定义变量指定数据类型

java

c

sql

xxx char(23)

a int;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196833.html原文链接:https://javaforall.net

(0)
上一篇 2025年9月19日 上午10:15
下一篇 2025年9月19日 上午10:43


相关推荐

  • java接口详解

    java接口详解Java基础——接口一、接口的概述:官方解释:Java接口是一系列方法的声明,是一些方法特征的集合,一个接口只有方法的特征没有方法的实现,因此这些方法可以在不同的地方被不同的类实现,而这些实现可以具有不同的行为(功能)。我的解释:接口可以理解为一种特殊的类,里面全部是由全局常量和公共的抽象方法所组成。接口是解决Java无法使用多继承的一种手段,但是接口在实际中更多的作用是制定标准的。或者我们可以直接把接口理解为100%的抽象类,既接口中的方法必须全部是抽象方法。(JDK1.8之前可以这样理解)二、接

    2022年7月7日
    30
  • ebx文件

    ebx文件EBX 是一种电子书格式 打开方式 用 XReader ebx 阅读器 打开 xreader 免费版是一款专门针对 psp 而推出的一款大众软件 不仅能够在 psp 中看图片 还能够当成一个专业的 PSP 阅读器 支持任意大小点阵字体 支持 html 读取 编码转换 竖看 翻页保留行 书签及自动书签等 可以看 zip 和 chm 和 rar 内的文本文件 有自动降频节能 不播放 mp3 时 另外 xReader 支持看图的格式有 b

    2026年3月20日
    2
  • WinForm界面优化工具

    WinForm界面优化工具引用等待尝试http://space.itpub.net/12639172/viewspace-678321

    2022年5月27日
    43
  • datagrip激活码2021.04【在线破解激活】[通俗易懂]

    datagrip激活码2021.04【在线破解激活】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    70
  • pyqt5 qtwidgets_第六高级中学地址

    pyqt5 qtwidgets_第六高级中学地址QTabWidget前言QTabWidget控件提供了一个选项卡和一个页面区域,默认显示第一个选项卡的页面,通过单击各选项卡可以查看对应的界面,如果在一个窗口中显示的输入字段很多,则可以对这些字段进行拆分,分别放置在不同界面的选项卡中QTabWidget类中常用的方法方法描述addTab()将一个控件添加到Tab控件的选项卡中in…

    2025年11月21日
    5
  • QQ农场怎么开挂_qq农场矿山辅助

    QQ农场怎么开挂_qq农场矿山辅助很久没更新博客了,今天就拿开发QQ开心农场外挂的一些问题来写篇短日志充个数。 关于登陆       在web上,QQ登陆的时候是将密码加密后再提交了,打开http://xiaoyou.qq.com,找到了密码加密过程在http://imgcache.qq.com/campus/js/Mlogin.js 文件中,通过解读代码可以了解到,QQ一共进行了4次的MD5运算,具体过程如下:比如

    2025年11月2日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号