JavaScript随笔

JavaScript

什么是JavaScript

一、概述

JavaScript是一门世界上最流行的脚本语言

一个合格的后端人员,必须要精通JavaScript

快速入门

一、引入JavaScript

  1. 内部标签

    <!-- script标签(可以放到文件任何位置):里面写JavaScript代码 -->
    <script>
    //......
    </script>
  2. 外部引入

    <!-- 外部引入 -->
    <!-- 注意:script标签必须成对出现 -->
    <script src="js/demo01.js"></script>
    <!-- 不用显示定义type,默认为javascript -->
    <script type="application/javascript"></script>

二、基本语法

// 1.定义变量 [变量类型 变量名 = 变量值]
const score = 70;
// 2.条件控制
if (score === 70) {
alert("良好");
} else {
alert("其它");
}
//在浏览器的控制台输出变量 console.log(score)
// 3.循环
// while循环 ( while(){} / do{}while() )
// for循环 ( for i / forEach()(ES5.1) / for of / for in(ES6) )

浏览器必备调试须知:

image-20220223164807011

三、数据类型

数值、字符、布尔、文本、图形、音频、视频等

  1. 数字 (number)
    js不区分小数和整数

    12 //整数
    12.1 //浮点数
    1.12e2 //科学计数法
    -99 //负数
    NaN //非数值
    Infinity //无穷大
  2. 字符串

    'abc'
    "abc"
  3. 布尔值

    true
    false
  4. 逻辑运算

    &&
    ||
    !
  5. 比较运算符(重要)

    =
    == //等于(类型不一样,值一样,判断为true)
    === //绝对等于(类型一样,值一样,判断为true)

    坚持不要使用==比较

    注意:

    • NaN与所有数值都不相等,包括自己
    • 只能通过isNaN(NaN)来判断,数值是否为NaN

    浮点数问题

    console.log((1/3) === (1 - (2 / 3))); //false

    尽量避免使用浮点数进行运算,存在精度问题

    Math.abs((1/3) - (1 - (2 / 3))) < 0.000000001 //解决方法
  6. null 和 undefined

    • null 空
    • undefined 未定义
  7. 数组
    Java的数组需要相同类型的对象,JS不需要。

    // 保证代码的可读性,尽量使用[]
    let array = [1, 2, 3, null, "hello", true];
    array = new Array(1, 2, 3, null, "hello", true);
    // 越界输出undefined
    console.log(array[2]);
  8. 对象

    let person = {
    name: "ylf",
    age: 18,
    tags: ["java", "python", "c/c++"]
    };
    console.log(person.age);

四、严格检查模式

// 严格检查模式,预防JavaScript的随意性导致的问题(必须写在第一行)
"use strict";
// 默认为全局变量,建议局部变量都是用let定义
let i = 1;

数据类型

一、字符串

  1. 正常字符串使用单引号或双引号包裹

  2. 转义字符

    \' 单引号
    \n 换行
    \t 制表符
    \u4e2d \u#### unicode字符
    \x41 \x## ascii字符
  3. 多行字符串

    // 反单引号
    let msg =
    `Hello,world!
    nico,nico.
    `;
    console.log(msg);
  4. 模板字符串

    let msg = "Hello, ";
    console.log(msg + "world!");
    let name = "ycx!";
    msg = `你好啊, ${name}`;
    console.log(msg);
  5. 字符串长度

    string.length
  6. 字符串的可变性(不可变)
    image-20220223215544704

  7. 大小写转换(注意:不是属性,是方法)

    string.toUpperCase()
    string.toLowerCase()
  8. string.indexOf("string")(通过子字符串获取子字符串第一个字符位置)

  9. string.substring()(截取字符串的一部分,返回一个新字符串)

    [)
    string.substring(1) //从第一个字符截取到最后一个字符
    string.substring(1,3) //[1,3)

二、数组

array可以包含任意的数据类型

