JavaScript基本语法

什么是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,封装了浏览器的信息

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>
html 复制代码
document.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

jQueryhttps://jquery.com/

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选择器

文档工具站

jQuery API 中文文档 | jQuery API 中文在线手册 | jquery api 下载 | jquery api chmhttp://jquery3.yanzhihui.com/index.html

事件

鼠标事件,键盘事件,其他事件

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() // 显示就隐藏,隐藏就显示
相关推荐
梦想科研社5 分钟前
【无人机设计与控制】红嘴蓝鹊优化器RBMO求解无人机路径规划MATLAB
开发语言·matlab·无人机
混迹网络的权某8 分钟前
每天一道C语言精选编程题之求数字的每⼀位之和
c语言·开发语言·考研·算法·改行学it·1024程序员节
一只特立独行的猪6111 小时前
Java面试题——微服务篇
java·开发语言·微服务
IronmanJay3 小时前
【LeetCode每日一题】——862.和至少为 K 的最短子数组
数据结构·算法·leetcode·前缀和·双端队列·1024程序员节·和至少为 k 的最短子数组
码农幻想梦3 小时前
实验九 视图的使用
前端·数据库·oracle
喵手3 小时前
Java 与 Oracle 数据泵实操:数据导入导出的全方位指南
java·开发语言·oracle
硬汉嵌入式4 小时前
H7-TOOL的LUA小程序教程第16期:脉冲测量,4路PWM,多路GPIO和波形打印(2024-10-25, 更新完毕)
开发语言·junit·小程序·lua
加载中loading...4 小时前
Linux线程安全(二)条件变量实现线程同步
linux·运维·服务器·c语言·1024程序员节
Wx120不知道取啥名4 小时前
C语言之长整型有符号数与短整型有符号数转换
c语言·开发语言·单片机·mcu·算法·1024程序员节
开心工作室_kaic5 小时前
ssm010基于ssm的新能源汽车在线租赁管理系统(论文+源码)_kaic
java·前端·spring boot·后端·汽车