前端-JavaScript1-3——JavaScript之字面量

字面量??????

字面量:英语叫做literals,有些书上叫做直接量。看见什么,它就是什么。

我们先来学习数字的字面量,和字符串的字面量。剩余的字面量类型,我们日后遇见再介绍。

3.1 数字的字面量

数字的字面量,就是这个数字自己,并不需要任何的符号来界定这个数字。

JavaScript中,数字的字面量可以有三种进制:

10进制:普通的数字就是十进制

8进制:如果以0开头、或者以0o开头、或者以0O开头的都是八进制,八进制只能用0~7来表示

16进制:如果以0x开头的都是十六进制。

八进制举例:

1        <script type="text/javascript">

2            //以0开头,所以就是八进制;显示的时候会以十进制显示

3           //3*8+6=30

4           console.log(036); //30

5           console.log(044);  //36

6           console.log(010);  //8

7           console.log(0o36); //30

8           console.log(0O36); //30

9        </script>

运行结果:

30

36

8

30

30

注意,八进制只能出现0~7这8中字符,如果表示不合法,那么JS将自动的认为你输入错了,从而用十进制进行显示:

1    console.log(088);  //以0开头,按理说是八进制,但是后面的数字错了,所以以十进制显示

输出  88

但是以0o开头、0O开头的数字,如果后面写错了,控制台报错!

1    console.log(0o88);

再看一下16进制:

1    console.log(0xff);

2    console.log(0x2b);

3    console.log(0x11);

运行结果:

255

43

17

如果后面有错误的写法,那么控制台报错:

1    console.log(0x2m);

总结一下,下面的输出结果都是15:

1    console.log(15);

2    console.log(017);

3    console.log(0o17);

4    console.log(0O17);

5    console.log(0xf);

下面的输出结果都是负15:

6    console.log(-15);

7    console.log(-017);

8    console.log(-0o17);

9    console.log(-0O17);

1    console.log(-0xf);

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

允许使用e来表示乘以10的几次幂

1    console.log(-3.1415926);  //-3.1415926

2    console.log(.315);       //.315 如果整数位数是0,可以不写

3    console.log(5e5);         //500000

4    console.log(5.6e5);      //560000

5    console.log(1e-4);        //0.0001

6    console.log(.1e-3);      //0.0001

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

最后学习两个特殊的字面量:

Infinity 无穷大

试图输出一个非常大的数字(比如):

1    console.log(3e45645645645645);

至于多大的数字能生成无穷大,不同浏览器不一样,不要管。

可以是负的无穷大:

1    console.log(-3e45645645645645);

我们可以直接在控制台输出无穷大,注意大小写:

1    console.log(Infinity);

NaN 英语全名叫做not a number,不是一个数。比较哲学的是,这个“不是一个数”是一个数字字面量。

1    console.log(0/0);

总结一下,数字字面量有整数字面量(十进制、16进制、八进制),浮点数字面量(要记住e),Infinity,NaN

3.2 字符串

字符串是一个术语,就是人类说的语句、词。

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

1    console.log("今天天气很好");

1    //  必须是同种引号,这是错误的:

2    console.log('哈哈");

如果一个数字,用引号引起来,那么就是字符串了:

1    console.log(“3”);

转义字符,

\n 回车换行

\t tab缩进

1    alert("你好\n\n我很爱你\n啊");

引号的转译:

正常情况下,引号内部可以有不同种的引号,比如双引号里面可以有单引号:

1    console.log("老师说你像'考拉'一样漂亮");

可以用\” 来表达引号:

1    console.log("老师说你像\"考拉\"一样漂亮");

反斜杠自己也用反斜杠来转义:

1    console.log("c:\\a\\b.jpg");

OK就是这样下面是一些参考代码

这个是数字的字面量的模样,呃,不算漂亮。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>Document</title>
<script type="text/javascript">
// 以0开头,所以就是八进制;显示的时候会以十进制显示 // console.log(036); //3*8+6=30 ,显示30
// console.log(044); //4*8+4=36 ,显示36
// console.log(010);
// console.log(0o36);
// console.log(0O36); // 注意,八进制中只有0~7这几个数字,不能有8、9
// 如果写错了,将当做10进制
// console.log(088); //显示88 // 如果是0o开头的,后面的数字错了,对不起,不转为10进制了,控制台报错!
// console.log(0o88); //报错
// console.log(0O88); //报错 // 十六进制:
// console.log(0xff); //255
// console.log(0x2b); //43
// console.log(0x2m); //报错 // 总结下面的数字都是-15
// console.log(-15);
// console.log(-017);
// console.log(-0o17);
// console.log(-0O17);
// console.log(-0xf); // 浮点数:
// console.log(-3.1415926); //-3.1415926
// console.log(.315); //.315 如果整数位数是0,可以不写
// console.log(5e5); //500000
// console.log(5.6e5); //560000
// console.log(1e-4); //0.0001
// console.log(.1e-3); //0.0001 // 非常小的数字,负无穷大
// console.log(-3e45645645645645); // 输出无穷大
// console.log(Infinity); // 输出NaN
// console.log(0/0);
</script>
</head>
<body> </body>
</html>

以及字符串的字面量的样子

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>Document</title>
<script type="text/javascript">
// 字符串用双引号包裹,或者单引号
// console.log("今天天气很好");
// console.log('今天天气很好'); // 不能不加引号,这是错误的:
// console.log(今天天气很好); // 必须是同种引号,这是错误的:
// console.log('哈哈"); // 一个数字如果加上了引号,那么就是字符串了
// console.log("老王,你中午吃了几碗饭?");
// console.log("3"); //转义字符
//alert("你好\n啊\n我很爱你\n啊"); // 引号的转义
// console.log("老师说你像\"考拉\"一样漂亮"); console.log("c:\\a\\b.jpg");
</script>
</head>
<body> </body>
</html>

这一篇文章到此over,下一篇走起。

上一篇:转载:Practical UML™: A Hands-On Introduction for Developers


下一篇:Servlet/JSP-03 HttpServlet