let array = [1, 2, 3, null, "hello", true];
  1. 长度

    array.length

    注意:给array.length赋值,数组大小会发生变化:数组变大,增加下标对应元素为空;数组变小,元素丢失

  2. indexOf()(通过元素获取下标索引)

  3. slice()(截取数组的一部分,返回一个新数组)类似字符串中的substring()

  4. push(), pop()(尾部)

    push() //将元素压入到尾部
    pop() //弹出尾部的一个元素
  5. unshift(), shift()(头部)

    unshift() //将元素压入到头部
    shift() //弹出头部的一个元素
  6. sort()(排序)

  7. reverse()(元素反转)

  8. concat()
    image-20220224172344741

    concat()没有修改数组,只是返回一个新数组

  9. join()(连接符)
    image-20220224172553876

    打印拼接数组,使用特定的字符串连接

  10. 多维数组
    image-20220224173056717

三、对象

若干个键值对

let 对象名 = {
属性名: 属性值,
属性名: 属性值,
属性名: 属性值
}

JavaScript中的键都是字符串,值为任意对象!

  1. 对象赋值
    image-20220228193910402
  2. 使用不存在的对象属性不报错!undefined
  3. 动态删减属性
    image-20220228194145657
  4. 动态添加属性
    image-20220228194252665
  5. 判断属性值是否在对象中
    image-20220228194911289
  6. 判断属性是否对象自身拥有的
    image-20220228195130136

四、Map和Set

ES6新特性

Map(键值对)

let map = new Map([["jack", 12], ["tom", 18], ["ylf", 20], ["jet", 30]]);
console.log(map.get("jack")); //获取对应的键值
map.set("nico", 78); //添加键值对
map.delete("nico"); //删除键值对
console.log(map.has("nico")); //判断指定键值对是否存在
// 遍历Map
for (let mapElement of map) {
console.log(mapElement);
}

Set(无序不重复集合)

let set = new Set([3, 1, 1, 2]);
set.add(4); //添加不重复元素到末尾
set.delete(4); //删除指定元素
console.log(set.has(4)); //判断指定元素是否存在
// 遍历Set
for (let number of set) {
console.log(number);
}

函数

一、定义函数

// 定义方式一
function 函数名(形参) {
函数体;
return 返回值;
}
// 定义方式二
// function(){} 为匿名内部类,但是可以把结果赋值给变量名,通过变量名调用函数
let 函数名 = function(形参) {
函数体;
return 返回值;
}
// 如果没有执行return,函数也会返回结果undefined

参数问题

JavaScript函数可以传入任意个参数,也可以不传入参数

传入参数是否合法存在,不合法存在如何规避?

let abs = function(x) {
// 手动抛出异常来判断
if (typeof x !== "number") {
throw "Not a number!";
}
if (x < 0) {
return -x;
} else {
return x;
}
};

arguments(包含所有传入函数的参数,是一个数组)

多参数问题

rest(ES6引入新特性,获取除了已经定义的参数之外的所有问题)

// 初始方法
if (arguments.length > 1) {
for (let i = 1; i < arguments.length; i++) {
console.log(arguments[i]);
}
}
function fun(a, ...rest) {
for (let restElement of rest) {
console.log(restElement);
}
}

rest参数只能写在最后面,必须用...标识

二、变量作用域

三、方法

对象里的叫方法

// 定义方法方式(方法就是把函数放入对象里,对象由属性和方法构成)
let person = {
name: "YLF",
birth: 1999,
// 方法
age: function () {
let fullYear = new Date().getFullYear();
return fullYear - this.birth;
}
}

面向对象语言中 this 表示当前对象的一个引用。

但在 JavaScript 中 this 不是固定不变的,它会随着执行环境的改变而改变。

  • 在方法中,this 表示该方法所属的对象。
  • 如果单独使用,this 表示全局对象。
  • 在函数中,this 表示全局对象。
  • 在函数中,在严格模式下,this 是未定义的(undefined)。
  • 在事件中,this 表示接收事件的元素。
  • 类似 call() 和 apply() 方法可以将 this 引用到任何对象。

内部对象

标准对象

image-20220302164401102

一、Date

