JavaScript都有哪些数据类型呢?

在JavaScript里面,数据类型分为两类:原始类型(primitive type)和对象类型(object type)

1. 原始类型(我的理解,不可分割的基本类型)
数字、字符串、布尔值、null、undefined

2. 对象类型(我的理解,由 键/值 对组成的一种类型)
普通对象、数组、函数、Date、RegExp、Error

PS:其中普通对象是指那些用户自定义的对象
(万物皆对象,类是对象类型的子类型,对象拥有属性和方法,但是null和undefined除外。)

1). Number

JavaScript 里面不区分整数和浮点数,统一用Number表示,e.g.

123;    // 整数123
12.3; // 浮点数12.3
-12; // 负数-12
1- 'a'; // NaN (NaN表示 Not a Number,意味着无法计算当前结果)
1/0; // Infinity (Infinity表示无限大)

其中,需要注意的是 NaN这个特殊的Number与所有其他值都不相等,包括它自己

NaN == NaN; // false

2). String

字符串是以单引号(')或者双引号(")括起来的任意字符,单引号和双引号基本上没有区别,你喜欢。个人建议,JavaScript里面的字符串都统一使用单引号(原因是 少敲一个Shift键,捂脸~~~)

'this is a string';   // this is a string

3). Boolean

布尔值只有两种可能,true 和 false,通常是由比较运算表达式得到,e.g.

2>1;  // trure
2>3; // false

4). null & undefined

JavaScript的设计者希望用null表示一个空的值,而undefined表示值未定义。事实证明,这并没有什么卵用,区分两者的意义不大。大多数情况下,我们都应该用null。

另外:null 也是一个特殊的对象,由 typeof(null) 可以得知

5). 对象(object)

JavaScript的对象是一组由键-值组成的无序集合,e.g:

var student = {
name: 'Michael',
age: 20,
sex: 'man'
};

6). 数组(Array)

数组是一组按顺序排列的集合,集合的每个值称为元素。JavaScript的数组可以包括任意数据类型。e.g.

[1, 2, 3, '4', false, {x: 1, y: 2}, [7, 8]];

这个数组包含了7个元素,其中类型有 数字,字符串,布尔值,对象,数组

7). 函数(funciton)

函数是可供其他程序调用的一个功能模块

function f() {
alert("Hello world!");
}

标识符和保留字

标识符:JavaScript 标识符必须以字母,或者下划线(_),或者美元符号($)开始,后面可以是任意可用字符

保留字:不能使用下面这些作为你的变量

break, case, catch, continue, debugger, default, delete, do,
else, false, finally, for, function, if, in, instanceof, new, null
return, switch, this, throw, true, try, typeof, var, void, while, with

如何声明变量呢?

使用关键字 var 声明变量。
调用声明但未初始化的变量返回undefined,调用未声明的变量会出现引用错误(ReferenceError)

var a = 10;
var b; console.log(a); //
console.log(b); // undefined
console.log(c); // ReferenceError

变量的作用域

一个变量的作用域(scope)是代码中定义这个变量的区域,有两种:

全局变量:在代码中任何地方都可见
局部变量:只在函数内部可见

在函数体内,局部变量优先级高于全局变量。e.g.

var scope = "global var";
function f(){
var scope = "local var";
console.log(scope);
} f(); // "local var"
console.log(scope); // "global var"

这里有一点要非常注意的:即使在函数内部,你也要使用 var 关键字来声明变量,否则它会变成全局变量。e.g.

var scope = "global var";
function f(){
scope = "local var"; // 这里忘记使用var关键字,因此这将会声明一个全局的变量,即使它在函数内执行
console.log(scope);
} f(); // "local var"
console.log(scope); // "local var"

有个规定:所有需要用到的变量都应该在函数体顶部声明,而不是在要用到的时候才声明

