04 JavaScript
04 JavaScript
一、js简介
1.js也是一门编程语言,也是可以写后端代码的
node.js 支持js代码跑在后端服务器上
js现在主要用的是5.1和6.0版本
JavaScript 是脚本语言 JavaScript 是一种轻量级的编程语言。 JavaScript 是可插入 HTML 页面的编程代码。 JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行。 JavaScript 很容易学习
注释
// 单行注释
/**/ 多行注释
两种引入方式
1.在script标签内直接书写js代码
2.script标签src属性引入外部js代码
语法结构
js是以分号作为语句结束;
不写分号也能正常执行,相当于没有结束符
二、变量
在js中 首次定义变量名时需要关键字声明
关键字var
var name = 'js';
es6推出的新语法
let name = 'js';
var和let的区别
var在for循环里面定义也会影响到全局 let在局部定义只会在局部生效
"""
js变量的命名规范
1.变量名只能是
数字 字母 下划线 $
2.变量名命名规范(不遵循也可以)
1.js中推荐使用驼峰式命名
userName
dataOfDb
2.python推荐使用下划线的方式
user_name
data_of_db
3.不能用关键字作为变量名
不需要记忆
js代码的书写位置
1.可以单独开设js文件书写
2.还可以直接在浏览器提供的console界面书写
在用浏览器书写js的时候 左上方的清空按钮只是清空当前页面 代码其实还在
如果你想要重新来 最好重新开设一个 页面
(在使用浏览器书写 你自己的js代码的时候推荐你在 自己的html页面打开)
"""
三、常量
python中没有真正意义上的常量的定义,都是约定俗成的用纯大写英文来表示
js中有对于常量的定义:
const pi = 3.14
四、数据类型
4.1 数值类型
var a = 11;
var b = 11.11;
在js中整数形和浮点数型都是数值类型number
查看类型的语法
typeof 数据;(python中是type)
特殊的 NaN:数值类型 表示的意思是“不是一个数字” NOT A NUMBER
类型转换
parseInt() 转换为整数型
parseFloat() 转换为浮点数型
ps :
如果字符串是以数字开头可以转成数值类型,取到英文为止
如果是字母开头不能转换,会形成NaN数值类型
parseInt('123sdasdajs2312dasd')
parseInt('asdasdad123sdasdajs2312dasd')
4.2 字符类型(string)
在python中字符串可以用单引号、双引号、三引号来表示
但是js中没有三引号,多行字符串要用``反引号
// 模版字符串
var s3 = `
asdkajsd
sdjkladj
asdjlajdkl
typeof s3
"string"
// 模版字符串除了可以定义多行文本之外还可以实现格式化字符串操作
// 书写${} 会自动去前面找大括号里面的变量名对应的值 如果没有定义直接报错
var name = 'jason'
var age = 18
var sss = `
my name is ${name} and my age is ${age}
console.log(sss)
my name is jason and my age is 18
js中字符串的拼接可以用+ :
var a = "Hello"
var b = "world;
var c = a + b;
console.log(c); // 得到Helloworld
字符类型的常用方法
1 .length 返回长度
2 .trim() 移除空白
3 .trimLeft() 移除左侧空白
4 .trimRight() 移除右侧空白
5.charAt(n) 返回第n个字符
6 .concat(value,...) 拼接
7 .indexOf(substring, start) 子序列位置
8 .substring(from, to) 根据索引获取子序列,不支持复数
9 .slice(from, to) 切片
10 .toLowerCase() 小写
11 .toUpperCase() 大写
12 .spilt(delimiter, limit) 分割
注意 :
trim()不能在括号里指定去除的内容
字符串的索引也是从零开始
substring不能识别负数:
name2.substring(0,-1) # 不识别负数
slice()可以识别负数:
name2.slice(0,-1) # 后面推荐就使用slice就可以
"$$jason$"
split('|', 2)后面的参数不是表示切割字符的个数,而是切割后元素的个数:
var name = 'tank|hecha|liaomei|mengsao|...'
undefined
name.split('|')
(5) ["tank", "hecha", "liaomei", "mengsao", "..."]
name.split('|',2)
(2) ["tank", "hecha"]0: "tank"1: "hecha"length: 2__proto__: Array(0)
name.split('|',10) # 第二个参数不是限制切割字符的个数而是获取切割之后元素的个数
(5) ["tank", "hecha", "liaomei", "mengsao", "..."]
js是弱类型语言:
var p = 1111
undefined
name.concat(p) # js是弱类型(内部会自动转换成相同的数据类型做操作)
"tank|hecha|liaomei|mengsao|...1111"
python中如果拼接元素中有数字类型直接报错
4.3 布尔值
python中布尔值的首字母大写:
True False
js中布尔值全是小写:
true false
布尔值是false的包括:
空字符串、0、null、underfined、NaN
null与underfined
'''
表示值为空 一般都是指定或者清空一个变量时使用
underfined
表示声明了一个变量 但是没有做初始化操作(没有给值)
函数没有指定返回值的时候 返回的也是undefined
'''
五、对象
JavaScript 中的所有事物都是对象:字符串、数值、数组、函数...此外,JavaScript 允许自定义对象。
JavaScript 提供多个内建对象,比如 String、Date、Array 等等。
对象只是带有属性和方法的特殊数据类型。
数组
数组对象的作用是:使用单独的变量名来存储一系列的值。类似于Python中的列表。
var a = [123, "ABC"];
console.log(a[1]); // 输出"ABC"
数组类型的常用方法:
var l = [111,222,333,444,555,666]
undefined
l.join('$') # 跟python刚好相反
"666$555$444$333$222$111"
l.concat([111,222,333]) # 相当于python中的extend
(9) [666, 555, 444, 333, 222, 111, 111, 222, 333]
l.sort() # 从小到大
(6) [111, 222, 333, 444, 555, 666]
# 三个比较重要的方法
var ll = [111,222,333,444,555,666]
ll.forEach(function(value){console.log(value)},ll)
VM2277:1 111 # 一个参数就是数组里面每一个元素对象
VM2277:1 222
VM2277:1 333
VM2277:1 444
VM2277:1 555
VM2277:1 666
ll.forEach(function(value,index){console.log(value,index)},ll)
VM2346:1 111 0 # 两个参数就是元素 + 元素索引
VM2346:1 222 1
VM2346:1 333 2
VM2346:1 444 3
VM2346:1 555 4
VM2346:1 666 5
undefined
ll.forEach(function(value,index,arr){console.log(value,index,arr)},ll) # 元素 + 元素索引 + 元素的数据来源
VM2430:1 111 0 (6) [111, 222, 333, 444, 555, 666]
VM2430:1 222 1 (6) [111, 222, 333, 444, 555, 666]
VM2430:1 333 2 (6) [111, 222, 333, 444, 555, 666]
VM2430:1 444 3 (6) [111, 222, 333, 444, 555, 666]
VM2430:1 555 4 (6) [111, 222, 333, 444, 555, 666]
VM2430:1 666 5 (6) [111, 222, 333, 444, 555, 666]
undefined
ll.forEach(function(value,index,arr,xxx){console.log(value,index,arr,xxx)},ll) # 最多三个
VM2532:1 111 0 (6) [111, 222, 333, 444, 555, 666] undefined
VM2532:1 222 1 (6) [111, 222, 333, 444, 555, 666] undefined
VM2532:1 333 2 (6) [111, 222, 333, 444, 555, 666] undefined
VM2532:1 444 3 (6) [111, 222, 333, 444, 555, 666] undefined
VM2532:1 555 4 (6) [111, 222, 333, 444, 555, 666] undefined
VM2532:1 666 5 (6) [111, 222, 333, 444, 555, 666] undefined
(6) [111, 222, 333, 444, 555, 666]
ll.splice(0,3) # 两个参数 第一个是起始位置 第二个是删除的个数
(3) [111, 222, 333]
(3) [444, 555, 666]
ll.splice(0,1,777) # 先删除后添加
[444]
(3) [777, 555, 666]
ll.splice(0,1,[111,222,333,444])
[777]
(3) [Array(4), 555, 666]
var l1 = [11,22,33,44,55,66]
undefined
l1.map(function(value){console.log(value)},l1)
VM3115:1 11
VM3115:1 22
VM3115:1 33
VM3115:1 44
VM3115:1 55
VM3115:1 66
l1.map(function(value,index){return value*2},l1)
(6) [22, 44, 66, 88, 110, 132]
l1.map(function(value,index,arr){return value*2},l1)
(6) [22, 44, 66, 88, 110, 132]
六、运算符
算术运算符
+ - * / % ++ --
var x=10;
var res1=x++;
var res2=++x;
res1;10
res2;12
这里由于的x++和++x在出现赋值运算式,x++会先赋值再进行自增1运算,而++x会先进行自增运算再赋值!
比较运算符
> >= < <= != == === !==
== 是弱等于,只能比较值,所以1 == '1' 成立;
=== 是强等于,不仅比较值,还比较数据类型,所以1 === '1'不成立;
逻辑运算符
&& 相当于python中的 and
|| 相当于python中的 or
! 相当于python中的 not
赋值运算符
= += -= *= /=
七、流程控制
if判断
if (判断条件){
}else if判断条件(){
}else{
var a = 10;
if (a > 5){
console.log("a > 5");
}else if (a < 5) {
console.log("a < 5");
}else {
console.log("a = 5");
switch case
var day = new Date().getDay();
switch (day) {
case 0:
console.log("Sunday");
break;
case 1:
console.log("Monday");
break;
default:
console.log("...");
switch中的case子句通常都会加break语句,否则程序会继续执行后续case中的语句。
for循环
for(var i = 0; i < 5; i++){
console.log(i);
1.先运行定义语句
2.在判断条件是否成立
3.成立则执行代码块(不成立就退出循环)
4.再执行自增
while循环
var n = 0;
while (n < 10){
console.log(n);
n++;
三元运算
python中的三元运算:
res = 1 if 1>2 else 3
if 后面条件成立res=1,不成立res=3
js中的三元运算:
var res = 1>2 ? 1:3
等于后面直接跟条件,成立res=1,不成立res=3
var a = 1;
var b = 2;
var c = a > b ? a : b
//这里的三元运算顺序是先写判断条件a>b再写条件成立返回的值为a,条件不成立返回的值为b;三元运算可以嵌套使用;
八、函数
JavaScript中的函数和Python中的非常类似,只是定义方式有点区别。
// 普通函数定义
function func(){
console.log('hello world');
// 调用函数
func()
// 有参函数定义
function func(x,y){
console.log(x,y);
// 调用函数
func('nb','666')
// 带返回值得函数
function sum(x,y){
reture x+y;
// 调用函数
sum(3,4)
// 匿名函数定义
var sum = function(x,y){
reture x+y;
//调用函数
sum(x,y)
// 立即执行函数 书写立即执行的函数,首先先写两个括号()()这样防止书写混乱
(function(a, b){
return a + b;
})(1, 2);
补充:
es6中允许使用箭头函数:
var func = v => v;
// 等同于
var f = function(v){
return v;
如果箭头函数不需要参数或需要多个参数,就是用圆括号代表参数部分:
var f = () => 5;
// 等同于
var f = function(){return 5};
var sum = (num1, num2) => num1 + num2;
// 等同于
var sum = function(num1, num2){
return num1 + num2; //这里的return只能返回一个值,如果想返回多个值需要自己手动给他们包一个数组或对象中
函数中的arguments参数
function add(a,b){
console.log(a+b);
console.log(arguments.length);
console.log(arguments[0]);//arguments相当于将出传入的参数全部包含,这里取得就是第一个元素1
add(1,2)
因为这个参数,所以实参的个数传多少都不会报错,少了就用underfined,多了只用需要的个数。
函数的全局变量和局部变量
局部变量 :
在JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它(该变量的作用域是函数内部)。只要函数运行完毕,本地变量就会被删除。
全局变量:
在函数外声明的变量是 全局 变量,网页上的所有脚本和函数都能访问它。
变量生存周期:
JavaScript变量的生命期从它们被声明的时间开始。
局部变量会在函数运行以后被删除。
全局变量会在页面关闭后被删除。
作用域
首先在函数内部查找变量,找不到则到外层函数查找,逐步找到最外层。与python作用域关系查找一模一样!
几个例子:
1.
var city = "BeiJing";
function f() {
var city = "ShangHai";
function inner(){
var city = "ShenZhen";
console.log(city);
inner();
f(); //输出结果是?
2.
var city = "BeiJing";
function Bar() {
console.log(city);
function f() {
var city = "ShangHai";
return Bar;
var ret = f();
ret(); // 打印结果是?
3.闭包
var city = "BeiJing";
function f(){
var city = "ShangHai";
function inner(){
console.log(city);
return inner;
var ret = f();
ret();
词法分析
JavaScript中在调用函数的那一瞬间,会先进行词法分析。
词法分析的过程:
当函数调用的前一瞬间,会先形成一个激活对象:Avtive Object(AO),并会分析以下3个方面:
1:函数参数,如果有,则将此参数赋值给AO,且值为undefined。如果没有,则不做任何操作。 2:函数局部变量,如果AO上有同名的值,则不做任何操作。如果没有,则将此变量赋值给AO,并且值为undefined。 3:函数声明,如果AO上有,则会将AO上的对象覆盖。如果没有,则不做任何操作。
函数内部无论是使用参数还是使用局部变量都到AO上找。
九、内置对象与方法
JavaScript中的所有事物都是对象:字符串、数字、数组、日期,等等。在JavaScript中,对象是拥有属性和方法的数据。
我们在学习基本数据类型的时候已经带大家了解了,JavaScript中的Number对象、String对象、Array对象等。
注意var s1 = "abc"和var s2 = new String("abc")的区别:typeof s1 --> string而 typeof s2 --> Object
9.1 自定义对象
JavaScript的对象(Object)本质上是键值对的集合(Hash结构),但是只能用字符串作为键。
var a = {"name": "Alex", "age": 18};
console.log(a.name);
console.log(a["age"]);
遍历对象中的内容:
var a = {"name": "Alex", "age": 18};
for (var i in a){
console.log(i, a[i]);
创建对象
var person = new Object();// 创建一个person对象
person.name="Alex"; // person对象的name属性
person.age=18; // person对象的age属性
9.2 Date对象
创建Date对象
//方法1:不指定参数
var d1 = new Date();
console.log(d1.toLocaleString());
//方法2:参数为日期字符串
var d2 = new Date("2004/3/20 11:12");
console.log(d2.toLocaleString());
var d3 = new Date("04/03/20 11:12");
console.log(d3.toLocaleString());
//方法3:参数为毫秒数
var d3 = new Date(5000);
console.log(d3.toLocaleString());
console.log(d3.toUTCString());
//方法4:参数为年月日小时分钟秒毫秒
var d4 = new Date(2004,2,20,11,12,0,300);
console.log(d4.toLocaleString()); //毫秒并不直接显示
Date对象的方法
var d = new Date();
//getDate() 获取日
//getDay () 获取星期
//getMonth () 获取月(0-11)
//getFullYear () 获取完整年份
//getYear () 获取年
//getHours () 获取小时
//getMinutes () 获取分钟
//getSeconds () 获取秒
//getMilliseconds () 获取毫秒
//getTime () 返回累计毫秒数(从1970/1/1午夜)
详细Date对象方法: 点我
JSON对象
var str1 = '{"name": "Alex", "age": 18}';
var obj1 = {"name": "Alex", "age": 18};
// JSON字符串转换成对象
var obj = JSON.parse(str1);
// 对象转换成JSON字符串
var str = JSON.stringify(obj1);
RegExp对象
// 定义正则表达式两种方式
var reg1 = new RegExp("^[a-zA-Z][a-zA-Z0-9]{5,11}");
var reg2 = /^[a-zA-Z][a-zA-Z0-9]{5,9}$/;
// 正则校验数据
reg1.test('jason666')
reg2.test('jason666')
/*第一个注意事项,正则表达式中不能有空格*/
// 全局匹配
var s1 = 'egondsb dsb dsb';
s1.match(/s/)
s1.match(/s/g)
var reg2 = /^[a-zA-Z][a-zA-Z0-9]{5,9}$/g
reg2.test('egondsb');
reg2.test('egondsb');
reg2.lastIndex;
/*第二个注意事项,全局匹配时有一个lastIndex属性*/
// 校验时不传参数
var reg2 = /^[a-zA-Z][a-zA-Z0-9]{5,9}$/
reg2.test();
reg2.test(undefined);
var reg3 = /undefined/;
reg3.test();
Math对象
abs(x) 返回数的绝对值。
exp(x) 返回 e 的指数。
floor(x) 对数进行下舍入。
log(x) 返回数的自然对数(底为e)。
max(x,y) 返回 x 和 y 中的最高值。
min(x,y) 返回 x 和 y 中的最低值。
pow(x,y) 返回 x 的 y 次幂。