let date = new Date();
console.log("date: ");
console.log(date);
console.log("星期: ");
console.log(date.getDay());
console.log("月: ");
console.log(date.getMonth());
console.log("日: ");
console.log(date.getDate());
console.log("年: ");
console.log(date.getFullYear());
console.log("时: ");
console.log(date.getHours());
console.log("分: ");
console.log(date.getMinutes());
console.log("秒: ");
console.log(date.getSeconds());
console.log("时间戳: ");
// 表示从 1970 年 1 月 1 日 00:00:00 UTC 到给定日期之间经过的毫秒数
console.log(date.getTime());

二、JSON

早期所有数据传输习惯使用XML文件

  • JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式
  • 简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言
  • 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率

JSON 与 JS 对象的关系

JSON 是 JS 对象的字符串表示法。它使用文本表示一个 JS 对象的信息,(JSON)本质是一个字符串。

如:

var obj = {a: 'Hello', b: 'World'}; //这是一个js对象,注意js对象的键名也是可以使用引号包裹的,这里的键名就不用引号包含
var json = '{"a": "Hello", "b": "World"}'; //这是一个 JSON 字符串,本质是一个字符串

JSON(格式字符串) 和 JS 对象(也可以叫JSON对象 或 JSON 格式的对象)互转(JSON.parse 和 JSON.stringify)。

要实现从JSON字符串转换为JS对象,使用 JSON.parse() 方法:

var obj = JSON.parse('{"a": "Hello", "b": "World"}'); //结果是 {a: 'Hello', b: 'World'} 一个对象

要实现从JS对象转换为JSON字符串,使用 JSON.stringify() 方法:

var json = JSON.stringify({a: 'Hello', b: 'World'}); //结果是 '{"a": "Hello", "b": "World"}' 一个JSON格式的字符串

说句不严谨的话:JSON.parse() 就是字符串js 对象, JSON.stringify()就是 js 对象字符串,它们前提是要 json 格式才有意义。

三、Ajax

  • 原生的js写法 xhr 异步请求
  • JQuery封装的方法 $("选择器").ajax("")
  • axios请求

面向对象编程

一、什么是面向对象

JavaScript,Java,C#

类(JavaScript中又称原型对象)

对象

二、原型继承

let student = {
name: "student",
age: 0,
run: function () {
console.log(this.name + ", run!");
}
};
let me = {
name: "ylf"
};
me.__proto__ = student;

三、class继承

定义类

// ES6之前
function Student(name) {
this.name = name;
// this.hello = function f() {
// alert("Hello");
// }
}
Student.prototype.hello = function () {
alert("Hello");
}

class关键字是ES6引入的

// ES6之后
class Student {
constructor(name) {
this.name = name;
}
hello() {
alert("Hello");
}
}
// class继承
class Pupil extends Student {
constructor(name, grade) {
super(name);
this.grade = grade;
}
play() {
alert("play");
}
}

本质还是原型继承

image-20220302211234353

四、原型链

操作BOM对象(重点)

一、浏览器

Javascript 和浏览器的关系:Javascript诞生是为了能够在浏览器运行

BOM(Browser Object Model):浏览器对象模型

内核

  • IE 6 - 11
  • Chrome
  • Safari
  • FireFox

三方

  • QQ浏览器
  • 360浏览器

二、window对象(重要)

window代表浏览器窗口

window.innerHeight
182
window.innerWidth
1488
window.alert('hello')

三、navigator对象

封装了浏览器的信息

navigator.appName
'Netscape'
navigator.appVersion
'5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.102 Safari/537.36 Edg/98.0.1108.62'
navigator.platform
'Win32'

尽量避免使用navigator对象,因为它会被人为修改

四、screen对象

获取屏幕分辨率

// 屏幕分辨率
screen.width
1536 px
screen.height
864 px

五、location对象(重要)

代表当前页面的URL信息

host: "developer.mozilla.org"
href: "https://developer.mozilla.org/zh-CN/docs/Web/API/Window/outerHeight"
protocol: "https:"
reload: ƒ reload() // 刷新网页
// 设置新的地址
location.assign('https://www.baidu.com/')

