变量,数据类型及类型转换

一.直面量(字面量)

字面量:英语叫做literal,也叫做直接量. 看见什么,他就是什么

1.数字的字面量

数字的字面量,就是这个数字自己

1.1整数

三种进制
整数可以被表示成十进制(基数为10)、十六进制(基数为16)以及八进制(基数为8)

10进制:十进制整数字组成的数字序列,
8进制:带前导0、0O、0o 的整数字面值表明它是八进制。八进制整数只能包括数字0-7。
16进制:如带前导0x,0X开头的就是十六进制。十六进制整数可以包含(0-9)和字母 a-f 或 A-F

// 八进制  最终显示是以十进制方式显示
alert(015)   // 1*8 + 5  =  13
alert(017)     // 1*8 + 7 *1 =15
alert(0o21)     // 2*8 + 1 *1 =17
alert(0O21);    // 2*8 + 1 *1 =17

八进制0-7这八个数字,如果小时不合法,js还自动给你转成10进制,转不了就报错

console.log(088);  //88
// 按理说以0开头是八进制,但是后面数字写错了,所以以十进制方式限制

如果以0o或0O开头的八进制将报错

console.log(0o88);  // 报语法错误
console.log(0O88);   // 报语法错误
1.2 浮点数(小数或指数)

小数的字面量也很简单,就是数学上的点。计算机世界中,小数称为“浮点数”。

浮点数字面值可以有以下的组成部分:

一个十进制整数,它可以带符号(即前面的“+”或“ - ”号),如果整数部分是0可以不写
一个小数点
一个小数部分(由一串十进制数表示),
一个指数部分

console.log(3.14159269);
console.log(5e4);       //50000
console.log(5e-4)       //0.0005

注意

只有十进制有小数的字面量,八进制、十六进制没有小数的字面量。所以小数没有进制之分

1.3特殊字面量

Infinity 无穷大

Infinity 用于存放表示正无穷大的数值。
-Infinity 用于存放表示负无穷大的数值。

console.log(3e31415926);     // Infinity

NaN
英语全名叫做not a number,不是一个数。

console.log(0/0);   // NaN
1.4 总结一下
  • 数字字面量有整数字面量(十进制,十六进制,八进制)
  • 浮点数字面量(记住e)
  • 特殊字面量:Infinity ,NaN

2.字符串的字面量

字符串是一个术语,说白了就是我们人说的话。

2.1 字符串字面量的书写方式

字符串的字面量有限定符,就是必须用双引号、单引号包裹起来。字符串被限定在同种引号之间;也就是说,必须是成对单引号或成对双引号。

console.log("今天你好帅哦");

2.2 特殊字符

在字符串中可以使用一些特殊字符,他们有特定的含义

\n New line 换行符
\t Tab tab缩进

但是可以使用字符串中可以使用转义字符,

' 单引号
\” 双引号
\ 反斜杠

二.变量

变量(Variables),和高中数学中的x、y、z很像,它们此时不是字母,而是蕴含值的符号。

什么是变量呢?

就是值可以变化的符号,能够存储JS不同数据类型的值

1.变量声明

使用关键词var

var a;  // 声明一个变量a

所谓关键字,就是有特殊功能的小词语。关键字后面一定要有空格隔开.

2.变量命名规则

变量的名字就是标识符(identifiers),任何标识符的命名都需要遵守一定的规则:

JS中标识符的定义规则,可先理解为变量的规则,以后我们还会接触到其他标识符

  • 由字母、下划线(_)、美元($)符号、数字(0-9)组成

  • 但不能以数字开头

也就是说,一个标识符必须由字母、下划线、美元符号开头,后续可以有字母、下划线、美元符号、数字

  • 严格区分大小写

所以A和a不是同一个变量

  • 不要使用中文变量名

  • 不能使用关键字和保留字

关键字=>js已经赋予特殊功能的字 保留字=>js预订可能未来要使用的字

关键字:

JS语法中有特殊意义的词

break、else、new、var、 case、 finally 、 return、 void 、 catch 、for 、switch 、 while 、 continue、 function 、this 、 with 、default 、 if 、 throw 、 delete 、 in 、 try 、do 、 instranceof、 typeof

保留字:

JS语法中现在不存在,但是以后会成为关键字的单词(替补关键词)

abstract 、 enum 、int 、 short 、 boolean 、export 、interface、 static、 byte 、extends 、 long 、 super 、 char 、 final 、native 、synchronized 、 class 、float 、 package 、throws 、 const 、goto 、private 、transient 、 debugger 、 implements 、protected 、 volatile 、 double 、import 、public

3.变量的赋值

等号表示赋值,会将等号右边的值,赋给左边的变量.

var a;   //定义
    a = 200;   //赋初值
console.log(a)

运行结果:200

3.1 可以将变量定义和赋值写在一起
var a = 200;
3.2 定义变量为赋值

用var 声明的未赋值的变量,值会被设定为undefined

var a;
console.log(a);

注意:
变量只需要var一次,今后更改变量的值,无需重复var,如果多次定义也不会报错

4.变量声明的提升

JavaScript 变量的另一特别之处是,你可以引用稍后声明的变量,而不会引发异常。这一概念称为变量声明提升.JavaScript 变量感觉上是被“举起”或提升到了所有函数和语句之前。然而提升后的变量将返回 undefined 值,所以即使在使用或引用某个变量之后存在声明和初始化操作,仍将得到 undefined 值。

5.不写var的情况

我们可以直接使用一个变量,直接给它赋值,不写var。系统不会报错,但是这样做,以后你会发现有后遗症:这个变量不是局部变量,而是一个全局变量。

a = 33;
console.log(a);
6.同时定义多个变量

定义多个变量时,中间用逗号隔开

var a = 7 , b = 9 , c = 10;
7.区分变量还是直接量

变量的时候,不能加引号。如果变量加上引号,就变成字符串的直接量了。

var a = 200;
console.log("a");     //a

引号是“字符串”的定界符,所以在双引号里面的a已经失去了变量的意思,就是一个字符串a。

三.数据类型

JavaScript中的值,无论是字面量还是变量,都有明确的类型。

1.概述

1.1基本类型5种

number 数字类型
string 字符串类型
boolean 布尔类型,true和false两个值
undefined undefined类型,只有一个值就是undefined
null null类型 只有一个值null

1.2 引用类型

{} 普通对象
[] 数组对象
function 函数对象

2.数据类型的检测

使用typeof关键字检查数据类型,通常用来检测变量的类型,因为直接量的类型一眼就看的出来

console.log(typeof 123);       //number
console.log(typeof "haha");       //string

四.运算符: 加号 +

加法运算符(+)在设计数字和字符串运算的表达式中,JavaScript 会把数字值转换为字符串。

在其它类型数据运算时,JavaScript语言不会把数字变为字符串。

1.转number()

有一些方法可以将内存中表示其他数据类型转换为对应的数字

  • number()

1.string "12px" => NaN => 0
2.boolean true => 1 false => 0
3.null null=>0
undefined undefined => NaN

Number('hello world')  //NaN
  • parseInt()
    paseInt仅能够返回整数,所以使用它会丢失小数部分
parseInt("250,231")     //250

另外,调用 parseInt 时最好总是带上进制(radix) 参数,这个参数用于指定使用哪一种数制

parseInt(17,8);      // 15
  • parseFloat()

parseFloat就是将字符串转为浮点数

尽可能的将一个字符串转为浮点数

 console.log(parseFloat(123.456.888));   //123.456

也就是说,数字类型都是number,不分整数和浮点数,但是转换的+时候分。

  • 正负运算符
console.log(+'88');

正负号转换为数字是内部调用为了Number方法

2.转string

  • + 号运算符

将一个数字,与一个空字符串进行连字符运算,那么就是自动转为字符串了。

var a = 123;
var b = a + "";
console.log(b); //123
console.log(typeof b);//string

3.转boolean

  • Boolean() 方法

只有六种情况Boolean(被转换的数据)的结果是false,其余全是true

  1. 0 数字0
  2. NaN 数字NaN
  3. "" 空字符串
  4. false 布尔值false
  5. undefined undefined类型
  6. null null类型

总结:
alert("您好");

prompt("请输入数字","默认值");

console.log("您好");

Number(“33”)

parseInt("250",8);

parseFloat("250.666");

Boolean("")

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351