day02-前端Web-JavaScript

目录

  • 1. JS介绍
  • 2. 引入方式
    • 2.1 介绍
    • 2.2 演示
  • 3. 基础语法
    • 3.1 书写规范
    • 3.2 变量
      • 3.2.1 let
      • 3.2.2 const
      • 3.2.3 注意
    • 3.3 数据类型
    • 3.4 运算符
      • 3.4.1 运算符
      • 3.4.2 类型转换
    • 3.5 流程控制语句
  • 4. 函数
    • 4.1 格式一
    • 4.2 格式二
  • 5. JS对象
    • 5.1 基本对象
      • 5.1.1 Array对象
        • 5.1.1.1 语法格式
        • 5.1.1.2 特点
        • 5.1.1.3 属性和方法
      • 5.1.2 String对象
        • 5.1.2.1 语法格式
        • 5.1.2.2 属性和方法
      • 5.1.3 JSON对象
        • 5.1.3.1 自定义对象
        • 5.1.3.2 JSON
          • 5.1.3.2.1 介绍
          • 5.1.3.2.2 定义
    • 5.2 BOM对象
        • 1.5.2.1 Window对象
        • 1.5.2.2 Location对象
    • 5.3 DOM对象
      • 5.3.1 DOM介绍
      • 5.3.2 DOM对象
      • 5.3.3 获取DOM对象
      • 5.3.4 案例
        • 5.3.4.1 需求
        • 5.3.4.2 分析
        • 5.3.4.3 实现
  • 6. JS事件
    • 6.1 事件介绍
    • 6.2 事件监听
    • 6.3 常见事件
    • 6.4 案例
      • 6.4.1 表格隔行换色
      • 6.4.2 表单校验
    • 6.5 正则表达式
  • 7. JS模块化

1. JS介绍

我们已经学习了HTML、CSS的基础内容,我们知道HTML负责网页的结构,而CSS负责的是网页的表现。 而要想让网页具备一定的交互效果,具有一定的动作行为,还得通过JavaScript来实现。那今天,我们就来讲解JavaScript,这门语言会让我们的页面能够和用户进行交互。

那什么是JavaScript呢 ?

  • JavaScript(简称:JS) 是一门跨平台、面向对象的脚本语言,是用来控制网页行为的,实现人机交互效果。JavaScript 和 Java 是完全不同的语言,不论是概念还是设计。但是基础语法类似。

  • 组成:

    • ECMAScript: 规定了JS基础语法核心知识,包括变量、数据类型、流程控制、函数、对象等。
    • BOM:浏览器对象模型,用于操作浏览器本身,如:页面弹窗、地址栏操作、关闭窗口等。
    • DOM:文档对象模型,用于操作HTML文档,如:改变标签内的内容、改变标签内字体样式等。
  • 备注:
    ECMA国际(前身为欧洲计算机制造商协会),制定了标准化的脚本程序设计语言ECMAScript,这种语言得到广泛应用。而JavaScript是遵守ECMAScript的标准的。

2. 引入方式

2.1 介绍

同样,js代码也是书写在html中的,那么html中如何引入js代码呢?主要通过下面的2种引入方式:

第一种方式: 内部脚本,将JS代码定义在HTML页面中

  • JavaScript代码必须位于<script></script>标签之间
  • 在HTML文档中,可以在任意地方,放置任意数量的<script>
  • 一般会把脚本置于<body>元素的底部,可改善显示速度

例子:

<body><!-- 页面内容 --><script>alert("Hello World");</script>
</body>

第二种方式: 外部脚本, 将JS代码定义在外部 JS文件中,然后引入到 HTML页面中

  • 外部JS文件中,只包含JS代码,不包含<script>标签
  • 引入外部js的<script>标签,必须是双标签

例子:

<script src="js/demo.js"></script>

注意1:demo.js中只有js代码,没有<script>标签

注意2:通过<script></script>标签引入外部JS文件时,标签不能自闭合

2.2 演示

接下来,我们通过VS Code来编写代码,演示html中2种引入js的方式

第一步:在VS Code中创建名为 01.JS-引入方式.html 的文件

第二步:按照上述第一种内部脚本的方式引入js,编写如下代码:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-引入方式</title>
</head>
<body><!-- 方式一: 内部脚本 --><script>alert("Hello World");</script>
</body>
</html>

第三步:浏览器打开效果如图所示:

在这里插入图片描述

第四步:接下来演示外部脚本,注释掉内部脚本,然后在css目录同级创建js目录,然后创建一个名为demo.js的文件:

在这里插入图片描述

第五步:在demo.js中编写如下js内容:

alert('Hello JavaScript');

第六步:注释掉之前的内部脚本代码,添加<script>标签来引入外部demo.js文件,具体代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-引入方式</title>
</head>
<body><!-- 方式一: 内部脚本 --><!-- <script>alert("Hello World");</script> --><script src="js/demo.js"></script>
</body>
</html>

第七步:浏览器刷新效果如图

在这里插入图片描述

3. 基础语法

3.1 书写规范

掌握了js的引入方式,那么接下来我们需要学习js的书写了,首先需要掌握的是js的书写语法,语法规则如下:

  • 区分大小写:与 Java 一样,变量名、函数名以及其他一切东西都是区分大小写的 。
  • 每行结尾的分号可有可无 【推荐要么全都写,要么全都不写】。
  • 大括号表示代码块 。
  • 注释:
    • 单行注释:// 注释内容
    • 多行注释:/* 注释内容 */

我们需要借助js中3钟输出语句,来演示书写语法

api描述
window.alert(…)警告框
document.write(…)在HTML 输出内容
console.log(…)写入浏览器控制台

接下来我们就通过VS Code,来演示一些上述的3种输出语句的书写语法

第一步:在VS Code中创建名为 02.JS-基础语法-输出语句.html的文件

第二步:按照基本语法规则,编写3种输出语句的代码,并且添加注释,具体代码如下;

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-基本语法-输出语句</title>
</head>
<body><script>//方式一: 写入浏览器的body区域document.write("Hello JS (document.write)");//方式二: 弹出框window.alert("Hello JS (window.alert)");//方式三: 控制台console.log("Hello JS (console.log)")</script>
</body>
</html>

浏览器打开如图所示效果:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

3.2 变量

3.2.1 let

基本的书写语法我们清楚了之后,接下来,我们再来讲解JS中的变量。在js中,变量的声明和java中还是不同的。

  • JS中主要通过 let 关键字来声明变量的。
  • JS是一门弱类型语言,变量是可以存放不同类型的值的。
  • 变量名需要遵循如下规则:
    • 组成字符可以是任何字母、数字、下划线(_)或美元符号($),且数字不能开头
    • 变量名严格区分大小写,如:name和Name是不同的变量
    • 不能使用关键字作为变量名,如:let、if、for等

变量的声明示例如下所示:

<script>//变量let a = 20;a = "Hello";alert(a);
</script>

上述的示例中,大家会看到变量a既可以存数字,又可以存字符串。 因为JS是弱类型语言。

3.2.2 const

在JS中,如果声明一个场景,需要使用const关键字。一旦声明,常量的值就不能改变 (不可以重新赋值)。

如下所示:

<body><script>//常量const PI = 3.14;PI = 3.15;alert(PI);</script>
</body>

浏览器打开之后,会报如下错误:

在这里插入图片描述

该错误就表示,常量不可以被重新分配值。

3.2.3 注意

在早期的JS中,声明变量还可以使用 var 关键字来声明。例如:

<body><script>//var声明变量var name = "A";name = "B";alert(name);var name = "C"alert(name);</script>
</body>

打开浏览器运行之后,大家会发现,可以正常执行,第一次弹出 B,第二次弹出 C 。我们看到 name变量重复声明了,但是呢,如果使用var关键字,是没有问题的,可以重复声明。

var声明的变量呢,还有一些其他不严谨的地方,这里就不再一一列举了,所以这个声明变量的关键字,并不严谨 【不推荐】。

3.3 数据类型

虽然JS是弱数据类型的语言,但是JS中也存在数据类型,JS中的数据类型分为 :原始数据类型 和 引用数据类型。那这部分,我们先来学习原始数据类型,主要包含以下几种类型:

数据类型描述
number数字(整数、小数、NaN(Not a Number))
string字符串,单双引(‘…’)、双引号(“…”)、反引号(`…`)皆可,正常使用推荐单引号
boolean布尔。true,false
null对象为空。 JavaScript 是大小写敏感的,因此 null、Null、NULL是完全不同的
undefined当声明的变量未初始化时,该变量的默认值是 undefined

