###一、JavaScript基本介绍及发展趋势
ES5是2019年发布,在所有现代浏览器中得到了相当完全的实现
###二、编写JS及如何运行JS
1.在HTML普通标签中直接写入JS代码
写在标签上的 js 代码需要依靠事件(行为)来触发
点击一下试试
点一下试试看
2.在HTML文档中写入代码(script标签)
内嵌式的 js 代码会在页面打开的时候直接触发
3.在*.js文件中写入JS代码
外链式 js 代码只要引入了 html 页面,就会在页面打开的时候直接触发
// 我是 index.js 文件
alert('我是一个弹出层')
###三、变量及命名规则
####1.变量的申明与定义
var a = 10
let b = 10 //ES6 新增
const c = 10 //ES6 新增
####2.变量的命名规则
####3.关键字
var
、let
、const
、break
、case
、catch
、continue
、default
、delete
、do
、else
、finally
、for
、function
、if
、in
、instanceof
、new
、return
、switch
、this
、throw
、try
、typeof
、void
、while
、with
###四、数据类型
####1. 基础数据类型
NaN
(not a number),一个非数字 var a = 1;// typeof a;->number
字符串类型(string)
var str = 'hello'//typeof str ->string
布尔类型(boolean)
true
或者 false
)null类型(null)
null
,表示空的意思undefined类型(undefined)
undefined
,表示没有值的意思####2. 复杂数据类型object
####3. 判断数据类型
typeof
关键字来进行判断// 第一种使用方式
var n1 = 100;
console.log(typeof n1);//number // 第二种使用方式
var s1 = 'abcdefg';
console.log(typeof(s1));//string
console.log(typeof typeof n1);//string
console.log (typeof true);//boolean
console.log( typeof null);//object
console.log( typeof undefined);//undefined
console.log( typeof {});//object
####4. 判断一个变量是不是数字
isNaN
这个方法来判断一个变量是不是 不是数字isNaN
:is not a number
// 如果变量是一个数字
var n1 = 100;
console.log(isNaN(n1)); //=> false// 如果变量不是一个数字
var s1 = 'Jack'
console.log(isNaN(s1)); //=> true
####5. 数据类型转换
####6. 其他数据类型转成数值
Number(变量)
NaN
(出现字母)parseInt(变量)
NaN
parseFloat(变量)
从第一位开始检查,是数字就转换,直到一个不是数字的内容
开头就不是数字,那么直接返回 NaN
除了加法以外的数学运算
NaN
####7. 其他数据类型转成字符串
变量.toString()
toString()
方法,比如 undefined
和 null
String(变量)
+
由两个含义+
任意一边是字符串,就会进行字符串拼接+
两边都是数字的时候,才会进行数学运算####8. 其他数据类型转成布尔
Boolean(变量)
''
、0
、null
、undefined
、NaN
,这些是 false
,其余都是 true
就是在代码里面进行运算的时候使用的符号,不光只是数学运算,我们在 js
里面还有很多的运算方式
算术运算符
####1. 算术运算符
+
-
会执行减法运算
会自动把两边都转换成数字进行运算
*
/
%
**
2**4----- 2的4次方
比较运算符
####2. 赋值运算符
=
=
右边的赋值给等号左边的变量名var num = 100
+=
var a = 10;
a += 10;// a = a + 10
console.log(a); //=> 20
a += 10
等价于 a = a + 10
-=
var a = 10;
a -= 10;
console.log(a); //=> 0
a -= 10
等价于 a = a - 10
*=
var a = 10;
a *= 10;
console.log(a); //=> 100
a *= 10
等价于 a = a * 10
/+
var a = 10;
a /= 10;
console.log(a); //=> 1
a /= 10
等价于 a = a / 10
%=
var a = 10;
a %= 10;
console.log(a); //=> 0
a %= 10
等价于 a = a % 10
####3. 赋值运算符
==
1 == '1'
true
===
1 === '1'
false
!=
1 != '1'
false
!==
1 !== '1'
true
>=
1 >= 1
结果是 true
1 >= 0
结果是 true
1 >= 2
结果是 false
<=
1 <= 2
结果是 true
1 <= 1
结果是 true
1 <= 0
结果是 false
>
1 > 0
结果是 true
1 > 1
结果是 false
1 > 2
结果是 false
<
1 < 2
结果是 true
1 < 1
结果是 false
1 < 0
结果是 false
&&
and
true
并且右边也是 true
,才会返回 true
true
,那么就会返回 false
true && true
结果是 true
true && false
结果是 false
false && true
结果是 false
false && false
结果是 false
||
or
true
或者右边为 true
,都会返回 true
false
的时候才会返回 false
true || true
结果是 true
true || false
结果是 true
false || true
结果是 true
false || false
结果是 false
!
非
true
的,会变成 false
false
的,会变成 true
!true
结果是 false
!false
结果是 true
++
进行自增运算
分成两种,前置++ 和 后置++
前置++,会先把值自动 +1,在返回
var a = 10;
console.log(++a);//++a 表达式的值的
// 会返回 11,并且把 a 的值变成 11
后置++,会先把值返回,在自动+1
var a = 10;
console.log(a++);//a++ 表达式的值的
// 会返回 10,然后把 a 的值变成 11
--
++
运算符道理一样###六、条件语句
####1. if 语句
通过一个 if
语句来决定代码是否执行
语法: if (条件) { 要执行的代码 }
通过 ()
里面的条件是否成立来决定 {}
里面的代码是否执行
// 条件为 true 的时候执行 {} 里面的代码
if (true) {alert('因为条件是 true,我会执行')
}// 条件为 false 的时候不执行 {} 里面的代码
if (false) {alert('因为条件是 false,我不会执行')
}
// 如果代码块中代码只有一句,可以把花括号省略
####2. if else 语句
通过 if
条件来决定,执行哪一个 {}
里面的代码
语法: if (条件) { 条件为 true 的时候执行 } else { 条件为 false 的时候执行 }
两个 {}
内的代码一定有一个会执行
// 条件为 true 的时候,会执行 if 后面的 {}
if (true) {alert('因为条件是 true,我会执行')
} else {alert('因为条件是 true,我不会执行')
}// 条件为 false 的时候,会执行 else 后面的 {}
if (false) {alert('因为条件为 false,我不会执行')
} else {alert('因为条件为 false,我会执行')
}
可以通过 if
和 else if
来设置多个条件进行判断
语法:if (条件1) { 条件1为 true 的时候执行 } else if (条件2) { 条件2为 true 的时候执行 }
会从头开始依次判断条件
true
了,那么就会执行后面的 {}
里面的内容false
,那么就会判断第二个条件,依次类推多个 {}
,只会有一个被执行,一旦有一个条件为 true
了,后面的就不在判断了
// 第一个条件为 true,第二个条件为 false,最终会打印 “我是代码段1”
if (true) {alert('我是代码段1')
} else if (false) {alert('我是代码段2')
}// 第一个条件为 true,第二个条件为 true,最终会打印 “我是代码段1”
// 因为只要前面有一个条件满足了,就不会继续判断了
if (true) {alert('我是代码段1')
} else if (true) {alert('我是代码段2')
}// 第一个条件为 false,第二个条件为 true,最终会打印 “我是代码段2”
// 只有前一个条件为 false 的时候才会继续向后判断
if (false) {alert('我是代码段1')
} else if (true) {alert('我是代码段2')
}// 第一个条件为 false,第二个条件为 false,最终什么也不会发生
// 因为当所有条件都为 false 的时候,两个 {} 里面的代码都不会执行
if (false) {alert('我是代码段1')
} else if (false) {alert('我是代码段2')
}
和之前的 if else if ...
基本一致,只不过是在所有条件都不满足的时候,执行最后 else
后面的 {}
// 第一个条件为 false,第二个条件为 false,最终会打印 “我是代码段3”
// 只有前面所有的条件都不满足的时候会执行 else 后面的 {} 里面的代码
// 只要前面有一个条件满足了,那么后面的就都不会执行了
if (false) {alert('我是代码段1')
} else if (false) {alert('我是代码段2')
} else {alert('我是代码段3')
}
也是条件判断语句的一种
是对于某一个变量的固定值判断
语法:
/*switch (要判断的变量) {case 情况1: //要判断的变量 === 情况1 情况1要执行的代码breakcase 情况2:情况2要执行的代码breakcase 情况3:情况3要执行的代码breakdefault:上述情况都不满足的时候执行的代码}default 默认case 情况break 中断switch 开关*/
var week = 1switch (week) {case 1://week===1alert('星期一')breakcase 2:alert('星期二')breakcase 3:alert('星期三')breakcase 4:alert('星期四')breakcase 5:alert('星期五')breakcase 6:alert('星期六')breakcase 7:alert('星期日')breakdefault:alert('请输入一个 1 ~ 7 之间的数字')}
三元运算,就是用 两个符号 组成一个语句
三元运算只是对 if else 语句的一个简写形式
语法: 条件 ? 条件为 true 的时候执行 : 条件为 false 的时候执行
var age = 18;
age >= 18 ? alert('已经成年') : alert('没有成年')
###七、循环结构
####1. FOR 循环
和 while
和 do while
循环都不太一样的一种循环结构
道理是和其他两种一样的,都是循环执行代码的
语法: for (var i = 0; i < 10; i++) { 要执行的代码 }
// 把初始化,条件判断,自身改变,写在了一起
for (var i = 0; i < 10; i++) {// 这里写的是要执行的代码console.log(i)
}// 控制台会依次输出 0 ~ 9
while
,中文叫 当…时,其实就是当条件满足时就执行代码,一旦不满足了就不执行了
语法 while (条件) { 满足条件就执行 }
因为满足条件就执行,所以我们写的时候一定要注意,就是设定一个边界值,不然就一直循环下去了
// 1. 初始化条件
var num = 0;
// 2. 条件判断
while (num < 10) {// 3. 要执行的代码console.log('当前的 num 的值是 ' + num)// 4. 自身改变num = num + 1
}
是一个和 while
循环类似的循环
while
会先进行条件判断,满足就执行,不满足直接就不执行了
但是 do while
循环是,先不管条件,先执行一回,然后在开始进行条件判断
语法: do { 要执行的代码 } while (条件)
// 下面这个代码,条件一开始就不满足,但是依旧会执行一次 do 后面 {} 内部的代码
var num = 10
do {console.log('我执行了一次')num = num + 1
} while (num < 10)
####4.BREAK 终止循环(常用)
在循环没有进行完毕的时候,因为我设置的条件满足,提前终止循环
比如:我要吃五个包子,吃到三个的时候,不能在吃了,我就停止吃包子这个事情
要终止循环,就可以直接使用 break
关键字
结束整个循环,break所在的循环完全结束了
for (var i = 1; i <= 5; i++) {// 每循环一次,吃一个包子console.log('我吃了一个包子')// 当 i 的值为 3 的时候,条件为 true,执行 {} 里面的代码终止循环// 循环就不会继续向下执行了,也就没有 4 和 5 了if (i === 3) {break}
}
####5. CONTINUE 结束本次循环
在循环中,把循环的本次跳过去,继续执行后续的循环
比如:吃五个包子,到第三个的时候,第三个掉地下了,不吃了,跳过第三个,继续吃第四个和第五个
跳过本次循环,就可以使用 continue
关键字
for (var i = 1; i <= 5; i++) {// 当 i 的值为 3 的时候,执行 {} 里面的代码// {} 里面有 continue,那么本次循环后面的代码就都不执行了// 自动算作 i 为 3 的这一次结束了,去继续执行 i = 4 的那次循环了if (i === 3) {console.log('这个是第三个包子,掉地下了,我不吃了')continue}console.log('我吃了一个包子')
}