六、document对象(重要)

代表当前页面

获取具体的文档树节点

<ul id="ul">
<li>Java</li>
<li>C++</li>
<li>Python</li>
</ul>
<script>
let ul = document.getElementById("ul");
console.log(ul);
</script>

获取cookie

document.cookie
'BAIDUID_BFESS=A57FC6971D87A9172CD9952274273C6B:FG=1; BIDUPSID=A57FC6971D87A9172CD9952274273C6B; PSTM=1645402825; BD_UPN=12314753; baikeVisitId=37443825-845d-443f-aacd-9504a8d0e3eb; RT="z=1&dm=baidu.com&si=gpeanogruej&ss=l09ccw1h&sl=2&tt=1m3&bcn=https%3A%2F%2Ffclog.baidu.com%2Flog%2Fweirwood%3Ftype%3Dperf&ld=24y&ul=e6v0&hd=e6xc"; ZD_ENTRY=bing; BD_HOME=1; H_PS_PSSID=34429_35106_31253_34584_35871_35908_35946_35972_35984_35315_26350; BA_HECTOR=a42k0l248la1850he71h210ue0q'

截取cookie原理

服务器端可以设置cookie为httpOnly保证安全

七、history对象

代表浏览器历史记录

history.forward()
history.back()

操作DOM对象(重点)

DOM:文档对象模型

浏览器网页就是一个DOM树形结构

  • 更新DOM节点
  • 遍历DOM节点
  • 删除DOM节点
  • 添加DOM节点

操作DOM节点需要先获取它!

一、获取DOM节点

// 对应css选择器
let elementsByTagName = document.getElementsByTagName("h1");
let elementById = document.getElementById("paragraph");
let elementsByClassName = document.getElementsByClassName("paragraph");
let container = document.getElementById("container");
let children = container.children; // 获取父节点的所有子节点
let parentNode = elementById.parentNode; //获取父节点

这是原生代码,之后尽量使用JQuery

二、更新DOM节点

<div id="container">
</div>
<script>
let elementById = document.getElementById("container");
</script>
  • 更新文本

    elementById.innerText = 123 // 修改文本值
    elementById.innerHTML = "<strong>123</strong>" // 可以解析HTML文本标签
  • 操作CSS

    elementById.style.color = "red"; // 属性值使用字符串
    elementById.style.fontSize = "50px" // -转驼峰命名问题

三、删除DOM节点

步骤:先获取父节点,然后通过父节点删除自己

<div id="container">
<h1>标题一</h1>
<p id="paragraph">段落一</p>
<p class="paragraph">段落二</p>
</div>
<script>
let elementById = document.getElementById("paragraph");
let parentNode = elementById.parentNode; //获取父节点
parentNode.removeChild(elementById);
</script>

注意:删除节点时是动态的,children是时空变化的

四、创建和插入DOM节点

节点为空时,使用 innerText 或者 innerHTML 可以添加DOM节点,但不为空时,其会覆盖原来的DOM节点

追加DOM节点

<p id="outerParagraph">外部段落</p>
<div id="container">
<p id="innerParagraph1">内部段落一</p>
<p id="innerParagraph2">内部段落二</p>
<p id="innerParagraph3">内部段落三</p>
</div>
<script>
let outerParagraph = document.getElementById("outerParagraph");
let container = document.getElementById("container");
// DOM父节点追加一个已存在的DOM节点
container.appendChild(outerParagraph);
// 创建新DOM节点,并追加到DOM父节点后面
let htmlParagraphElement = document.createElement("p");
// htmlParagraphElement.setAttribute("id", "newNode");
htmlParagraphElement.id = "newNode";
htmlParagraphElement.innerText = "newNode";
container.appendChild(htmlParagraphElement);
</script>

向前插入DOM节点