使用typeof 关键字可以返回变量的数据类型,接下来我们需要通过书写代码来演示js中的数据类型

第一步:在VS Code中创建名为 04.JS-基础语法-数据类型.html 的文件

第二步:编写如下代码,然后直接挨个观察数据类型:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-数据类型</title>
</head>
<body><script>//原始数据类型alert(typeof 3); //numberalert(typeof 3.14); //numberalert(typeof "A"); //stringalert(typeof 'Hello');//stringalert(typeof true); //booleanalert(typeof false);//booleanalert(typeof null); //object var a ;alert(typeof a); //undefined</script>
</body>
</html>

对于字符串类型的数据,除了可以使用双引号(“…”)、单引号(‘…’)以外,还可以使用反引号 (`…`) 。 而使用反引号引起来的字符串,也称为 模板字符串。

  • 模板字符串的使用场景:拼接字符串和变量。
  • 模板字符串的语法:
    • `…` :反引号 (英文输入模式下键盘 tab 键上方波浪线 ~ 那个键)
    • 内容拼接时,使用 ${ } 来引用变量

具体示例如下:

  <script>let name = 'Tom';let age = 18;console.log('大家好, 我是新入职的' + name + ', 今年' + age + '岁了, 请多多关照'); //原始方式 , 手动拼接字符串console.log(`大家好, 我是新入职的${name}, 今年${age}岁了, 请多多关照`); //使用模板字符串方式拼接字符串</script>

3.4 运算符

3.4.1 运算符

那接下来,我们再来介绍JS中的运算符。JS中的运算规则绝大多数还是和JAVA中是一致的,具体运算符如下:

运算规则运算符
算术运算符+ , - , * , / , % , ++ , –
赋值运算符= , += , -= , *= , /= , %=
比较运算符> , < , >= , <= , != , == , === 注意 == 会进行类型转换,=== 不会进行类型转换
逻辑运算符&& , || , !
三元运算符条件表达式 ? true_value: false_value

上述所罗列的这些运算符中,绝大部分的运算符和Java中的使用方式、含义都是一样的。那这里,我们主要介绍一下 = 、==、= = = 的区别:

  • = 是赋值操作
  • == 会在比较时,判断左右两边的值是否相等 (会自动进行类型转换)
  • === 全等,在比较时,判断左右两边的类型和值是否都相等,都相等才为true(不会进行类型转换)

接下来我们通过代码来演示JS中的运算法,主要记忆JS中和JAVA中不一致的地方

第一步:在VS Code中创建名为05. JS-基础语法-运算符.html的文件

第二步:编写代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-运算符</title>
</head>
<body> <script>var age = 20;var _age = "20";var $age = 20;alert(age == _age); //true ,只比较值alert(age === _age); //false ,类型不一样alert(age === $age); //true ,类型一样,值一样</script>
</body>
</html>

3.4.2 类型转换

在某些运算被执行时,系统内部自动将数据类型进行转换,这种转换成为 隐式转换。

  • 字符串 <-> 数字:

    • +号两边只要有一个是字符串,都会把另外一个转成字符串。
    • 除了+外的算术运算符,比如:- * / 都会把字符串转为数字类型。
    • 通过parseInt(…)函数,可以将一个字符串转为数字。
  • 其他类型 -> 布尔类型:

    • Number:0 和 NaN为false,其他均转为true。
    • String:空字符串为false,其他均转为true。
    • Null 和 undefined :均转为false。

演示1: 字符串 <-> 数字

//类型转换 - 字符串 <-> 数字
alert(typeof ('10' - 1)); //number
alert(typeof ('10' + 1)); //stringalert(parseInt("12")); //12
alert(parseInt("12A45")); //12
alert(parseInt("A45"));//NaN (not a number)

演示2: 其他类型 <-> 布尔类型

在js中,还有非常重要的一点是:0,null,undefined,“”,NaN 理解成false,反之理解成true。

// 类型转换 - 其他类型转为boolean
if(0){//falsealert("0 转换为false");
}
if(NaN){//falsealert("NaN 转换为false");
}
if(1){//truealert("除0和NaN其他数字都转为 true");
}if(""){//falsealert("空字符串为 false, 其他都是true");
}if(" "){//truealert("空格字符串为 true");
}if(null){//falsealert("null 转化为false");
}
if(undefined){//falsealert("undefined 转化为false");
}

需要注意的是: 在JS中,0,null,undefined,“”,NaN理解成false,反之都为 true。

3.5 流程控制语句

在JS中,当然也存在对应的流程控制语句。常见的流程控制语句如下:

  • if … else if … else …
  • switch
  • for
  • while
  • do … while

而JS中的流程控制语句与JAVA中的流程控制语句的作用,执行机制都是一样的。这个呢,我们现在就不再一个一个的如研究了,后面用到的时候,我们再做说明。

4. 函数

在JAVA中我们为了提高代码的复用性,可以使用方法 。同样,在JavaScript中可以使用函数来完成相同的事情。JavaScript中的函数被设计为执行特定任务的代码块,方便程序的封装复用。在JS中,需要通过关键字function来定义。接下来我们学习一下JavaScript中定义函数的2种语法:

4.1 格式一

第一种定义格式如下:

function 函数名(参数1,参数2..){要执行的代码
}

因为JavaScript是弱数据类型的语言,所以有如下几点需要注意:

  • 形参不需要声明类型,并且JS中不管什么类型都是let去声明,加上也没有意义。
  • 返回值也不需要声明类型,直接return即可

示例:

function add(a, b){return a + b;
}

如果要调用上述的函数add,可以使用:函数名称(实际参数列表)

let result = add(10,20);
alert(result);

我们在调用add函数时,再添加2个参数,修改代码如下:

var result = add(10,20,30,40);
alert(result);

浏览器打开,发现没有错误,并且依然弹出30,这是为什么呢?

因为在JavaScript中,函数的调用只需要名称正确即可,参数列表不管的。如上述案例,10传递给了变量a,20传递给了变量b,而30和40没有变量接受,但是不影响函数的正常调用。

注意:由于JS是弱类型语言,形参、返回值都不需要指定类型。在调用函数时,实参个数与形参个数可以不一致,但是建议一致。

4.2 格式二

刚才我们定义函数,是为函数指定了一个名字。 那我们也可以不为函数指定名字,那这一类的函数,我们称之为匿名函数。那接下来,方式二,就来介绍一下匿名函数的定义和调用。

匿名函数: 是指一种没有名称的函数,由于它们没有名称,因此无法直接通过函数名来调用,而是通过变量或表达式来调用。

匿名函数定义可以通过两种方式:函数表达式 和 箭头函数。

示例一(函数表达式):

var add = function (a,b){return a + b;
}

示例二(箭头函数):

var add = (a,b) => {return a + b;
}

上述匿名函数声明好了之后,是将这个函数赋值给了add变量。 那我们就可以直接通过add函数直接调用,调用代码如下:

let result = add(10,20);
alert(result);

也可以在定义完匿名函数之后,让该函数立即执行,这类函数我们也称为 立即执行函数

(function (a,b) {console.log(a + b);})(10,20);((a,b) => {console.log(a + b);})(100,200);

5. JS对象

JavaScript中的对象有很多,主要可以分为如下3大类,我们可以打开W3school在线学习文档,来到首页,在左侧栏找到浏览器脚本下的JavaScript,如下图所示:

在这里插入图片描述

然后进入到如下界面,点击右侧的参考书

在这里插入图片描述

然后进入到如下页面,此页面列举出了JavaScript中的所有对象

在这里插入图片描述

可以大体分页3大类:

第一类:基本对象,我们主要学习Array、String和JSON

在这里插入图片描述

第二类:BOM对象,主要是和浏览器相关的几个对象

在这里插入图片描述

第三类:DOM对象,JavaScript中将html的每一个标签都封装成一个对象

在这里插入图片描述

5.1 基本对象

5.1.1 Array对象

5.1.1.1 语法格式

Array对象时用来定义数组的。常用语法格式有如下2种:

方式1:

var 变量名 = new Array(元素列表); 

例如:

var arr = new Array(1,2,3,4); //1,2,3,4 是存储在数组中的数据(元素)

方式2:

var 变量名 = [ 元素列表 ]; 

例如:

var arr = [1,2,3,4]; //1,2,3,4 是存储在数组中的数据(元素)

