JavaScript 基本语法 -- 数据类型 & 变量
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 基本语法 -- 数据类型 & 变量的更多相关文章
- javascript基础语法备忘录-变量和数据类型
//javascript基础语法备忘录-变量和数据类型 // 定义变量使用var关键字 后面跟变量名,不要使用eval 和arguments为变量名 var message = "hi&qu ...
- javascript基本语法和变量(转)
转载来自 阮一峰老师的文章,地址为:http://javascript.ruanyifeng.com/grammar/basic.html#toc0 1.1语句 JavaScript 程序的执行单位是 ...
- C语言笔记 02_基本语法&数据类型&变量
基本语法 令牌 C 程序由各种令牌组成,令牌可以是关键字.标识符.常量.字符串值,或者是一个符号.例如,下面的 C 语句包括五个令牌: printf("Hello, World! \n&qu ...
- Java学习笔记之基础语法(数据类型)
8种基本数据类型 整型: byte[1字节] short[2字节] int[4字节] long[8字节] 1,四种整型之间的区别:申 ...
- 学习 JavaScript (三)核心概念:语法、变量、数据类型
JavaScript 的核心概念主要由语法.变量.数据类型.操作符.语句.函数组成,这篇文章主要讲解的是前面三个,后面三个下一篇文章再讲解. 01 语法 熟悉 JavaScript 历史的人应该都知道 ...
- Javascript用途,语法特点,难点,调试工具,引入方式,命名规范,变量声明及赋值,数据类型,运算符
JavaScript用来干什么 数据的验证 将动态的内容写入到网页当中(ajax) 对事件做出相应 读写html当中的内容 检测浏览器 创建cookies 模拟动画 语法特点 基于对象和事件驱动的松散 ...
- javascript基础语法——变量和标识符
× 目录 [1]定义 [2]命名规则 [3]声明[4]特性[5]作用域[6]声明提升[7]属性变量 前面的话 关于javascript,第一个比较重要的概念是变量,变量的工作机制是javascript ...
- JAVA学习(三):Java基础语法(变量、常量、数据类型、运算符与数据类型转换)
Java基础语法(变量.常量.数据类型.运算符与数据类型转换) 1.变量 Java中.用户能够通过指定数据类型和标识符来声明变量.其基本的语法为: DataType identifier; 或 Dat ...
- Javascript语法,变量类型,条件,循环语句,函数,面向对象
1.JavaScript代码革两种存在形式: <!-- 方式一 --> <script type='txt/javascript' src='/js/comment.js'>& ...
随机推荐
- loadrunner中如何将MD5加密的值转换为大写
上篇博客中写过如何将MD5加密,但是我们在实际的测试过程中可能需要将加密的结果进行大小写转换.我在这次的测试过程中就遇见了这样的问题, 我在测试时发现开发人员代码传的sign值是大写,而我加密出来的s ...
- python解析域名
#coding:utf-8 import socket def URL2IP(): for oneurl in urllist.readlines(): url=str(oneurl.strip()) ...
- 信息学奥赛一本通算法(C++版)基础算法:高精度计算
高精度加法(大位相加) #include <bits/stdc++.h> using namespace std; int main() { ],b1[]; ],b[],c[];//a,b ...
- [ZOJ3256] Tour in the Castle
插头DP+矩阵乘法 m喜闻乐见地达到了10^9级别..而n<=7,并且没有障碍..所以列与列之间的转移时一样的..就可以上矩乘了. 感觉自己快没救了..看半天题解还是不懂.. http://ww ...
- 斐波那契数列 Library
http://acm.tju.edu.cn/toj/showp3267.html3267. Library Time Limit: 1.0 Seconds Memory Limit: 6553 ...
- RabbitMQ 使用demo
1.新建一个控制台应用程序:如图 2.代码如下: using RabbitMQ.Client;using RabbitMQ.Client.Events;using System;using Syste ...
- [国嵌笔记][005][Linux命令详解]
用户管理类命令 添加用户:useradd name 删除用户:userdel -r name "-r"表示删除对应用户的目录 修改密码:passwd name 切换用户:su - ...
- 关于Set对象(ES6)
今天初次接触ES6,发现确实挺神奇的,许多用以前方法去实现需要一大串代码的,用ES6竟然几句就搞定了. 这里我要说的是Set对象.Set对象是ES6中新增的类型,可以自动排除重复项,生成Set对象后, ...
- PHP安全之webshell和后门检测
基于PHP的应用面临着各种各样的攻击: XSS:对PHP的Web应用而言,跨站脚本是一个易受攻击的点.攻击者可以利用它盗取用户信息.你可以配置Apache,或是写更安全的PHP代码(验证所有用户输入) ...
- 跟我一起读postgresql源码(十三)——Executor(查询执行模块之——Join节点(上))
Join节点 JOIN节点有以下三种: T_NestLoopState, T_MergeJoinState, T_HashJoinState, 连接类型节点对应于关系代数中的连接操作,PostgreS ...