JavaScript 基本语法 -- 数据类型 & 变量的更多相关文章

  1. javascript基础语法备忘录-变量和数据类型

    //javascript基础语法备忘录-变量和数据类型 // 定义变量使用var关键字 后面跟变量名,不要使用eval 和arguments为变量名 var message = "hi&qu ...

  2. javascript基本语法和变量(转)

    转载来自 阮一峰老师的文章,地址为:http://javascript.ruanyifeng.com/grammar/basic.html#toc0 1.1语句 JavaScript 程序的执行单位是 ...

  3. C语言笔记 02_基本语法&数据类型&变量

    基本语法 令牌 C 程序由各种令牌组成,令牌可以是关键字.标识符.常量.字符串值,或者是一个符号.例如,下面的 C 语句包括五个令牌: printf("Hello, World! \n&qu ...

  4. Java学习笔记之基础语法(数据类型)

    8种基本数据类型    整型:   byte[1字节]          short[2字节]        int[4字节]         long[8字节]      1,四种整型之间的区别:申 ...

  5. 学习 JavaScript (三)核心概念:语法、变量、数据类型

    JavaScript 的核心概念主要由语法.变量.数据类型.操作符.语句.函数组成,这篇文章主要讲解的是前面三个,后面三个下一篇文章再讲解. 01 语法 熟悉 JavaScript 历史的人应该都知道 ...

  6. Javascript用途,语法特点,难点,调试工具,引入方式,命名规范,变量声明及赋值,数据类型,运算符

    JavaScript用来干什么 数据的验证 将动态的内容写入到网页当中(ajax) 对事件做出相应 读写html当中的内容 检测浏览器 创建cookies 模拟动画 语法特点 基于对象和事件驱动的松散 ...

  7. javascript基础语法——变量和标识符

    × 目录 [1]定义 [2]命名规则 [3]声明[4]特性[5]作用域[6]声明提升[7]属性变量 前面的话 关于javascript,第一个比较重要的概念是变量,变量的工作机制是javascript ...

  8. JAVA学习(三):Java基础语法(变量、常量、数据类型、运算符与数据类型转换)

    Java基础语法(变量.常量.数据类型.运算符与数据类型转换) 1.变量 Java中.用户能够通过指定数据类型和标识符来声明变量.其基本的语法为: DataType identifier; 或 Dat ...

  9. Javascript语法,变量类型,条件,循环语句,函数,面向对象

    1.JavaScript代码革两种存在形式: <!-- 方式一 --> <script type='txt/javascript' src='/js/comment.js'>& ...

随机推荐

  1. MQTT Server搭建(apache-apollo)和MQtt Client搭建

    目标 本文就MQTT server和client搭建做以下总结,方便测试及开发使用,能基于MQTT软件发送和接收消息. 介绍 MQTT是基于tcp的消息发送,目前JAVA方面有两种实现,分别是mqtt ...

  2. NOIP2017游记

    日常大考之前感冒(这次感冒了3周..) Day -4~Day 0 停课一周,不写作业不上课是很爽,然而想到NOIP结束第二天就要期中考.. 在学校刷刷题,跟着一大堆大佬的步伐,做着一大堆大佬的题目(其 ...

  3. html笔记2

    html css的用法 <style type="text/css">代表我要使用css了 <html> <head> <style ty ...

  4. 1492: [NOI2007]货币兑换Cash

    Description 小Y最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A纪念券(以下简称A券)和 B纪念券(以下 简称B券).每个持有金券的顾客都有一个自己的帐户.金券的数目可以是一个 ...

  5. Flume环境搭建_五种案例

    Flume环境搭建_五种案例 http://flume.apache.org/FlumeUserGuide.html A simple example Here, we give an example ...

  6. Laravel5.5 的 Homestead 开发环境部署

    首先明白以下几个概念 VirtualBox  -- Oracle 公司的虚拟机软件, 能运行在当前大部分流行的系统上; Vagrant 提供一种命令行接口, 允许自动化安装虚拟机, 并且因为是脚本编写 ...

  7. IntelliJ IDEA 2016.2.x 激活

    注册码获取:http://idea.lanyus.com/

  8. vue中组件之间的相互调用,及通用后台管理系统左侧菜单树的迭代生成

    由于本人近期开始学习使用vue搭建一个后端管理系统的前端项目,在左侧生成菜单树的时候遇到了一些问题.在这里记录下 分析:由于本人设定的菜单可以使多级结构,直接使用vue的v-for 遍历并不是很方便. ...

  9. mysql-冗余和重复索引

    mysql允许在相同列上创建多个索引,无论是有意还是无意,mysql需要单独维护重复的索引,并且优化器在优化查询的时候也需要逐个地进行考虑,这会影响性能. 重复索引是指的在相同的列上按照相同的顺序创建 ...

  10. Centos7-安装telnet服务

    1,检查是否安装 telnet-server和xinetd rpm -qa telnet-server rpm -qa xinetd 2,如果没有安装过就安装 查找yum yum list |grep ...