数组定义好了,那么我们该如何获取数组中的值呢?和java中一样,需要通过索引来获取数组中的值(索引从0 开始)。语法如下:

arr[索引] =;

接下来,我们在VS Code中创建名为 07. JS-对象-Array.html 的文件,按照上述的语法定义数组,并且通过索引来获取数组中的值。

<script>//定义数组//let arr = new Array(1,2,3,4);let arr = [1,2,3,4];//获取数组中的值,索引从0开始计数console.log(arr[0]);console.log(arr[1]);
</script>

浏览器控制台观察的效果如下:输出1和2

在这里插入图片描述

5.1.1.2 特点

与java中不一样的是,JavaScript中数组相当于java中的集合,数组的长度是可以变化的。而且JavaScript是弱数据类型的语言,所以数组中可以存储任意数据类型的值 【总结起来:长度可变、类型可变】。

接下来我们通过代码来演示上述特点。注释掉之前的代码,添加如下代码:

//特点: 长度可变 类型可变
let arr = [1,2,3,4];
arr[10] = 50;console.log(arr[10]);
console.log(arr[9]);
console.log(arr[8]);

上述代码定义的arr变量中,数组的长度是4,但是我们直接再索引10的位置直接添加了数据10,并且输出索引为10的位置的元素,浏览器控制台数据结果如下:

在这里插入图片描述

因为索引8和9的位置没有值,所以输出内容undefined。 当然,我们也可以给数组添加其他类型的值,添加代码如下:注释掉之前控制台输出的代码

//特点: 长度可变 类型可变
let arr = [1,2,3,4];
arr[10] = 50;// console.log(arr[10]);
// console.log(arr[9]);
// console.log(arr[8]);arr[9] = "A";
arr[8] = true;console.log(arr);

浏览器控制台输出结果如下:
在这里插入图片描述

5.1.1.3 属性和方法

Array作为一个对象,那么对象是有属性和方法的,所以接下来我们介绍一下Array对象的属性和方法

官方文档中提供了Array的很多属性和方法,但是我们只学习常用的属性和方法,如下图所示:

  • 属性:
属性描述
length设置或返回数组中元素的数量。
  • 方法:
方法描述
forEach()遍历数组中的每个有值的元素,并调用一次传入的函数
map()遍历每个数组元素,调用函数进行处理,并将结果封装到一个新数组中
push()将一个或多个元素添加到数组的末尾,并返回新的长度。
pop()从数组移除最后一个元素,并返回该元素。
unshift()在数组开头添加一个或多个元素,并返回数组的新长度。
shift()从数组移除第一个元素,并返回该元素。
splice()从数组中删除元素。
  • length属性:

    length属性可以用来获取数组的长度,所以我们可以借助这个属性,来遍历数组中的元素,添加如下代码:

    let arr = [1,2,3,4];
    arr[10] = 50;
    for (let i = 0; i < arr.length; i++) {console.log(arr[i]);
    }
    

    浏览器控制台输出结果如图所示:

在这里插入图片描述

  • forEach()方法

    首先我们学习forEach()方法,顾名思义,这是用来遍历的,那么遍历做什么事呢?所以这个方法的参数,需要传递一个函数,而且这个函数接受一个参数,就是遍历时数组的值。修改之前的遍历代码如下:

    //e是形参,接受的是数组遍历时的值
    arr.forEach(function(e){console.log(e);
    })
    

    当然了,在ES6中,引入箭头函数的写法,语法类似java中lambda表达式,修改上述代码如下:

    arr.forEach((e) => {console.log(e);
    }) 
    

浏览器输出结果如下:注意的是,没有元素的内容是不会输出的,因为forEach只会遍历有值的元素

在这里插入图片描述

  • map() 方法

    该方法是用于遍历数组中的元素,调用传入的函数对元素进行处理,并将结果封装到一个新数组中。 如下所示:

    //map: 对arr中的每一个元素进行处理, 在原来的基础上加10, 并将其封装到一个新的数组 arr2 中.
    let arr2 = arr.map((e) => e = e+10);
    console.log(arr2);
    

    该方法演示完毕后,将其注释。

  • push()方法

    push()方法是用于向数组的末尾添加元素的,其中函数的参数就是需要添加的元素。编写如下代码:向数组的末尾添加3个元素

    //push: 添加元素到数组末尾
    arr.push(7,8,9);
    console.log(arr);
    

    浏览器输出结果如下:
    在这里插入图片描述

  • pop()方法

    pop()方法是用来移除数组中的最后一个元素,并返回该元素。编写如下代码:

    //pop: 移除最后一个元素
    arr.pop();
    console.log(arr);
    

    浏览器输出结果如下:
    在这里插入图片描述

  • unshift() 方法

    该方法是用于在数组的开头添加元素(一个或多个),并返回新的数组的长度。示例如下:

    //unshift: 往数组的头部添加元素 A
    arr.unshift('A', 'B');
    console.log(arr);
    

    浏览器输出结果如下:
    在这里插入图片描述

  • shift() 方法

    该方法用来在数组的头部移除第一个元素,并返回该元素。示例如下:

    arr.shift();
    console.log(arr);
    

    浏览器输出结果如下:
    在这里插入图片描述

  • splice()方法

    splice()方法用来数组中的元素,函数中填入2个参数。

    参数1:表示从哪个索引位置删除

    参数2:表示删除元素的个数

    如下代码表示:从索引2的位置开始删,删除2个元素

    //splice: 删除元素
    arr.splice(2,2);
    console.log(arr);
    

    浏览器执行效果如下:元素3和4被删除了,元素3是索引2
    在这里插入图片描述

Array数组的完整代码如下:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-对象-Array</title>
</head><body><script>//1. 定义数组//let arr = new Array(1,2,3,4);// let arr = [1,2,3,4];//获取数组中的值,索引从0开始计数// console.log(arr[0]);// console.log(arr[1]);//特点: 长度可变 类型可变// let arr = [1,2,3,4];// arr[10] = 50;// arr[9] = "A";// arr[8] = true;// console.log(arr);// console.log(arr[10]);// console.log(arr[9]);// console.log(arr[8]);//2. 数组属性 - lengthlet arr = [1,2,3,4];arr[10] = 50;// for (let i = 0; i < arr.length; i++) {//     console.log(arr[i]);// }//3. 数组方法 - forEach , map, push , pop , unshift , shift , splice// arr.forEach(function(e){//     console.log(e);// })// let arr2 = arr.map((e) => e = e+10);// console.log(arr2);// arr.push(7,8,9);// console.log(arr);// arr.pop();// console.log(arr);// arr.unshift('A', 'B');// console.log(arr);// arr.shift();// console.log(arr);//splice: 删除元素arr.splice(2,2);console.log(arr);</script>
</body></html>

5.1.2 String对象

5.1.2.1 语法格式

String对象的创建方式有2种:

方式1:

var 变量名 = new String("…") ; //方式一

例如:

var str = new String("Hello String");

方式2:

var 变量名 = '…' ; //方式二

例如:

var str = 'Hello String';

按照上述的格式,在VS Code中创建为名03. JS-对象-String.html的文件,编写代码如下:

<script>//创建字符串对象//var str = new String("Hello String");var str = '  Hello String    ';console.log(str);
</script>
5.1.2.2 属性和方法

String对象也提供了一些常用的属性和方法,如下表格所示:

属性:

属性描述
length字符串的长度。

方法:

方法描述
charAt()返回在指定位置的字符。
indexOf()检索字符串。
trim()去除字符串两边的空格
substring()提取字符串中两个指定的索引号之间的字符。
  • length属性:

    length属性可以用于返回字符串的长度,添加如下代码:

    //length
    console.log(str.length);
    
  • charAt()函数:

    charAt()函数用于返回在指定索引位置的字符,函数的参数就是索引。添加如下代码:

    console.log(str.charAt(4));
    
  • indexOf()函数

    indexOf()函数用于检索指定内容在字符串中的索引位置的,返回值是索引,参数是指定的内容。添加如下代码:

    console.log(str.indexOf("lo"));
    
  • trim()函数

    trim()函数用于去除字符串两边的空格的。添加如下代码:

    var s = str.trim();
    console.log(s.length);
    
  • substring()函数

    substring()函数用于截取字符串的,函数有2个参数。

    参数1:表示从那个索引位置开始截取。包含

    参数2:表示到那个索引位置结束。不包含

    console.log(s.substring(0,5));
    

