廖雪峰JS
Posted 山有扶苏
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了廖雪峰JS相关的知识,希望对你有一定的参考价值。
一、JS代码可以嵌在网页任何地方不过一般放在<head>里面
<head> <script> alert(‘Hello, world‘); </script> </head>
或者(多个页面可以引用同一个js文件,一个页面可以引用多个js文件)
<head> <script src="/static/js/abc.js"></script> </head>
二、调试
打开网页console,可以输入js代码,回车执行。
要查看一个变量内容,输入console.log(a);回车显示变量内容。
如果你对自己还有更高的要求,可以研究开发者工具的“源码(Sources)”,掌握断点、单步执行等高级调试技巧。
三、基本语法(不建议一行代码有两个语句)
下面一行代码是一个完整的赋值语句:
var x=1;
下面一行代码是一个字符串,可以视为一个完整的语句:
‘Hello, world‘;
四、数据类型和变量
number
123; // 整数123 0.456; // 浮点数0.456 1.2345e3; // 科学计数法表示1.2345x1000,等同于1234.5 -99; // 负数 NaN; // NaN表示Not a Number,当无法计算结果时用NaN表示 Infinity; // Infinity表示无限大,当数值超过了javascript的Number所能表示的最大值时,就表示为Infinity
计算机由于使用二进制,所以,有时候用十六进制表示整数比较方便,十六进制用0x前缀和0-9,a-f表示,例如:0xff00,0xa5b4c3d2,等等,它们和十进制表示的数值完全一样。
1 + 2; // 3 (1 + 2) * 5 / 2; // 7.5 2 / 0; // Infinity 0 / 0; // NaN 10 % 3; // 1 10.5 % 3; // 1.5
字符串
引号括起来的任意文本,单引号双引号都一样。
布尔值
&&与运算,||或运算,!非运算
比较运算符
实际上,JS允许对任意数据类型做比较
false == 0; // true false === 0; // false
相等运算符==
第一种是==比较,它会自动转换数据类型再比较,很多时候,会得到非常诡异的结果;
第二种是===比较,它不会自动转换数据类型,如果数据类型不一致,返回false,如果一致,再比较。
另一个例外是NaN这个特殊的Number与所有其他值都不相等,包括它自己:
NaN === NaN; // false
唯一能判断NaN的方法是通过isNaN()函数:
isNaN(NaN); // true
最后要注意浮点数的相等比较:
1 / 3 === (1 - 2 / 3); // false
这不是JavaScript的设计缺陷。浮点数在运算过程中会产生误差,因为计算机无法精确表示无限循环小数。要比较两个浮点数是否相等,只能计算它们之差的绝对值,看是否小于某个阈值:
Math.abs(1 / 3 - (1 - 2 / 3)) < 0.0000001; // true
null和undefined
0是一个数值,‘‘表示长度为0的字符串,而null表示“空”。
大多数情况下,我们都应该用null。undefined仅仅在判断函数参数是否传递的情况下有用。
数组
数组是一组按顺序排列的集合,集合的每个值称为元素。JavaScript的数组可以包括任意数据类型。例如:[1, 2, 3.14, ‘Hello‘, null, true];
另一种创建数组的方法是通过Array()函数实现:
new Array(1, 2, 3); // 创建了数组[1, 2, 3]
数组的元素可以通过索引来访问。请注意,索引的起始值为0:
arr[6]; // 索引超出了范围,返回undefined
对象
JavaScript的对象是一组由键-值组成的无序集合,例如:
var person = { name: ‘Bob‘, age: 20, tags: [‘js‘, ‘web‘, ‘mobile‘], city: ‘Beijing‘, hasCar: true, zipcode: null };
要获取一个对象的属性,我们用对象变量.属性名的方式:
person.name; // ‘Bob‘ person.zipcode; // null
变量
变量名是大小写英文、数字、$和_的组合,且不能用数字开头。变量名也不能是JavaScript的关键字,如if、while等。
strict模式
如果一个变量没有通过var申明就被使用,那么该变量就自动被申明为全局变量
使用var申明的变量则不是全局变量,它的范围被限制在该变量被申明的函数体内(函数的概念将稍后讲解),同名变量在不同的函数体内互不冲突。
启用strict模式的方法是在JavaScript代码的第一行写上:
‘use strict‘;
以上是关于廖雪峰JS的主要内容,如果未能解决你的问题,请参考以下文章