什么是JavaScript?
概述
JavaScript是一门世界上最流行的脚本语言
历史
ECMAScript可以理解为JavaScript的一个标准
最新版本已经是 es6 版本
但是大部分浏览器还只停留在 es5 代码上
这就会导致 开发环境----线上环境,版本不一致
快速入门
引入JavaScript
内部引入
javascript
<!-- script标签内,写JavaScript代码-->
<script>
alert('HELLO WORLD');
</script>
外部引入
javascript
// Ling.js
alert('Hello World!');
// index.html
<!--外部引入-->
<!--注意:script必须成对出现-->
<script src="js/Ling.js"></script>
测试代码
javascript
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- script标签内,写JavaScript代码-->
<!-- <script>-->
<!-- alert('HELLO WORLD');-->
<!-- </script>-->
<!--外部引入-->
<!--注意:script必须成对出现-->
<script src="js/Ling.js"></script>
<!--不用显示type,也默认就是JavaScript-->
<!-- <script type="text/javascript">-->
<!-- </script>-->
</head>
<body>
<!--这里也可以存放-->
</body>
</html>
基本语法入门
javascript
<script>
// 1. 定义变量 变量类型 变量名 = 变量值;
// var num = 1;
// alert(num);
// var name = "LING";
// alert(name);
var score = 71;
// 2. 条件控制
if (score > 60 && score < 70) {
alert("60-70");
} else if (score > 70 && score < 80) {
alert("70-80");
} else {
alert("other");
}
</script>
浏览器必备调试须知
数据类型
数值、文本、图形、音频、视频......
变量
变量不能以数字开头
javascript
var num = 1;
number
js 不区分小数和整数,Number
javascript
123 // 整数123
123.1 // 浮点数123.1
1.123e3 // 科学计数法
-99 // 负数
NaN // NOT A NUMBER
Infinity // 表示无限大
字符串
'abc' "abc"
布尔值
true、false
逻辑运算
javascript
&& // 两个都为真,结果为真
|| // 一个为真,结果为真
! // 真即假,假即真
比较运算符
javascript
=
== 等于(类型不一样,纸一样,也会判断为true)
=== 绝对等于(类型一样,值一样,结果为true)
这是一个JS的缺陷,坚持不要使用 == 比较
须知:
NaN===NaN,这个与所有的数值都不相等,包括自己
只能通过 isNaN(NaN) 来判断这个数是否是 NaN
浮点数问题
javascript
console.log((1/3) === (1-2/3))
尽量避免使用浮点数进行运算,存在精度问题!
javascript
Math.abs(1/3-(1-2/3))<0.0000001
null 和 undefined
- null 空
- undefined 未定义
数组
Java的数组中必须是相同类型的对象,但JS中不需要这样!
javascript
// 保证代码的可读性,尽量使用[]
var arr = [1,2,3,4,"hello",null,true]
new Array(1,2,3,4,"hello",nulltrue);
取数组下标,如果越界了,就会 undefined
对象
对象是大括号,数组是中括号
每个属性之间使用逗号隔开,最后一个属性不需要
javascript
// Person person = new Person(1,2,3,4,5);
var person = {
name: "lingsuu",
age: 3,
tags: ['js','java','前端']
}
取对象的值
javascript
person.age
> 3
person.name
> 'lingsuu'
person.tags
> ['js', 'java', '前端']
严格检查格式
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!--
'use strict'; 代表严格检查模式,预防JavaScript的随意性导致产生的一些问题
必须写在JavaScript的第一行
局部变量建议都使用 let 去定义
-->
<script>
'use strict';
let i = 1;
</script>
</head>
<body>
</body>
</html>
数据类型
字符串
正常字符串我们使用单引号 或者双引号包裹
注意转义字符 \
html
\'
\n
\t
\u4e2d \u#### unicode 字符
\x41 ASCII字符
多行字符串编写
符号是 tab 键的上面
javascript
var msg =
`hello
world
lingsuu`
模板字符串
javascript
let name = 'ling'
let age = 3
let msg = `你好啊,${name}`
字符串长度
javascript
str.length
字符串的可变性:不可变
大小写转换
javascript
// 注意:这里是方法,不是属性了
student.toUppercase()
student.toLowerCase()
获取指定字符的索引
javascript
student.indexOf('t')
截取字符串
javascript
student.substring(1) // 从第一个字符开始截取
student.substring(1,3) // [1,3)
数组
Array可以包含任意的数据类型
javascript
var arr = [1,2,3,4,5] // 通过下标取值和赋值
长度
javascript
arr.length
注意:加入给 arr.length 赋值,数组大小就会发生变化;如果赋值过小,元素就会丢失
indexOf
获取指定数据的下标索引
javascript
arr.indexOf(2)
1
字符串的 "1" 和数字 1 是不一样的
slice()
截取Array的一部分,返回一个新的数组,同样是包头不包尾
push()、pop()
javascript
push: 压入到尾部
pop:弹出尾部的一个元素
unshift()、shift()
javascript
unshift: 压入到头部
shift:弹出头部的一个元素
排序 sort()
元素反转 reverse()
concat()
拼接的是数组
注意:返回的是一个新的数组,并没有修改原来的数组
连接符 join()
打印拼接数组,使用特定的字符串连接,得加上单引号
多维数组
数组:存储数据(如何存,如何取,方法都可以自己实现!)
对象
若干个键值对 key:value
javascript
var 对象名 = {
属性名:属性值,
属性名:属性值,
属性名:属性值,
属性名:属性值
}
// 定义了一个person对象,它有四个属性
let person = {
name: "lingsuu",
age: 3,
email: "2479433253@qq.com",
score: 0
}
JS中的对象,{......}表示一个对象,键值对描述属性 XXX:XXX,多个属性之间使用逗号隔开,最后一个属性不加逗号!
JavaScript中的所有的键都是字符串,值是任意对象!
对象赋值
使用一个不存在的对象属性,不会报错!
动态的删减属性,通过 delete 删除对象的属性
动态的添加,直接给新的属性添加值即可
判断属性值是否在这个对象中! XXX in XXX
虽然在 person 这个对象中 没有 toString 这个属性,但是在 person 的父类中,存在这个属性,因此也会返回 true
判断一个属性是否是这个对象自身拥有的 hasOwnProperty()
流程控制
if判断
javascript
var age = 3;
if (age>3){
alert("hh");
} else if() {
...
} else {
alert("xx")
}
while循环,避免程序死循环
javascript
while(age<100){
age = age + 1;
console.log(age);
}
do{
age = age + 1;
console.log(age);
}while(age<100);
for循环
javascript
for (let i = 0; i < 100; i++) {
age = age + 1;
console.log(age)
}
forEach循环
javascript
age.forEach(function (e) {
console.log(e)
})
for...in循环
javascript
var age = [1,45,65,3,87,34,56];
for(var num in age) {
if (age.hasOwnProperty(num)){
console.log("存在");
console.log(age[num])
}
}
Map 和 Set
ES6的新特性
Map:
javascript
var map = new Map([['tom',100],['jack',99]]);
var name = map.get('tom');
map.set("ling",123); // 新增或修改
map.delete("tom"); // 删除
Set:无序不重复的集合
javascript
var set = new Set([3,1,1,1,1]); // set可以去重
set.add(2); // 添加
set.delete(1); // 删除
console.log(set.has(3)) // 是否包含某个元素
iterator
遍历数组
javascript
// 通过for of 实现
let arr = [3,4,5];
for (let i of arr) {
console.log(i);
}
遍历Map
javascript
let map = new Map([["tom",100],["jack",90],["haha",80]]);
for (let i of map) {
console.log(i);
}
遍历Set
javascript
let set = new Set([3,4,5]);
for (let i of set) {
console.log(i)
}
函数
定义函数
定义方式一
绝对值函数
javascript
function abs(x) {
if(x>=0) {
return x;
} else {
return -x;
}
}
一旦执行到 return 代表函数结束,返回结果!
如果没有执行 return,函数执行完也会返回结果,结果就是 undefined
定义方式二
javascript
var abs = function(x) {
if(x>=0) {
return x;
} else {
return -x;
}
}
function(x){...}这是一个匿名函数,但是可以把结果赋值给 abs,通过 abs 就可以调用函数!
方式一和方式二等价!
调用函数
参数问题:JavaScript 可以传任意个参数,也可以不传递参数
假设不存在参数,如何规避?
javascript
var abs = function(x) {
// 手动抛出异常来判断
if (typeof x!== 'number') {
throw 'Not A Number';
}
if(x>=0) {
return x;
} else {
return -x;
}
}
arguments
arguments 是一个JavaScript 免费赠送的关键字
arguments 代表传递进来的所有参数,是一个数组
javascript
var abs = function(x) {
console.log("x=>"+x);
for (let i = 0; i < arguments.length; i++) {
console.log(arguments[i]);
}
if(x>=0) {
return x;
} else {
return -x;
}
}
问题:arguments 包含所有的参数,我们有时候想使用多余的参数来进行附加操作,需要排除已有的参数
rest
以前:
javascript
if (arguments.length > 2) {
for (var i = 2; i < arguments.length; i++) {
// ...
}
}
获取除了已经定义的参数之外的所有参数
javascript
function aaa(a,b,...rest) {
console.log("a=>"+a);
console.log("b=>"+b);
console.log(rest);
}
rest 参数只能写在最后面,必须用...标识
变量的作用域
在JavaScript中,var 定义变量实际上是有作用域的
假设在函数体中声明,则在函数体外不可以使用(非要实现的话,需要研究一下闭包)
javascript
function ling() {
var x = 1;
x = x + 1;
}
x = x + 2; // Uncaught ReferenceError: x is not defined
如果两个函数使用了相同的变量名,但是只要是在函数内部,就不冲突
javascript
function ling() {
var x = 1;
x = x + 1;
}
function lingsuu() {
var x = 'a';
x = x + 1;
}
内部函数可以调用外部函数的成员,反之则不行
javascript
function ling() {
var x = 1;
// 内部函数可以访问外部函数的成员,反之则不行
function lingsuu() {
var y = x + 1;
}
var z = y + 1; // Uncaught ReferenceError: y is not defined
}
假设内部函数变量和外部函数的变量重名
javascript
function ling() {
var x = 1;
function lingsuu() {
var x = 'A';
console.log('inner' + x); // innerA
}
console.log('outer' + x); // outer1
lingsuu();
}
- 假设在JavaScript中,函数查找变量从自身函数开始,由内向外查找
- 假设外部存在这个同名的函数变量,则内部函数会屏蔽外部函数的变量
提升变量的作用域
javascript
function ling() {
var x = "x" + y;
console.log(x);
var y = "y";
}
结果:xundefined
说明:JavaScript 执行引擎,自动提升了 y 的声明,但是不会提升变量 y 的赋值
javascript
function lingsuu() {
var y;
var x = "x" + y;
console.log(x);
y = 'y';
}
这个是在JavaScript建立之初就存在的特性。养成规范:所有的变量定义都放在函数的头部,不要乱放,便于代码维护。
javascript
function lingsuu() {
var x = 1,
y = x + 1,
z,i,a; // undefined
// 之后随意用
}
全局函数
javascript
// 全局变量
var x = 1;
function ling() {
console.log(x);
}
ling();
console.log(x);
全局对象 window
javascript
var x = 'xxx';
alert(x);
alert(window.x); // 默认所有的全局变量,都会自动绑定在 window 对象下
alert() 这个函数本身也是一个 window对象
javascript
var x= "xxx";
window.alert(x);
var old_alert = window.alert;
// old_alert();
window.alert = function () {
}
// 发现 alert() 失效了
window.alert(123);
// 恢复
window.alert = old_alert;
window.alert(123456);
JavaScript 实际上只有一个全局作用域,任何变量(函数也可以是为变量),假设没有在函数作用范围内找到,就会向外查找,如果在全局作用域都没有找到,就会报错 ReferenceError
规范
由于我们所有的全局变量都会绑定到我们的 window 上,如果不同的 js 文件,使用了享用的全局变量,如何减少冲突?
javascript
// 唯一全局变量
var LINGSUU = {};
// 定义全局变量
LINGSUU.name = "lingsuu";
LINGSUU.add = function (a,b) {
return a + b;
}
把自己的代码全部放入到自己定义的唯一空间名字中,降低全局命名冲突的问题
JQuery
局部作用域 let
javascript
function aaa() {
for (var i = 0; i < 100; i++) {
console.log(i);
}
console.log(i+1); // i 出了这个作用域还可以使用
}
let 关键字,解决局部作用域冲突的问题
javascript
function aaa() {
for (let i = 0; i < 100; i++) {
console.log(i);
}
console.log(i+1); // Uncaught ReferenceError: i is not defined
}
建议使用 let 去定义局部作用域的变量
常量 const
在 ES6 之前,怎么定义常量:只要用全部大写字母命名的变量就是常量;建议不要修改这样的值
javascript
var PI = '3.14';
console.log(PI);
PI = '123'; // 可以改变这个值
console.log(PI);
在 ES6 引入了常量的关键字 const
javascript
const PI = '3.14'; // 只读变量
console.log(PI);
PI = '123'; // 不能修改,直接报错
console.log(PI); // Uncaught TypeError: Assignment to constant variable
方法
定义
方法就是把函数放在对象的里面,对象只有两个东西:属性和方法
javascript
var lingsuu = {
name: "ling",
birth: "2003",
// 方法
age: function () {
var now = new Date().getFullYear();
return now - this.birth;
}
}
//属性
lingsuu.name
//方法,一定要带()
lingsuu.age()
this代表什么?
javascript
function getAge() {
var now = new Date().getFullYear();
return now - this.birth;
}
var lingsuu = {
name: "ling",
birth: "2003",
// 方法
age: getAge
}
// lingsuu.age() ok
// getAge() NaN
this是无法指向的,是默认只想他调用它的那个对象
apply
在 js 中可以控制 this 的指向
javascript
function getAge() {
var now = new Date().getFullYear();
return now - this.birth;
}
var lingsuu = {
name: "ling",
birth: "2003",
// 方法
age: getAge
}
getAge.apply(lingsuu,[]); // this指向了lingsuu这个对象,参数为空
内部对象
标准对象
Date
基本使用
javascript
var now = new Date(); // Thu Oct 24 2024 15:17:03 GMT+0800 (中国
now.getFullYear(); // 年
now.getMonth(); // 月 0~11 代表月
now.getDate(); // 日
now.getDay(); // 星期几
now.getHours(); // 时
now.getMinutes(); // 分
now.getSeconds(); // 秒
now.getTime(); // 时间戳 全世界同意 1970 1.1 00:00:00 到现在的毫秒数
console.log(new Date(1729754500805)); // 时间戳转换为时间
转换
javascript
> now = new Date(1729754500805)
< Thu Oct 24 2024 15:21:40 GMT+0800 (中国标准时间)
> now.toLocaleString() // 注意:调用是一个方法,不是一个属性
< '2024/10/24 15:21:40'
> now.toGMTString()
< 'Thu, 24 Oct 2024 07:21:40 GMT'
JSON
- JSON 是一种轻量级的数据交换格式
- 简洁和清晰的层次结构使得JSON被称为理想的数据交换语言
- 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率
在JavaScript中,一切皆为对象,任何 js 支持的类型都可以用JSON来标识
格式:
- 对象都用 { }
- 数组都用 [ ]
- 所有的键值对 都使用 key:value
JSON字符串和JS对象的传化
javascript
var user = {
name: "lingsuu",
age: 3,
sex: '男'
}
// 对象转化为JSON字符串 {"name":"lingsuu","age":3,"sex":"男"}
var jsonuser = JSON.stringify(user)
// JSON 字符串转化为对象 参数为JSON字符串
var obj = JSON.parse('{"name":"lingsuu","age":3,"sex":"男"}');
JSON 和 JS 对象的区别
javascript
var obj = {a: 'hello',b: 'hellob'};
var json = '{"a": "hello","b": "hellob"}';
Ajax
- 原生的js写法 xhr 异步请求
- jQuery 封装好的方法 $("#name").ajax("")
- axious 请求
面向对象编程
什么是面向对象
- 类:模板 原型对象
- 对象:具体的实例
在 JavaScript 中需要换一下思维方式
原型
javascript
var Student = {
name: "lingsuu",
run: function () {
console.log(this.name + ' run...')
}
}
var xiaoming = {
name: 'xiaoming'
}
// 将小明的原型设置为Student
xiaoming.__proto__ = Student;
var Bird = {
name: 'ling',
fly: function () {
console.log(this.name + ' fly...')
}
}
xiaoming.__proto__ = Bird;
javascript
function Student(name) {
this.name = name;
}
// 给Student新增一个方法
Student.prototype.hello = function () {
alert('Hello')
}
class 继承
class关键字,是在ES6引入的
定义一个类,属性、方法
javascript
class Student {
constructor(name) {
this.name = name;
}
hello(){
alert('hello')
}
}
var xiaoming = new Student("xiaoming");
var xiaohong = new Student("xiaohong");
> xiaoming.hello();
继承
javascript
class Student {
constructor(name) {
this.name = name;
}
hello(){
alert('hello')
}
}
class XiaoStudent extends Student{
constructor(name,grade) {
super();
this.grade = grade;
}
myGrade() {
alert('我是一名小学生')
}
}
var xiaoming = new Student("xiaoming");
var xiaohong = new XiaoStudent("xiaohong", 1);
本质:查看对象原型
原型链
proto
操作BOM对象(重点)
浏览器介绍
JavaScript 和 浏览器关系?
JavaScript 诞生就是为了让他在浏览器中运行!
BOM:浏览器对象模型
- IE 6~11
- Chrome
- Safari
- FireFox
三方
- QQ浏览器
- 360浏览器
window对象
window 代表 浏览器窗口
javascript
> window.alert(1)
< undefined
> window.innerHeight
< 385
> window.innerWidth
< 854
> window.outerHeight
< 1026
> window.outerWidth
< 868
// 可以调整浏览器窗口试试
navigator(不建议使用)
navigator,封装了浏览器的信息
javascript
> navigator.appName
< 'Netscape'
> navigator.appVersion
< '5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/130.0.0.0 Safari/537.36'
> navigator.userAgent
< 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/130.0.0.0 Safari/537.36'
> navigator.platform
< 'Win32'
大多数时候,不会使用navigator对象,应为会被人为修改!
不建议使用这些属性来判断和编写代码
screen
代表屏幕的尺寸
javascript
> screen.width
< 1707
> screen.height
< 1067
location
location 代表当前页面的URL信息
javascript
host: "www.baidu.com" // 主机
href: "https://www.baidu.com/" // 当前路径
protocol: "https:" // 协议
reload: ƒ reload() // 刷新网页
// 设置新的地址
location.assign('其他路径')
document(内容:DOM)
document 代表当前的页面,HTML DOM文档树
javascript
> document.title
< '百度一下,你就知道'
> document.title = 'LINGSUU'
< 'LINGSUU'
获取具体的文档树节点
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<dl id="app">
<dt>JAVA</dt>
<dd>JavaSE</dd>
<dd>JavaEE</dd>
</dl>
<script>
let byId = document.getElementById('app');
</script>
</body>
</html>
获取 cookie
html
document.cookie
劫持 cookie 原理
html
<script src = "aa.js"></script>
<!--恶意人员:获取你的cookie上传到他的服务器-->
服务器端可以设置 cookie:httpOnly
history(不建议使用)
history 代表浏览器的历史记录
html
history.forward() // 前进
history.back() // 后退
操作DOM对象(重点)
DOM:文档对象模型
核心
浏览器网页就是一个 DOM 树形结构!
- 更新:更新 DOM 节点
- 遍历 DOM 节点:得到 DOM 节点
- 删除:删除一个 DOM 节点
- 添加:添加一个新的节点
要操作一个 DOM 节点,就必须要先获得这个 DOM 节点
获得 DOM 节点
javascript
// 对应CSS选择器
var h1 = document.getElementsByTagName('h1');
var p1 = document.getElementById('p1');
var p2 = document.getElementsByClassName('p2');
var father = document.getElementById('father');
var children = father.children; // 获取父节点下的所有子节点
var firstChild = father,firstChild; // 获得父节点下的第一个子节点
var lastChild = father.lastChild; // 获得父节点下最后一个子节点
这是原生代码,之后尽量使用 JQuery();
更新节点
javascript
<div id="id1">
</div>
<script>
var id1 = document.getElementById('id1');
</script>
修改文本的值
javascript
id1.innerText = "456"
可以解析HTML文本标签
javascript
id1.innerHTML='<strong>123</strong>'
操作css
javascript
id1.style.color = 'red' // 属性使用字符串包裹
id1.style.fontSize = '200px' // 下划线转驼峰命名问题
id1.style.padding = '100px'
删除节点
删除节点的步骤:先获取父节点,再通过父节点删除自己
javascript
<div id="father">
<h1>标题一</h1>
<p id="p1">p1</p>
<p class="p2">p2</p>
</div>
<script>
var self = document.getElementById('p1');
var father = p1.parentElement;
father.removeChild(self);
// 删除一个动态的过程
father.removeChild(father.children[0])
father.removeChild(father.children[1])
father.removeChild(father.children[2])
</script>
注意:删除多个节点的时候,children 是在是可变化的,删除的时候一定要注意
插入节点
我们获得了某个 DOM 节点,假设这个 DOM 节点是空的,我们通过 innerHTML 就可以增加一个元素;但是如果这个 DOM 节点意见存在元素,就不能这么干,不然会覆盖。
追加
html
<p id="js">JavaScript</p>
<div id="list">
<p id="se">JavaSE</p>
<p id="ee">JavaEE</p>
<p id="me">JavaME</p>
</div>
<script>
let js = document.getElementById('js');
let list = document.getElementById('list');
list.appendChildren(js); // 追加到后面
</script>
创建一个新的标签,实现插入
javascript
<script>
let js = document.getElementById('js'); // 已存在的节点
let list = document.getElementById('list');
// 通过js创建一个新的节点
let newP = document.createElement('p');
newP.id = 'newP';
newP.innerText = 'Hello World';
list.appendChild(newP);
// 创建一个标签节点
let myScript = document.createElement('script');
myScript.setAttribute('type','text/javascript');
// 可以创建一个style标签
var myStyle = document.createElement('style'); // 创建了一个空的style标签
myStyle.setAttribute('type','text/css');
myStyle.innerHTML = 'body{background-color: red;}' // 设置标签内容
let head = document.getElementsByTagName('head');
head[0].appendChild(myStyle);
</script>
insertBefore
javascript
let ee = document.getElementById('ee');
let js = document.getElementById('js');
let list = document.getElementById('list');
// 要包含的节点.insertBefore(newNode, targetNode);
list.insertBefore(js,ee);
操作表单(验证)
表单是什么?
form、DOM树
- 文本框 text
- 密码框 password
- 下拉框 < select >
- 单选框 radio
- 多选框 checkbox
- 隐藏域 hidden
- ......
表单的目的:提交信息
获得要提交的信息
html
<form action="post">
<p><span>用户名:</span><input type="text" id="username"></p>
<!-- 无论是单选框还是多选框,获得的之就是定义好的value -->
<p>
<span>性别:</span>
<input type="radio" name="sex" value="boy" id="boy"> 男
<input type="radio" name="sex" value="girl" id="girl"> 女
</p>
</form>
<script>
let input_text = document.getElementById('username');
let boy_radio = document.getElementById('boy');
let girl_radio = document.getElementById('girl');
// 的到输入框的值
input_text.value
// 修改输入框的值
input_text.value = '123'
// 对于单选框、多选框等等固定的值,用boy_radio.value只能取到当前的值
boy_radio.checked; // 查案返回的结果是否为true,如果为true,则被选中
girl_radio.checked = true; // 赋值
</script>
提交表单
md5加密密码,表单优化
html
<!--表单绑定提交事件
onsubmit= 绑定一个提交检测的函数, true false
将这个结果返回给表单,使用 onsubmit 接收
onsubmit="return contain()"
-->
<form action="http://www.baidu.com" method="post" onsubmit="contain()">
<p>
<span>用户名:</span><input type="text" id="username" name="username">
</p>
<p>
<span>密码:</span><input type="password" id="input-password" >
</p>
<input type="hidden" id="md5-password" name="password">
<!-- 绑定事件 onclick 被点击 -->
<button type="submit">提交</button>
</form>
<script>
function contain() {
let username = document.getElementById("username");
let password = document.getElementById("input-password");
let md5password = document.getElementById("password");
md5password.value = md5(password.value)
// 可以校验判断表单内容,ture就是通过提交,false就是组织提交
return true;
}
</script>
jQuery
JavaScript 和 jQuery库 的关系
jQuery库 里面存在大量的 JavaScript 函数
获取jQuery
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- CDN 引入 -->
<!-- <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>-->
<script src="lib/jquery-3.7.1.js"></script>
</head>
<body>
<!--
公式:$(selector).action()
-->
<a href="" id="test-jquery">点我</a>
<script>
// document.getElementById('test-jquery');
// 选择器就是css的选择器
$('#test-jquery').click(function () {
alert('hello world')
})
</script>
</body>
</html>
选择器
javascript
// 原生js,选择器少,麻烦不好记
// 标签选择器
document.getElementsByTagName()
// id选择器
document.getElementById()
// class选择器
document.getElementsByClassName()
// jQuery css 中的选择器全部都能用
$('p').click() // 标签选择器
$('#id1').click() // id选择器
$('.class1').click() // class选择器
文档工具站
事件
鼠标事件,键盘事件,其他事件
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="lib/jquery-3.7.1.js"></script>
<style>
#divMove{
width: 500px;
height: 500px;
border: 1px solid red;
}
</style>
</head>
<body>
<!--获取鼠标当前的一个坐标-->
mouse: <span id="mouseMove"></span>
<div id="divMove">
在这里移动鼠标试试
</div>
<script>
// 当网页元素加载完毕之后,响应事件
$(function () {
$('#divMove').mousemove(function (e) {
$('#mouseMove').text('x:' + e.pageX + 'y:' + e.pageY)
})
})
</script>
</body>
</html>
操作 DOM
节点文本操作
html
$('#test-ul li[name=java]').test() // 获得值
$('#test-ul li[name=java]').test('设置值') // 设置值
$('#test-ul).html() // 获得值
$('#test-ul).html('<strong>123</strong>') // 设置值
css的操作
单元素
html
$('#test-ul li[id=java]').css('color','red')
多元素
html
$('#test-ul li[name=java]').css({'color':'red','fontSize': '100px'})
元素的显示和隐藏
本质上 display: none;
隐藏
html
$('#test-ul li[name=java]').hide()
显示
html
$('#test-ul li[name=java]').show()
娱乐
html
$(window).width()
$(window).height()
$('#test-ul li[name=java]').toggle() // 显示就隐藏,隐藏就显示