整体代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-对象-String</title>
</head>
<body></body>
<script>//创建字符串对象//var str = new String("Hello String");var str = "  Hello String    ";console.log(str);//lengthconsole.log(str.length);//charAtconsole.log(str.charAt(4));//indexOfconsole.log(str.indexOf("lo"));//trimvar s = str.trim();console.log(s.length);//substring(start,end) --- 开始索引, 结束索引 (含头不含尾)console.log(s.substring(0,5));</script>
</html>

浏览器执行效果如图所示:

在这里插入图片描述

5.1.3 JSON对象

5.1.3.1 自定义对象

在 JavaScript 中自定义对象特别简单,其语法格式如下:

var 对象名 = {属性名1: 属性值1, 属性名2: 属性值2,属性名3: 属性值3,方法名称: function(形参列表){}
};

我们可以通过如下语法调用属性:

对象名.属性名

通过如下语法调用函数:

对象名.方法名()

接下来,我们再VS Code中创建名为 09. JS-对象-JSON.html 的文件演示自定义对象

<script>//自定义对象var user = {name: "Tom",age: 10,gender: "男",sing: function(){console.log("悠悠的唱着最炫的民族风~");}}console.log(user.name);user.eat();
<script>

浏览器控制台结果如下:
在这里插入图片描述

其中,上述函数定义的语法可以简化成如下格式:

<script>//自定义对象var user = {name: "Tom",age: 10,gender: "男",sing(){console.log("悠悠的唱着最炫的民族风~");}}console.log(user.name);user.eat();
<script>
5.1.3.2 JSON
5.1.3.2.1 介绍

JSON对象:JavaScript Object Notation,JavaScript对象标记法。JSON是通过JavaScript标记法书写的文本。其格式如下:

{"key":value,"key":value,"key":value
}

其中,key必须使用引号并且是双引号标记,value可以是任意数据类型。

例如我们可以直接百度搜索“json在线解析”,随便挑一个进入,然后编写内容如下:

{"name": "李传播"
}

在这里插入图片描述

但是当我们将双引号切换成单引号,再次校验,则报错,如下图所示:

在这里插入图片描述

而由于语法简单,层级结构鲜明,现多用于作为数据载体,在网络中进行数据传输。

在这里插入图片描述

5.1.3.2.2 定义

接下来我们通过代码来演示json对象:注释掉之前的代码,编写代码如下:

var userStr = '{"name":"Tom", "age":18, "addr":["北京","上海","西安"]}';
alert(userStr.name);

浏览器输出结果如下:

在这里插入图片描述

为什么呢?因为上述是一个json格式的字符串,不是JS对象,所以我们需要借助JS中提供的JSON对象,来将json字符串和JS对象之间来完成转换。

1). JSON字符串 -> JS对象

var obj = JSON.parse(userStr);
alert(obj.name);

此时浏览器输出结果如下:

在这里插入图片描述

2). JS对象 -> JSON字符串

alert(JSON.stringify(obj));

浏览器输出结果如图所示:

在这里插入图片描述

整体全部代码如下:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-对象-JSON</title>
</head><body><script>//1. 自定义JS对象// var user = {//     name: "Tom",//     age: 10,//     gender: "男",//     sing: function(){//         console.log("悠悠的唱着最炫的民族风~");//     }// }// console.log(user.name);// user.sing();//2. JSON对象var userStr = '{"name":"Tom", "age":18, "addr":["北京","上海","西安"]}';// alert(userStr.name);var obj = JSON.parse(userStr);alert(obj.name);alert(JSON.stringify(obj));</script>
</body></html>

5.2 BOM对象

接下来我们学习BOM对象,BOM的全称是Browser Object Model,翻译过来是浏览器对象模型。

也就是JavaScript将浏览器的各个组成部分封装成了对象。我们要操作浏览器的部分功能,可以通过操作BOM对象的相关属性或者函数来完成。

例如:我们想要将浏览器的地址改为http://www.baidu.com,我们就可以通过BOM中提供的location对象的href属性来完成,代码如下:location.href='http://www.baidu.com'

BOM中提供了如下5个对象:

对象名称描述
Window浏览器窗口对象
Navigator浏览器对象
Screen屏幕对象
History历史记录对象
Locationd地址栏对象

上述5个对象与浏览器各组成对应的关系如下图所示:

在这里插入图片描述

1.5.2.1 Window对象

window对象指的是浏览器窗口对象,是JavaScript的全部对象,所以对于window对象,我们可以直接使用,并且对于window对象的方法和属性,我们可以省略window.例如:我们之前学习的alert()函数其实是属于window对象的,其完整的代码如下:

window.alert('hello');

其可以省略window. 所以可以简写成

alert('hello')

所以对于window对象的属性和方法,我们都是采用简写的方式。window提供了很多属性和方法,下表列出了常用属性和方法

window对象提供了获取其他BOM对象的属性:

属性描述
history用于获取history对象
location用于获取location对象
Navigator用于获取Navigator对象
Screen用于获取Screen对象

也就是说我们要使用location对象,只需要通过代码window.location或者简写location即可使用

window也提供了一些常用的方法,如下表格所示:

函数描述
alert()显示带有一段消息和一个确认按钮的警告框。
comfirm()显示带有一段消息以及确认按钮和取消按钮的对话框。
setInterval()按照指定的周期(以毫秒计)来调用函数或计算表达式。
setTimeout()在指定的毫秒数后调用函数或计算表达式。

接下来,我们通过VS Code中创建名为 10. JS-对象-BOM.html 文件来编写代码来演示上述函数:

  • alert()函数:弹出警告框,函数的内容就是警告框的内容

    <script>//window对象是全局对象,window对象的属性和方法在调用时可以省略window.window.alert("Hello BOM");alert("Hello BOM Window");
    </script> 
    
  • confirm()函数:弹出确认框,并且提供用户2个按钮,分别是确认和取消。

    添加如下代码:

    confirm("您确认删除该记录吗?");
    

    浏览器打开效果如图所示:
    在这里插入图片描述

    但是我们怎么知道用户点击了确认还是取消呢?所以这个函数有一个返回值,当用户点击确认时,返回true,点击取消时,返回false。我们根据返回值来决定是否执行后续操作。修改代码如下:再次运行,可以查看返回值true或者false

    var flag = confirm("您确认删除该记录吗?");
    alert(flag);
    
  • setInterval(fn,毫秒值):定时器,用于周期性的执行某个功能,并且是循环执行。该函数需要传递2个参数:

    fn:函数,需要周期性执行的功能代码

    毫秒值:间隔时间

    注释掉之前的代码,添加代码如下:

    //定时器 - setInterval -- 周期性的执行某一个函数
    var i = 0;
    setInterval(function(){i++;console.log("定时器执行了"+i+"次");
    },2000);
    

    刷新页面,浏览器每个一段时间都会在控制台输出,结果如下:

在这里插入图片描述

  • setTimeout(fn,毫秒值) :定时器,只会在一段时间后执行一次功能。参数和上述setInterval一致

    注释掉之前的代码,添加代码如下:

    //定时器 - setTimeout -- 延迟指定时间执行一次 
    setTimeout(function(){alert("JS");
    },3000);
    

    浏览器打开,3s后弹框,关闭弹框,发现再也不会弹框了。

1.5.2.2 Location对象

location是指代浏览器的地址栏对象,对于这个对象,我们常用的是href属性,用于获取或者设置浏览器的地址信息,添加如下代码:

//获取浏览器地址栏信息
alert(location.href);
//设置浏览器地址栏信息
location.href = "https://www.itcast.cn";

浏览器效果如下:首先弹框展示浏览器地址栏信息,

在这里插入图片描述

然后点击确定后,因为我们设置了地址栏信息,所以浏览器跳转到传智首页

完整代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-对象-BOM</title>
</head>
<body></body>
<script>//获取// window.alert("Hello BOM");// alert("Hello BOM Window");//方法//confirm - 对话框 -- 确认: true , 取消: false// var flag = confirm("您确认删除该记录吗?");// alert(flag);//定时器 - setInterval -- 周期性的执行某一个函数// var i = 0;// setInterval(function(){//     i++;//     console.log("定时器执行了"+i+"次");// },2000);//定时器 - setTimeout -- 延迟指定时间执行一次 // setTimeout(function(){//     alert("JS");// },3000);//locationalert(location.href);location.href = "https://www.itcast.cn";</script>
</html>

5.3 DOM对象

5.3.1 DOM介绍