<p id="outerParagraph">外部段落</p>
<div id="container">
<p id="innerParagraph1">内部段落一</p>
<p id="innerParagraph2">内部段落二</p>
<p id="innerParagraph3">内部段落三</p>
</div>
<script>
let outerParagraph = document.getElementById("outerParagraph");
let innerParagraph2 = document.getElementById("innerParagraph2");
let container = document.getElementById("container");
container.insertBefore(outerParagraph, innerParagraph2);
</script>

操作表单(验证)

一、什么是表单

目的:提交信息

二、获取和修改表单提交信息

<form action="#" method="post">
<span>用户名:</span> <input type="text" id="username"> <br>
<input type="radio" id="male" name="sex" value="male">
<input type="radio" id="female" name="sex" value="female">
</form>
<script>
let username = document.getElementById("username");
let male = document.getElementById("male");
let female = document.getElementById("female");
//获取文本框提交信息 username.value
//修改文本框提交信息 username.value = '123'
//获取单选框提交信息
if (male.checked = true) {
console.log(male.value);
}
</script>

三、表单提交验证及密码MD5加密

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>表单提交验证及密码MD5加密</title>
<!-- MD5工具类 -->
<script src="https://cdn.bootcss.com/blueimp-md5/2.12.0/js/md5.min.js"></script>
</head>
<body>
<!--
表单绑定事件
1.事件处理程序的返回值
在JavaScript中通常事件处理程序不需要有返回值,这时浏览器会按默认方式进行处理;
但很多情况下需要使用返回值,来判断事件处理程序是否正确进行处理。
2.返回值类型:boolean值
浏览器根据返回值的类型决定下一步如何操作。当返回值为true,进行默认操作; 当返回值为 false,阻止浏览器下一步操作。
3.基本语法:事件句柄=“return 函数名(参数);"
-->
<form action="https://www.baidu.com" method="post" onsubmit="return check()">
<p>
<span>用户名:</span>
<input type="text" name="username" id="username">
</p>
<p>
<span>密码:</span>
<input type="password" name="password" id="password">
</p>
<p>
<!-- 按钮绑定事件 onclick 被点击 -->
<input type="submit" value="提交">
</p>
</form>
<script>
function check() {
let username = document.getElementById("username");
let password = document.getElementById("password");
// MD5加密
password.value = md5(password.value);
return false;
}
</script>
</body>
</html>

JQuery

JQuery库,里面存在大量的JavaScript函数

一、JQuery入门

  1. 下载JQuery

image-20220304215145889

  1. 引入JQuery

    <!-- 方法一:CDN引入 -->
    <script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
    <!-- 方法二:下载JQuery链接引入 -->
    <!-- <script src="../lib/jquery-3.6.0.js"></script> -->
  2. 使用JQuery

    <a href="#" id="test-jquery">超链接</a>
    <script>
    // JQuery使用语法:$(选择器).事件(事件函数)
    $("#test-jquery").click(function () {
    alert("Hello, JQuery!");
    })
    </script>

二、选择器

jQuery API 中文文档 | jQuery API 中文在线手册 | jquery api 下载 | jquery api chm (cuishifeng.cn)

三、事件

鼠标事件、键盘事件、其它事件

获取鼠标当前坐标

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>获取鼠标当前坐标</title>
<script src="../lib/jquery-3.6.0.js"></script>
<style>
body {
height: 500px;
}
span {
width: 100px;
height: 100px;
display: block;
}
</style>
</head>
<body>
鼠标当前坐标:<span id="coordinate"></span>
<script>
// 当页面加载完毕之后,响应事件
$(function () {
$("body").mousemove(function (coordinate) {
$("#coordinate").text("X坐标:" + coordinate.pageX + "\t" + "Y坐标:" + coordinate.pageY);
});
})
</script>
</body>
</html>

四、操作DOM对象

// 操作文本
//text(),html() 无参获取文本值,有参设置文本值 html()可以解析HTML文本标签
console.log($("#test-ul li[name=python]").text());
console.log($(".java").html());
// 操作CSS
$(".java").css({"color": "red", "font-size": 50});
// 元素展示和隐藏
$(".java").hide() //本质disply: none
$(".java").show()
posted @   我是小花啊  阅读(27)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示