DOM:Document Object Model 文档对象模型。也就是 JavaScript 将 HTML 文档的各个组成部分封装为对象。

DOM 其实我们并不陌生,之前在学习 XML 就接触过,只不过 XML 文档中的标签需要我们写代码解析,而 HTML 文档是浏览器解析。封装的对象分为

  • Document:整个文档对象
  • Element:元素对象
  • Attribute:属性对象
  • Text:文本对象
  • Comment:注释对象

如下图,左边是 HTML 文档内容,右边是 DOM 树

在这里插入图片描述

那么我们学习DOM技术有什么用呢?主要作用如下:

  • 改变 HTML 元素的内容
  • 改变 HTML 元素的样式(CSS)
  • 对 HTML DOM 事件作出反应
  • 添加和删除 HTML 元素

从而达到动态改变页面效果目的,具体我们可以查看代码中提供的 11. JS-对象-DOM-演示.html 来体会DOM的效果。

5.3.2 DOM对象

  • DOM对象:浏览器根据HTML标签生成的JS对象

    • 所有的标签属性都可以在这个对象上面找到
    • 修改这个对象的属性,就会自动映射到标签身上
  • DOM的核心思想:将网页的内容当做对象来处理

  • document对象

    • 网页中所有内容都封装在document对象中
    • 它提供的属性和方法都是用来访问和操作网页内容的,如:document.write(…)
  • DOM操作步骤:

    • 获取DOM元素对象
    • 操作DOM对象的属性或方法 (查阅文档)

5.3.3 获取DOM对象

我们可以通过如下两种方式来获取DOM元素。

  1. 根据CSS选择器来获取DOM元素,获取到匹配到的第一个元素:document.querySelector('CSS选择器');
  2. 根据CSS选择器来获取DOM元素,获取匹配到的所有元素:document.querySelectorAll('CSS选择器');

​ 注意:获取到的所有元素,会封装到一个NodeList节点集合中,是一个伪数组(有长度、有索引的数组,但是没有push、pop等数组方法)

PS:在早期的JS中,我们也可以通过如下方法获取DOM元素(了解)。

函数描述
document.getElementById()根据id属性值获取,返回单个Element对象
document.getElementsByTagName()根据标签名称获取,返回Element对象数组
document.getElementsByName()根据name属性值获取,返回Element对象数组
document.getElementsByClassName()根据class属性值获取,返回Element对象数组

接下来我们通过VS Code中创建名为 12. JS-对象-DOM-获取元素.html 的文件来演示上述api,首先在准备如下页面代码:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-对象-DOM</title>
</head><body><span id="sid">DOM元素1</span><span class="txt">DOM元素2</span><span class="txt">DOM元素3</span><script>//根据CSS选择器获取DOM元素, 获取到匹配的第一个元素let s1 = document.querySelector('#sid');console.log(s1);//根据CSS选择器获取DOM元素, 获取到匹配的所有元素let s2 = document.querySelectorAll('.txt');s2.forEach(s => console.log(s))</script>
</body></html>
  • 操作属性

    那么获取到标签了,我们如何操作标签的属性呢?通过查询文档资料,如下图所示:

在这里插入图片描述
得出我们可以通过div标签对象的innerHTML属性来修改标签的内容。此时我们想把页面中的传智教育替换成传智教育666,所以要获取2个div中的第一个,所以可以通过下标0获取数组中的第一个div,注释之前的代码,编写如下代码:

//根据CSS选择器获取DOM元素, 获取到匹配的第一个元素
let s1 = document.querySelector('#sid');
console.log(s1);
s1.innerHTML = '传智教育 666'

浏览器刷新页面,展示效果如下图所示:

在这里插入图片描述
发现页面内容变成了传智教育666

完整代码如下:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-对象-DOM</title>
</head><body><span id="sid">DOM元素1</span><span class="txt">DOM元素2</span><span class="txt">DOM元素3</span><script>//根据CSS选择器获取DOM元素, 获取到匹配的第一个元素let s1 = document.querySelector('#sid');console.log(s1);s1.innerHTML = '传智教育 666'//根据CSS选择器获取DOM元素, 获取到匹配的所有元素let s2 = document.querySelectorAll('.txt');s2.forEach(s => console.log(s))</script>
</body></html>

5.3.4 案例

5.3.4.1 需求

需求:订单支付完成后,5秒之后跳转到系统首页(www.jd.com)

效果如下所示:
在这里插入图片描述

5.3.4.2 分析
  • 要实现倒计时效果,那其实倒计时,就是每1秒钟,执行一次,把数字往下减1,直到数据减为0 。所以,这里我们需要用到一个定时器:setInterval(…)
  • 跳转网页,其实控制的地址栏的地址,那这里我们就需要通过 location 来设置地址栏的信息 。
5.3.4.3 实现
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.center {text-align: center;margin-top: 50px;}</style>
</head><body><div class="center">您好, 支付完成, <span id="time">5</span> 秒之后将自动跳转至 <a href="https://www.jd.com">官网</a> 首页 ~</div><script>//1. 获取时间对应的DOM元素let time = document.querySelector('#time');//2. 开启定时器, 每秒将时间往下减一 , 如果时间>0 , 更新DOM元素的内容 ; 如果时间 < 0 , 则跳转页面 ;count = time.innerHTML;let timer = setInterval(() => {count--;if (count > 0) {time.innerHTML = count;} else {clearInterval(timer);location.href = 'https://www.jd.com';}}, 1000);</script>
</body>
</html>

6. JS事件

6.1 事件介绍

如下图所示的百度注册页面,当我们用户输入完内容,百度可以自动的提示我们用户名已经存在还是可以使用。那么百度是怎么知道我们用户名输入完了呢?这就需要用到JavaScript中的事件了。

在这里插入图片描述

什么是事件呢?HTML事件是发生在HTML元素上的 “事情”,例如:

  • 按钮被点击
  • 鼠标移到元素上
  • 输入框失去焦点
  • 按下键盘按键

而我们可以给这些事件绑定函数,当事件触发时,可以自动的完成对应的功能。这就是事件监听。例如:对于我们所说的百度注册页面,我们给用户名输入框的失去焦点事件绑定函数,当我们用户输入完内容,在标签外点击了鼠标,对于用户名输入框来说,失去焦点,然后执行绑定的函数,函数进行用户名内容的校验等操作。JavaScript事件是js非常重要的一部分,那么我们对于JavaScript事件需要学习哪些内容呢?我们得知道有哪些常用事件,然后我们得学会如何给事件绑定函数。

所以主要围绕2点来学习:

  • 事件监听
  • 常用事件

6.2 事件监听

JS事件监听的语法:

事件源.addEventListener('事件类型', 要执行的函数);

在上述的语法中包含三个要素:

  • 事件源: 哪个dom元素触发了事件, 要获取dom元素
  • 事件类型: 用什么方式触发, 比如: 鼠标单击 click, 鼠标经过 mouseover
  • 要执行的函数: 要做什么事

演示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-事件-事件绑定</title>
</head><body><input type="button" id="btn1" value="点我一下试试1"><input type="button" id="btn2" value="点我一下试试2"><script>document.querySelector("#btn1").addEventListener('click', ()=>{alert("按钮1被点击了...");})</script>
</body>
</html>

JavaScript对于事件的绑定还提供了另外2种方式(早期版本):

1). 通过html标签中的事件属性进行绑定

例如一个按钮,我们对于按钮可以绑定单机事件,可以借助标签的onclick属性,属性值指向一个函数。

<input type="button" id="btn1" value="点我一下试试1" onclick="on()">
<script>function on(){alert('试试就试试')}
</script>

2). 通过DOM中Element元素的事件属性进行绑定

依据我们学习过得DOM的知识点,我们知道html中的标签被加载成element对象,所以我们也可以通过element对象的属性来操作标签的属性。

例如一个按钮,我们对于按钮可以绑定单机事件,可以通过DOM元素的属性,为其做事件绑定。

  <body><input type="button" id="btn1" value="点我一下试试1"><script>document.querySelector('#btn1').onclick = function(){alert("按钮2被点击了...");}</script></body>

整体代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-事件-事件绑定</title>
</head><body><input type="button" id="btn1" value="事件绑定1"><input type="button" id="btn2" value="事件绑定2"><script>document.querySelector("#btn1").addEventListener('click', ()=>{alert("按钮1被点击了...");})document.querySelector('#btn2').onclick = function(){alert("按钮2被点击了...");}</script>
</body>
</html>

addEventListener 与 on事件 区别:

  • on方式会被覆盖,addEventListener 方式可以绑定多次,拥有更多特性,推荐使用 addEventListener .

6.3 常见事件

上面案例中使用到了 onclick 事件属性,那都有哪些事件类型供我们使用呢?下面就给大家列举一些比较常用的事件属性:

在这里插入图片描述

示例演示:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS-事件-常见事件</title>
</head><body><form action="" style="text-align: center;"><input type="text" name="username" id="username"><input type="text" name="age" id="age"><input id="b1" type="submit" value="提交"><input id="b2" type="button" value="单击事件"></form><br><br><br><table width="800px" border="1" cellspacing="0" align="center"><tr><th>学号</th><th>姓名</th><th>分数</th><th>评语</th></tr><tr align="center"><td>001</td><td>张三</td><td>90</td><td>很优秀</td></tr><tr align="center" id="last"><td>002</td><td>李四</td><td>92</td><td>优秀</td></tr></table><script>//click: 鼠标点击事件document.querySelector('#b2').addEventListener('click', () => {console.log("我被点击了...");})//mouseenter: 鼠标移入document.querySelector('#last').addEventListener('mouseenter', () => {console.log("鼠标移入了...");})//mouseleave: 鼠标移出document.querySelector('#last').addEventListener('mouseleave', () => {console.log("鼠标移出了...");})//keydown: 某个键盘的键被按下document.querySelector('#username').addEventListener('keydown', () => {console.log("键盘被按下了...");})//keydown: 某个键盘的键被抬起document.querySelector('#username').addEventListener('keyup', () => {console.log("键盘被抬起了...");})//blur: 失去焦点事件document.querySelector('#age').addEventListener('blur', () => {console.log("失去焦点...");})//focus: 元素获得焦点document.querySelector('#age').addEventListener('focus', () => {console.log("获得焦点...");})//input: 用户输入时触发document.querySelector('#age').addEventListener('input', () => {console.log("用户输入时触发...");})//submit: 提交表单事件document.querySelector('form').addEventListener('submit', () => {alert("表单被提交了...");})</script>
</body></html>

6.4 案例

6.4.1 表格隔行换色

需求:实现表格隔行换色效果,奇数行设置背景色为: #FBFBD4,偶数行设置背景色为: #D9D9FA

效果:

在这里插入图片描述

分析:当鼠标引入表格,呈现一个颜色,离开之后颜色马上变为默认的白色了。 那这就涉及到鼠标移入事件 mouseenter、鼠标移出事件 mouseleave。

实现:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>table {/* 设置表格的宽度 */width: 60%;/* 将表格边框合并,消除单元格之间的间距 */border-collapse: collapse;/* 将表格边框间的距离设置为0,确保没有任何间距 */border-spacing: 0;/* 文本居中对齐 */text-align: center;/* 版心居中展示 */margin: auto;/* 距离顶部的外边距 */margin-top: 20px;/* 行高 */line-height: 30px;/* 字体 */font-family: 'Courier New', 华文中宋, monospace;}table,tr,th,td {/* 设置表格的边框 */border: 1px solid black;}h1 {/* 文本居中对齐 */text-align: center;}.footer_btn {/* 文本居中对齐 */text-align: center;margin-top: 10px;}</style>
</head><body><h1 id="title">用户信息表</h1><table><tr><th>编号</th><th>姓名</th><th>年龄</th><th>性别</th><th>爱好</th></tr><tr class="data"><td>1</td><td>Tom</td><td>18</td><td></td><td>Java , JS , HTML , Vue</td></tr><tr class="data"><td>2</td><td>Cat</td><td>12</td><td></td><td>Java , JS , HTML , Vue</td></tr><tr class="data"><td>3</td><td>Lee</td><td>21</td><td></td><td>Java , Vue</td></tr><tr class="data"><td>4</td><td>Jerry</td><td>19</td><td></td><td>JS , HTML , Vue</td></tr><tr class="data"><td>5</td><td>Jack</td><td>25</td><td></td><td>Java</td></tr><tr class="data"><td>6</td><td>Jones</td><td>22</td><td></td><td>HTML , Vue</td></tr></table><script>//1. 获取表格中的数据行 DOM对象let trs = document.querySelectorAll('.data');//2. 判断, 如果是奇数行, 设置背景颜色为 #FBFBD4; 如果是偶数行, 设置背景颜色为: #D9D9FAfor (let i = 0; i < trs.length; i++) {const tr = trs[i];tr.addEventListener('mouseenter', ()=> {if(i % 2 == 0){ //偶数tr.style = "background-color: #D9D9FA";}else { //奇数tr.style = "background-color: #FBFBD4";}})tr.addEventListener('mouseleave', ()=> {tr.style = "background-color: #FFFFFF";})}</script>
</body></html>

6.4.2 表单校验

**1). 需求:**完成用户注册的表单校验操作,要求做到以下两点。

  1. 在表单项中输入完成,鼠标离开焦点时,进行表单项内容的校验,如果内容格式不正确,显示提示信息。

  2. 在表单提交时,校验整个表单内容,如果内容格式有一项不正确,弹出提示信息,阻止表单数据提交。

2). 效果:

在这里插入图片描述

3). 分析:

  1. JS的事件监听:离焦事件 blur,表单提交事件 submit

  2. DOM对象操作

4). 实现:

<!DOCTYPE html>
<html><head><title>表单</title><style>label {display: inline-block;width: 80px;text-align: right;margin-right: 10px;}input {width: 250px;padding: 10px;border: 1px solid #ccc;border-radius: 5px;margin-bottom: 10px;}.btn {width: 150px;}.tip {color: #ff0000;font-size: 12px;}</style>
</head><body><div><h1>用户注册</h1><form><label for="username">用户名:</label><input type="text" id="username" name="username" placeholder="用户名不能为空且长度在4-16个字符"><span class="tip" id="name_msg"></span> <br><label for="phone">手机号:</label><input type="text" id="phone" name="phone" placeholder="手机号不能为空且长度为11位"><span class="tip" id="phone_msg"></span><br><input type="submit" value="提交" class="btn"><input type="reset" value="重置" class="btn"></form></div><script>//1. 校验用户名 - 失去焦点时校验 - blurfunction checkUsername(){ //true, 合法; false, 不合法;let flag = true;let usernameValue = document.querySelector('#username').value;let errMsg = "";if(usernameValue.length < 4 || usernameValue.length > 16){errMsg = "用户名不合法";flag = false;}document.querySelector('#name_msg').innerHTML = errMsg;return flag;}document.querySelector('#username').addEventListener('blur', checkUsername);//2. 校验手机号function checkPhone(){ //true, 合法; false, 不合法;let flag = true;let phoneValue = document.querySelector('#phone').value;let errMsg = "";if(phoneValue.length != 11 ){errMsg = "手机号不合法";flag = false;}document.querySelector('#phone_msg').innerHTML = errMsg;return flag;}document.querySelector('#phone').addEventListener('blur', checkPhone)//3. 表单提交的时候 - 校验整个表单 - submitdocument.querySelector('form').addEventListener('submit', function(event){//判断用户名及手机号是否合法, 如果不合法, 提示错误信息;if(!checkUsername() || !checkPhone()){alert('表单数据不合法');//组织表单默认的提交事件event.preventDefault();//组织事件的默认行为}})</script>
</body></html>

注意:JavaScript中,可以通过事件对象event中的preventDefault() 方法来阻止事件的默认行为,比如阻止表单提交。

虽然表单校验功能,我们基于DOM操作已经完成了,成功的校验了用户名和密码的长度,长度不符合条件,直接提示错误信息,并不允许表单提交,看似非常完美。但是大家可以想一想,对于手机号,是只要11位就可以了吗? 如果出现如下的手机号,是合法的手机号吗?

  • 12209120990
  • 11009120990
  • 1220912abcd

我们发现,上述的字符串,长度都是11位,但是却不是合法的手机号 。因为手机号,是需要符合特定规则的,比如全部都是数字,而且第一位,必须是1,第二位,可以是 3/4/5/6/7/8/9 ,然后后面是9位数字。

那我们应该如何来校验类似于手机号这种,特定规则的字符串呢? 那此时呢,就需要通过正则表达式,来校验了,那接下来,我们就来学习正则表达式。

6.5 正则表达式

  • 介绍:正则表达式(Regular Expression,也简称为正则),定义了字符串组成的规则。

  • 作用:通常用来验证数据格式、查找替换文本 等。

  • 定义:

    • 正则表达式字面量 (注意不要加引号)

      const reg1 = /abc/;
      
    • 创建正则对象RegExp

      const reg2 = new RegExp('abc');
      
  • 方法:

    test(str):判断指定字符串是否符合规则,符合返回true;不符合返回false。

  • 语法:

    1. 普通字符:大多数的字符仅能描述它们本身,这些字符称作普通字符,比如字母和数字。

    2. 特殊字符:是一些具有特殊含义的字符,可以极大提高了灵活性和强大的匹配功能。

    3. 量词:表示要匹配的字符或表达式的数量。

符号含义
^表示以谁开始
$表示以谁结束
[]表示某个范围内的单个字符,如:[0-9]单个数字字符
.表示任意单个字符,除了换行和行结束符
\w代表单词字符:字母、数字、下划线(_),相当于[A-Za-z0-9_]
\d代表数字字符:相当于[0-9]
\s代表空格(包括换行符、制表符、空格等)
符号含义
?零个或一个
*零个或多个
+一个或多个(至少一个)
{n}n个
{m,}至少m个
{m,n}至少m个,最多n个

示例:

  <script>let str1 = 'hello World';let str2 = '二哈很二o';let str3 = 'er哈就是很二o';let str4 = '二哈就是很二';console.log(/\w+/.test(str1)); //trueconsole.log(/\w+/.test(str2)); //trueconsole.log(/\w+/.test(str3)); //trueconsole.log(/\w+/.test(str4)); //falseconst reg1 = /abc/;const reg2 = new RegExp('abc');console.log(reg1.test('my name is : abc')); //trueconsole.log(reg2.test('my name is : abc')); //true</script>

基本的正则表达式的语法,我们已经掌握了,那接下来,我们就需要通过正则表达式来校验表单中用户名、手机号了。 具体代码如下:

<!DOCTYPE html>
<html><head><title>表单</title><style>label {display: inline-block;width: 80px;text-align: right;margin-right: 10px;}input {width: 250px;padding: 10px;border: 1px solid #ccc;border-radius: 5px;margin-bottom: 10px;}.btn {width: 150px;}.tip {color: #ff0000;font-size: 12px;}</style>
</head><body><div><h1>用户注册</h1><form><label for="username">用户名:</label><input type="text" id="username" name="username" placeholder="用户名不能为空且长度在4-16个字符"><span class="tip" id="name_msg"></span> <br><label for="phone">手机号:</label><input type="text" id="phone" name="phone" placeholder="手机号不能为空且长度为11位"><span class="tip" id="phone_msg"></span><br><input type="submit" value="提交" class="btn"><input type="reset" value="重置" class="btn"></form></div><script>//在鼠标离开焦点时, 校验输入框内容的长度 .//校验用户名function checkUsername(){ //true, 合法; false, 不合法;let flag = true;let usernameValue = document.querySelector('#username').value;let errMsg = "";if(!/^\w{4,16}$/.test(usernameValue)){errMsg = "用户名不合法";flag = false;}document.querySelector('#name_msg').innerHTML = errMsg;return flag;}document.querySelector('#username').addEventListener('blur', checkUsername)//校验密码function checkPhone(){ //true, 合法; false, 不合法;let flag = true;let phoneValue = document.querySelector('#phone').value;let errMsg = "";if(!/^1[3-9]\d{9}$/.test(phoneValue)){errMsg = "手机号不合法";flag = false;}document.querySelector('#phone_msg').innerHTML = errMsg;return flag;}document.querySelector('#phone').addEventListener('blur', checkPhone)//在表单提交时, 判断是否所有的输入框输入的值合法 .document.querySelector('form').addEventListener('submit', (e)=> {if(!checkUsername() || !checkPhone()){alert('表单校验失败, 不能提交表单')e.preventDefault();}})</script>
</body></html>

7. JS模块化

所谓JS模块化,指的是JS提供的一种,将JavaScript程序拆分位若干个可按需导入的单独模块的机制。

比如,我们前面实现的表单校验的案例,我们是可以把JS代码单独的抽取到一个js文件中,然后在html中引入对应的js文件即可,这样做,便于管理、提升代码的复用性。具体操作如下:

A. 定义一个js文件,命名位 check.js

//在鼠标离开焦点时, 校验输入框内容的长度 .
//校验用户名
function checkUsername(){ //true, 合法; false, 不合法;let flag = true;let usernameValue = document.querySelector('#username').value;let errMsg = "";if(!/^\w{4,16}$/.test(usernameValue)){errMsg = "用户名不合法";flag = false;}document.querySelector('#name_msg').innerHTML = errMsg;return flag;
}
document.querySelector('#username').addEventListener('blur', checkUsername)//校验密码
function checkPhone(){ //true, 合法; false, 不合法;let flag = true;let phoneValue = document.querySelector('#phone').value;let errMsg = "";if(!/^1[3-9]\d{9}$/.test(phoneValue)){errMsg = "手机号不合法";flag = false;}document.querySelector('#phone_msg').innerHTML = errMsg;return flag;
}
document.querySelector('#phone').addEventListener('blur', checkPhone)//在表单提交时, 判断是否所有的输入框输入的值合法 .
document.querySelector('form').addEventListener('submit', (e)=> {if(!checkUsername() || !checkPhone()){alert('表单校验失败, 不能提交表单')e.preventDefault();}
})

B. 在html文件中,如果需要用到上述的JS代码,直接在 script 标签中引入该js即可。

<!DOCTYPE html>
<html><head><title>表单</title><style>label {display: inline-block;width: 80px;text-align: right;margin-right: 10px;}input {width: 250px;padding: 10px;border: 1px solid #ccc;border-radius: 5px;margin-bottom: 10px;}.btn {width: 150px;}.tip {color: #ff0000;font-size: 12px;}</style>
</head><body><div><h1>用户注册</h1><form><label for="username">用户名:</label><input type="text" id="username" name="username" placeholder="用户名不能为空且长度在4-16个字符"><span class="tip" id="name_msg"></span> <br><label for="phone">手机号:</label><input type="text" id="phone" name="phone" placeholder="手机号不能为空且长度为11位"><span class="tip" id="phone_msg"></span><br><input type="submit" value="提交" class="btn"><input type="reset" value="重置" class="btn"></form></div><script src="./js/check.js"></script>
</body></html>

OK,那这是在html中,引入JS文件,可以直接使用 <script src=".."></script> 来引入。 那如果是在一个js文件中,我需要用到另外一个js文件中的方法呢。 那此时该如何实现呢 ?

那在JS中,就给我们提供了模块化导入、导出的操作,我们可以通过 export 关键字,来导出模块。 然后在别的需要用到的地方,通过 import 关键字导入模块。

如下所示:

A. checkFn.js 中定义是校验方法

在变量前面加上 export 代表,我们要将该变量、函数、对象导出为一个模块。别的js中要想使用,就可以 import 导入了。

export function checkUsername(){ //true, 合法; false, 不合法;let flag = true;let usernameValue = document.querySelector('#username').value;let errMsg = "";if(!/^\w{4,16}$/.test(usernameValue)){errMsg = "用户名不合法";flag = false;}document.querySelector('#name_msg').innerHTML = errMsg;return flag;
}export function checkPhone(){ //true, 合法; false, 不合法;let flag = true;let phoneValue = document.querySelector('#phone').value;let errMsg = "";if(!/^1[3-9]\d{9}$/.test(phoneValue)){errMsg = "手机号不合法";flag = false;}document.querySelector('#phone_msg').innerHTML = errMsg;return flag;
}

B. check.js 中定义的是校验的事件监听

那在check.js中需要用到 checkUsername、checkPhone函数,就可以通过 import 关键字将其导入进来。

import {checkUsername, checkPhone} from './checkFn.js'//1. 校验用户名 - 失去焦点时校验 - blur
document.querySelector('#username').addEventListener('blur', checkUsername)//2. 校验手机号
document.querySelector('#phone').addEventListener('blur', checkPhone)//3. 表单提交的时候 - 校验整个表单 - submit
document.querySelector('form').addEventListener('submit', function(event){//判断用户名及手机号是否合法, 如果不合法, 提示错误信息;if(!checkUsername() || !checkPhone()){alert('表单数据不合法');//组织表单默认的提交事件event.preventDefault();//组织事件的默认行为}
})

C. xxx.html 中就是html的基础代码样式

注意:如果我们使用到了 export, import 这种模块化的js,那在通过 <script src="..."></script> 在引入JS文件时,必须指定 type="module" 属性,表名我们使用的是模块化的JS。 如下所示:

<!DOCTYPE html>
<html><head><title>表单</title><style>label {display: inline-block;width: 80px;text-align: right;margin-right: 10px;}input {width: 250px;padding: 10px;border: 1px solid #ccc;border-radius: 5px;margin-bottom: 10px;}.btn {width: 150px;}.tip {color: #ff0000;font-size: 12px;}</style>
</head><body><div><h1>用户注册</h1><form><label for="username">用户名:</label><input type="text" id="username" name="username" placeholder="用户名不能为空且长度在4-16个字符"><span class="tip" id="name_msg"></span> <br><label for="phone">手机号:</label><input type="text" id="phone" name="phone" placeholder="手机号不能为空且长度为11位"><span class="tip" id="phone_msg"></span><br><input type="submit" value="提交" class="btn"><input type="reset" value="重置" class="btn"></form></div><!-- 模块化JS引入方式,需要指定type="module" --><script type="module" src="./js/check.js"></script>
</body></html>

注意:如果使用模块的js,使用了 exportimport ,要保证我们的代码,一定是在服务器端运行,而不是在磁盘中直接打开。 所以运行的时候,在VSCode中已经要右键选择 “Open with Live Server”。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/505702.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

有收到腾讯委托律师事务所向AppStore投诉带有【水印相机】主标题名称App的开发者吗

近期&#xff0c;有多名开发者反馈&#xff0c;收到来自腾讯科技 (深圳) 有限公司委托北京的一家**诚律师事务所卞&#xff0c;写给AppStore的投诉邮件。 邮件内容主要说的是&#xff0c;腾讯注册了【水印相机】这四个字的商标&#xff0c;所以你们这些在AppStore上的app&…

2024年度漏洞态势分析报告,需要访问自取即可!(PDF版本)

2024年度漏洞态势分析报告&#xff0c;需要访问自取即可!(PDF版本),大家有什么好的也可以发一下看看

moviepy 将mp4视频文件提取音频mp3 - python 实现

DataBall 助力快速掌握数据集的信息和使用方式&#xff0c;会员享有 百种数据集&#xff0c;持续增加中。 需要更多数据资源和技术解决方案&#xff0c;知识星球&#xff1a; “DataBall - X 数据球(free)” -------------------------------------------------------------…

算法(二)——一维差分、等差数列差分

文章目录 一维差分、等差数列差分一维差分例题&#xff1a;航班预订统计 等差数列差分例题&#xff1a;三步必杀例题&#xff1a;Lycanthropy 一维差分、等差数列差分 一维差分 差分解决的是 区间修改&#xff08;更新&#xff09;问题&#xff0c;特别是多次区间修改问题&…

深度学习笔记11-优化器对比实验(Tensorflow)

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 目录 一、导入数据并检查 二、配置数据集 三、数据可视化 四、构建模型 五、训练模型 六、模型对比评估 七、总结 一、导入数据并检查 import pathlib,…

FreeROTS学习 内存管理

内存管理是一个系统基本组成部分&#xff0c;FreeRTOS 中大量使用到了内存管理&#xff0c;比如创建任务、信号量、队列等会自动从堆中申请内存&#xff0c;用户应用层代码也可以 FreeRTOS 提供的内存管理函数来申请和释放内存 FreeRTOS 内存管理简介 FreeRTOS 创建任务、队列…

【设计模式】介绍常见的设计模式

&#x1f970;&#x1f970;&#x1f970;来都来了&#xff0c;不妨点个关注叭&#xff01; &#x1f449;博客主页&#xff1a;欢迎各位大佬!&#x1f448; 文章目录 ✨ 介绍一下常见的设计模式✨ Spring 中常见的设计模式 这期内容主要是总结一下常见的设计模式&#xff0c;可…

6 分布式限流框架

限流的作用 在API对外互联网开放的情况下&#xff0c;是无法控制调用方的行为的。当遇到请求激增或者黑客攻击的情况下&#xff0c;会导致接口占用大量的服务器资源&#xff0c;使得接口响应效率的降低或者超时&#xff0c;更或者导致服务器宕机。 限流是指对应用服务进行限制…

【动态规划篇】欣赏概率论与镜像法融合下,别出心裁探索解答括号序列问题

本篇鸡汤&#xff1a;没有人能替你承受痛苦&#xff0c;也没有人能拿走你的坚强. 欢迎拜访&#xff1a;羑悻的小杀马特.-CSDN博客 本篇主题&#xff1a;带你解答洛谷的括号序列问题&#xff08;绝对巧解&#xff09; 制作日期&#xff1a;2025.01.10 隶属专栏&#xff1a;C/C题…

数据库高安全—角色权限:权限管理权限检查

目录 3.3 权限管理 3.4 权限检查 书接上文数据库高安全—角色权限&#xff1a;角色创建角色管理&#xff0c;从角色创建和角色管理两方面对高斯数据库的角色权限进行了介绍&#xff0c;本篇将从权限管理和权限检查方面继续解读高斯数据库的角色权限。 3.3 权限管理 &#x…

深入浅出负载均衡:理解其原理并选择最适合你的实现方式

负载均衡是一种在多个计算资源&#xff08;如服务器、CPU核心、网络链接等&#xff09;之间分配工作负载的技术&#xff0c;旨在优化资源利用率、提高系统吞吐量和降低响应时间。负载均衡的实现方式多种多样&#xff0c;以下是几种常见的实现方式&#xff1a; 1. 硬件负载均衡&…

Training-free regional prompting for diffusion transformers

通过语言模型来构建位置关系的,omnigen combine来做位置生成,其实可以通过大模型来做,不错。 1.introduction 文生图模型在准确处理具有复杂空间布局的提示时仍然面临挑战,1.通过自然语言准确描述特定的空间布局非常困难,特别是当对象数量增加或需要精确的位置控制时,2.…

麦田物语学习笔记:背包物品选择高亮显示和动画

如题,本篇文章没讲动画效果 基本流程 1.代码思路 (1)先用点击事件的接口函数去实现,点击后反转选择状态(isSelected),以及设置激活状态(SetActive),并且还需要判断该格子是否为空,空格子是点不动的,完成后以上后,出现的问题是高亮应该是有且仅有一个格子是高亮的,而现在可以让…

Linux:深入了解fd文件描述符

目录 1. 文件分类 2. IO函数 2.1 fopen读写模式 2.2 重定向 2.3 标准文件流 3. 系统调用 3.1 open函数认识 3.2 open函数使用 3.3 close函数 3.4 write函数 3.5 read函数 4. fd文件描述符 4.1 标准输入输出 4.2 什么是文件描述符 4.3 语言级文件操作 1. 文件分类…

数据结构:栈(Stack)和队列(Queue)—面试题(一)

目录 1、括号匹配 2、逆波兰表达式求值 3、栈的压入、弹出序列 4、最小栈 1、括号匹配 习题链接https://leetcode.cn/problems/valid-parentheses/description/ 描述&#xff1a; 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] …

51单片机(一) keil4工程与小灯实验

直接开始 新建一个工程 在这里插入图片描述 添加文件 另存为 添加文件到组 写下一个超循环系统代码 调整编译项编译 可以在工程目录找到编译好的led_fst.hex 自行烧写到各自的开发板。 会看到什么都没有。 现在定义一个GPIO端口与小灯的连接&#xff0c;再点亮小灯…

基于 Python 和 OpenCV 的人脸识别上课考勤管理系统

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

Vue2:el-table中的文字根据内容改变颜色

想要实现的效果如图,【级别】和【P】列的颜色根据文字内容变化 1、正常创建表格 <template><el-table:data="tableData"style="width: 100%"><el-table-column prop="id" label="ID"/> <el-table-column …

案例研究:UML用例图中的结账系统

在软件工程和系统分析中&#xff0c;统一建模语言&#xff08;UML&#xff09;用例图是一种强有力的工具&#xff0c;用于描述系统与其用户之间的交互。本文将通过一个具体的案例研究&#xff0c;详细解释UML用例图的关键概念&#xff0c;并说明其在设计结账系统中的应用。 用…

73.矩阵置零 python

矩阵置零 题目题目描述示例 1&#xff1a;示例 2&#xff1a;提示&#xff1a; 题解思路分析Python 实现代码代码解释提交结果 题目 题目描述 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例…