【BOM笔记】基本概述、window对象常见事件、定时器、JS执行机制、location/navigator/history对象

news2025/3/13 18:52:07

文章目录

    • 1 BOM概述
      • 1.1 什么是BOM
      • 1.2 BOM的构成
    • 2 window 对象的常见事件
      • 2.1 窗口加载事件
      • 2.2 调整窗口大小事件
    • 3 定时器
      • 3.1 `setTimeout()` 定时器
      • 3.2 `setInterval()` 定时器
      • 3.3 this
    • 4 JS 执行机制
      • 4.1 JS 是单线程
      • 4.2 同步和异步
      • 4.3 JS 执行机制
    • 5 `location` 对象
      • 5.1 属性
      • 5.2 方法
    • 6 `navigator` 对象
    • 7 `history` 对象

1 BOM概述

1.1 什么是BOM

  • BOM(Browser Object Model)即浏览器对象模型,它提供了独立于内容而与浏览器窗口进行交互的对象,其核心对象是 window。
  • BOM 由 一系列相关的对象构成 ,并且每个对象都提供了很多方法与属性。
  • BOM 缺乏标准,JavaScript 语法的标准化组织是 ECMA,DOM 的标准化组织是 W3C,BOM 最初是Netscape 浏览器标准的一部分,兼容性较差。
    在这里插入图片描述

1.2 BOM的构成

BOM 比 DOM 更大,它包含 DOM。

image-20231221113456899

window 对象是浏览器的顶级对象,它具有双重角色。

  1. 它是 JS 访问浏览器窗口的一个接口
  2. 它是一个全局对象。定义在全局作用域中的变量、函数都会变成 window 对象的属性和方法。但是在调用的时候可以省略 window,前面学习的对话框都属于 window 对象方法,如 alert()、prompt() 等。

注意:window下的一个特殊属性window.name本身是有含义的,因此声明变量时最好不用name。

2 window 对象的常见事件

2.1 窗口加载事件

窗口 (页面)加载事件:当**文档内容完全加载完成**后会触发该事件(包括图像、脚本文件、CSS…),调用后面的处理函数,方法有以下两种:

// 传统方法
window.onload = function(){}  // 只能写一次
// 新方法
window.addEventListener("load",function(){});  // 没有次数限制

只要DOM加载完毕(不包含图片、falsh、CSS…)就可以触发该事件,调用后面的处理函数,加载速度比load更快一些(Ie9以上才支持,图片较多时用)

// 只加载完DOM就开始调用处理函数
window.addEventListener('DOMContentLoaded',function(){});   // 图片较多时用

例子:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script>   // 有了窗口 (页面)加载事件,就可以把script标签放在head中或其他地方了
        // 一、传统方法 `window.onload = function(){}`
        window.onload = function() {
            var btn = document.querySelector('button');
            btn.addEventListener('click', function() {
                alert('点击我');
            })
        }
        
        window.onload = function() {   // 出现多个`window.onload`后,上面的'点击我事件'会被覆盖,只出现'22'
            alert(22);
        }
        
        // 二、新方法 `window.addEventListener("load",function(){});`
        window.addEventListener('load', function() {
            var btn = document.querySelector('button');
            btn.addEventListener('click', function() {
                alert('点击我');
            })
        })
        
        window.addEventListener('load', function() {
            alert(22);    // '点击我'和'22'两个事件都有效,不会覆盖
        })
        
        // 三、DOM加载完毕就可以执行,图片较多时用 						`window.addEventListener('DOMContentLoaded',function(){});`
        document.addEventListener('DOMContentLoaded', function() {
            alert(33);    // 最先弹出,加载时间最快
        })
    </script>
</head>

<body>
    <button>点击</button>
</body>

</html>

注意:

  1. 有了窗口 (页面)加载事件就可以把 JS 代码写到页面元素的上方(head中),该事件是等页面内容全部加载完毕,再去执行处理函数。
  2. window.onload = function(){} 传统注册事件方式只能写一次,如果有多个,会以最后一个为准。
  3. window.addEventListener("load",function(){});没有使用次数限制
  4. 如果页面的图片很多的话,从用户访问到onload触发可能需要较长的时间,交互效果就不能实现,必然影响用户的体验,此时用window.addEventListener('DOMContentLoaded',function(){});事件比较合适

2.2 调整窗口大小事件

我们经常利用这个窗口大小事件完成 响应式布局。 使用window.innerWidth得到当前窗口的宽度,当窗口小于某个值,就让页面中某个(列)元素进行隐藏。

window.onresize = function(){}    // 只要窗口大小发生像素变化,就会触发这个事件
window.addEventListener("resize",function(){});
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        div {
            width: 200px;
            height: 200px;
            background-color: pink;
        }
    </style>
</head>

<body>
    <script>
        window.addEventListener('load', function() {   // script写在了div上面,因此要load
            var div = document.querySelector('div');
            window.addEventListener('resize', function() {  // 窗口发生变化就触发以下内容
                console.log(window.innerWidth);  // 窗口宽度实时变化
                if (window.innerWidth <= 800) {
                    div.style.display = 'none';  // 窗口宽度<800px,div隐藏
                } else {
                    div.style.display = 'block';
                }
            })
        })
    </script>
    <div></div>
</body>

</html>

3 定时器

window 对象下有2个非常好用定时器

  • window.setTimeout(function() {...}, 2000); 在2s后执行function
  • setInterval(function() {...}, 2000); 每隔2s就执行一次function

3.1 setTimeout() 定时器

window.setTimeout(function() {}, [延迟的毫秒数]);    // 在定时器到期后执行调用函数,[...]内的参数可以省略,默认为0立马执行
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <script>
        // 函数写法一:直接写函数(window可以省略)
        setTimeout(function() {    
            console.log('时间到了');  // 2s后出现该语句
        }, 2000);
        
        function callback() {    
            console.log('爆炸了');
        }
        // 函数写法二
        setTimeout(callback, 3000); 
        // 函数写法三:不提倡(比二啰嗦)
        setTimeout('callback()', 3000);  
        
        var timer1 = setTimeout(callback, 3000);  // 页面中可能有很多的定时器,需要给定时器加标识符(名字)
        var timer2 = setTimeout(callback, 5000);
    </script>
</body>

</html>

回调函数:

  • 普通函数是按照代码顺序直接调用。 而setTimeout() 需要等待时间,时间到了才去调用这个函数,因此称为回调函数callback
  • 以前我们讲的 element.onclick = function(){}或者 element.addEventListener(“click”, fn); 里面的函数也是回调函数。

案例:5秒后广告自动关闭

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <img src="images/ad.jpg" alt="" class="ad">
    <script>
        var ad = document.querySelector('.ad');
        setTimeout(function() {
            ad.style.display = 'none';   // 5s后图片隐藏
        }, 5000);
    </script>
</body>

</html>

停止setTimeout() 定时器:

window.clearTimeout(timeoutID)  // 取消先前通过调用`setTimeout()`建立的定时器,`timeoutID`参数为定时器名字

案例:点击按钮,关闭定时炸弹

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <button>点击停止定时器</button>
    <script>
        var btn = document.querySelector('button');
        var timer = setTimeout(function() {
            console.log('爆炸了');
        }, 5000);
        
        btn.addEventListener('click', function() {
            clearTimeout(timer);  // 点击按钮,停止`timer`(window 可以省略)
        })
    </script>
</body>

</html>

3.2 setInterval() 定时器

window.setInterval(function() {}, [间隔的毫秒数]);  // 每间隔一段时间,就反复调用一次函数

案例:秒杀倒计时,数字不断自动变化

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        div {
            margin: 200px;
        }
        
        span {
            display: inline-block;
            width: 40px;
            height: 40px;
            background-color: #333;
            font-size: 20px;
            color: #fff;
            text-align: center;
            line-height: 40px;
        }
    </style>
</head>

<body>
    <div>
        <span class="hour">1</span>
        <span class="minute">2</span>
        <span class="second">3</span>
    </div>
    <script>
        // 1. 获取元素 
        var hour = document.querySelector('.hour'); // 小时的黑色盒子
        var minute = document.querySelector('.minute'); // 分钟的黑色盒子
        var second = document.querySelector('.second'); // 秒数的黑色盒子
        var inputTime = +new Date('2024-1-1 12:00:00'); // 秒杀活动截至时间
        countDown(); // 我们先提前调用一次这个函数(不等那1s),防止第一次刷新页面有空白
        
        // 2. 开启定时器
        setInterval(countDown, 1000);   // 每隔1s调用一次cutDown,刷新页面后要等1S才调用,这样用户体验不好,因此要在上面提前调用一次`countDown();`

        function countDown() {   // 时间差
            var nowTime = +new Date();  // 返回的是当前时间总的毫秒数
            var times = (inputTime - nowTime) / 1000;  // times是剩余时间总的秒数,inputTime是全局变量可以调用
            var h = parseInt(times / 60 / 60 % 24); // 时
            h = h < 10 ? '0' + h : h;
            hour.innerHTML = h;  // 把剩余的小时给`小时黑色盒子`
            var m = parseInt(times / 60 % 60);  // 分
            m = m < 10 ? '0' + m : m;
            minute.innerHTML = m;
            var s = parseInt(times % 60);  // 剩余的秒
            s = s < 10 ? '0' + s : s;
            second.innerHTML = s;
        }
    </script>
</body>

</html>

效果(时、分、秒 实时变化):image-20231221162329203

停止setInterval() 定时器:

window.clearInterval(intervalID); // 取消先前通过调用`setInterval()`建立的定时器,`timeoutID`参数为定时器名字

案例1:点击按钮,开启 / 停止定时器

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <button class="begin">开启定时器</button>
    <button class="stop">停止定时器</button>
    <script>
        var begin = document.querySelector('.begin');
        var stop = document.querySelector('.stop');
        var timer = null; // 全局变量,null是一个空对象,要赋值否则undefined
        begin.addEventListener('click', function() {
            timer = setInterval(function() {  // 局部变量,下面函数调用不了,因此在前面声明一下变成全局变量,值都指向堆中,改同一个对象值
                console.log('我每秒都要叫一次');
            }, 1000);
        })
        stop.addEventListener('click', function() {
            clearInterval(timer);  // 吵死,把timer停掉!
        })
    </script>
</body>

</html>

案例2:发送完短信60s内不能再次点击

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    手机号码: <input type="number"> <button>发送</button>
    <script>
        var btn = document.querySelector('button');
        var time = 60; // 定义剩下的秒数
        btn.addEventListener('click', function() {
            btn.disabled = true;  // 按钮点击之后要对按钮禁用,disabled为true 
            var timer = setInterval(function() {
                if (time == 0) {    // 倒计时结束
                    clearInterval(timer);  // 清除定时器
                    btn.disabled = false;  // 复原按钮点击功能
                    btn.innerHTML = '发送';  // 复原按钮内容
                    time = 60;    // 复原时间
                } else {
                    btn.innerHTML = '还剩下' + time + '秒';  //button里面的内容通过innerHTML修改
                    time--;
                }
            }, 1000);
        })
    </script>
</body>

</html>

3.3 this

this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,一般情况下this的最终指向的是那个调用它的对象 ,注意:

  1. 全局作用域普通函数定时器中this指向全局对象window
  2. 方法调用中this指向谁调用该方法
  3. 构造函数中this指向构造函数的实例
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <button>点击</button>
    <script>
        // 1. `全局作用域`,`普通函数`,`定时器`中this指向`全局对象window`
        console.log(this);   // Window{...},`全局作用域`
        
        function fn() {
            console.log(this); 
        }
        window.fn();   // Window{...},`普通函数`
        
        window.setTimeout(function() {
            console.log(this);   // Window{...},`定时器`
        }, 1000);
        
        // 2. 方法调用中this指向`谁调用该方法`
        var o = {
            sayHi: function() {
                console.log(this);
            }
        }
        o.sayHi();   // {sayHi:f},`o这个对象`
        
        var btn = document.querySelector('button');
        btn.onclick = function() {
        	console.log(this);  // <button>点击</button>,`btn这个按钮对象`
        }
        btn.addEventListener('click', function() {
            console.log(this);  // <button>点击</button>,`btn这个按钮对象`
        })
        
        // 3. 构造函数中this指向`构造函数的实例`
        function Fun() {
            console.log(this); // `fun实例对象`
        }
        var fun = new Fun();
    </script>
</body>

</html>

4 JS 执行机制

4.1 JS 是单线程

单线程:JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事。前一个任务结束,才会执行后一个任务。

问题: 如果中间有一块代码JS执行的时间过长,这样会影响后面代码的执行,造成页面的渲染不连贯。

解决办法:利用多核 CPU 的计算能力,HTML5 提出 Web Worker 标准,允许 JavaScript 脚本创建多个线程。于是,JS 中出现了同步异步的概念。

4.2 同步和异步

  1. 同步

前一个任务结束后再执行后一个任务,程序的执行顺序任务的排列顺序是一致的、同步的。(同步任务:都在主线程上执行,形成一个执行栈

  1. 异步

程序的执行顺序任务的排列顺序通常不一致。(异步任务 :JS 的异步是通过回调函数实现的。相关回调函数添加到任务队列/消息队列中)

一般异步任务有以下三种类型:

  • 普通事件,如 click、resize 等
  • 资源加载,如 load、error 等
  • 定时器,包括 setInterval、setTimeout 等

image-20231221172746436

4.3 JS 执行机制

  1. 先执行执行栈中的同步任务
  2. 异步任务(回调函数)放入任务队列中。
  3. 一旦执行栈中的所有同步任务执行完毕,系统就会按次序读取任务队列中的异步任务,于是被读取的异步任务结束等待状态,进入执行栈,开始执行

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

打印顺序:123

image-20231221164626964

由于主线程不断的重复获得任务、执行任务、再获取任务、再执行,所以这种机制被称为**事件循环(event loop)**。

5 location 对象

location对象:window 对象下的 location 属性用于获取或设置窗体的URL,并且可以用于解析URL。 因为这个属性返回的是一个对象,所以我们将这个属性也称为 location 对象。

**URL:**统一资源定位符 (Uniform Resource Locator, URL) 是互联网上标准资源的地址。互联网上的每个文件都有 一个唯一的 URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它。

// URL的一般语法格式:
protocol://host[:port]/path/[?query]#fragment
// 例如:
http://www.itcast.cn/index.html?name=andy&age=18#link

image-20231221164754850

5.1 属性

image-20231221184743827

案例1:5秒钟之后自动跳转页面

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <button>点击</button>
    <div></div>
    <script>
        var btn = document.querySelector('button');
        var div = document.querySelector('div');
        btn.addEventListener('click', function() {
            // console.log(location.href);
            location.href = 'http://www.itcast.cn';  // 点击按钮后跳转到新页面
        })
        var timer = 5;   // 5秒后自动跳转到新页面
        setInterval(function() {
            if (timer == 0) {
                location.href = 'http://www.itcast.cn';
            } else {
                div.innerHTML = '您将在' + timer + '秒钟之后跳转到首页';
                timer--;
            }
        }, 1000);
    </script>
</body>

</html>

案例2:URL参数数据在不同页面传递

第一个页面:登陆页面 login.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <form action="index.html">  <!-- 用action,把表单提交到index.html -->
        用户名: <input type="text" name="uname">
        <input type="submit" value="登录">
    </form>
</body>

</html>

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在login.html页面中输入用户名前:image-20231221190440085

输入andy后,跳往index.html,保存了uname:外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

第二个页面:欢迎页面 index.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div></div>
    <script>
        console.log(location.search); // ?uname=andy
        var params = location.search.substr(1); // 先去掉'?',substr('起始的位置',截取几个字符);substr(1)为从索引号1开始,取到剩下所有字符
        console.log(params);  // uname=andy
        var arr = params.split('='); // 利用=把字符串分割为数组 split('=');
        console.log(arr); // ["uname", "andy"]
        var div = document.querySelector('div');
        div.innerHTML = arr[1] + '欢迎您';  // 把数据写入div中
    </script>
</body>

</html>

跳转后效果:image-20231221190806098

5.2 方法

image-20231221185335249

6 navigator 对象

navigator 对象: 包含有关浏览器的信息(用户用的PC端还是移动端?什么浏览器?浏览器版本号?电脑的系统版本号?),它有很多属性,我们最常用的是userAgent,该属性可以返回由客户机发送服务器的user-agent头部的值。

下面前端代码可以判断用户那个终端打开页面,实现跳转

if((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
    window.location.href = "";   // 手机
} else { 
	window.location.href = "";   // 电脑
}

7 history 对象

history 对象:浏览器历史记录进行交互,对象包含用户(在浏览器窗口中)访问过的 URL。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

history 对象一般在实际开发中比较少用,但是会在一些 OA 办公系统中见到

image-20231221185551354

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【深度学习笔记】9_9 语义分割和数据集

注&#xff1a;本文为《动手学深度学习》开源内容&#xff0c;部分标注了个人理解&#xff0c;仅为个人学习记录&#xff0c;无抄袭搬运意图 9.9 语义分割和数据集 在前几节讨论的目标检测问题中&#xff0c;我们一直使用方形边界框来标注和预测图像中的目标。本节将探讨语义分…

【欢迎投稿|稳定检索|高录用】2024年建筑土木与水利工程国际学术会议(ICBCHE 2024)

【欢迎投稿|稳定检索|高录用】2024年建筑土木与水利工程国际学术会议&#xff08;ICBCHE 2024) 苏老师 电话&#xff1a;19113133262&#xff08;微信同号&#xff09; QQ&#xff1a;2950880851 【投稿时请附言&#xff1a;icbche投稿苏老师推荐 将享有优先审稿及录用和学…

weblogic CVE-2023-21839详细复现

1、本次复现使用vulhub的靶场 切换到靶场的目录下&#xff0c;用docker -compose up -d启动靶场 使用docker-compose ps -a查看靶场的端口 2、访问开启的环境 3、准备工作都做好之后开始复现 &#xff08;1&#xff09;开启JNDIExploit 工具地址&#xff1a;GitHub - WhiteH…

HNU-计算机系统-实验1-原型机vspm1.0-(二周目玩家视角)

前言 二周目玩家&#xff0c;浅试一下这次的原型机实验。总体感觉跟上一年的很相似&#xff0c;但还是有所不同。 可以比较明显地感觉到&#xff0c;这个界面越来越好看了&#xff0c;可操作与可探索的功能也越来越多了。 我们HNU的SYSTEM真的越来越好了&#xff01;&#x…

使用C#创建服务端Web API

前言 C# Web API 是一种基于 .NET 平台&#xff08;包括但不限于.NET Framework 和 .NET Core&#xff09;构建 HTTP 服务的框架&#xff0c;用于创建 RESTful Web 服务。REST&#xff08;Representational State Transfer&#xff09;是一种软件架构风格&#xff0c;它利用HT…

Vue.js+SpringBoot开发APK检测管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 开放平台模块2.3 软件档案模块2.4 软件检测模块2.5 软件举报模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 开放平台表3.2.2 软件档案表3.2.3 软件检测表3.2.4 软件举报表 四、系统展示五、核心代…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Flex)

以弹性方式布局子组件的容器组件。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。Flex组件在渲染时存在二次布局过程&#xff0c;因此在对性能有严格要求的场景下建议使用Column、Row代替。Flex组…

【Spring】SpringMVC请求原理

什么是SpringMVC&#xff1a; SpringMVC 是Springframework中基于Java实现的Model-View-Controller框架&#xff0c;用于管理web应用程序的请求处理流程&#xff0c;并遵循MVC设计原则。 什么是MVC&#xff1a; MVC是Model-View-Controller的缩写&#xff0c;是一种设计原则&am…

PS学习 - 抠图-通道-主题颜色和背景颜色不能相近

抠出蝴蝶 1.通道抠图 套索工具 这里需要圈住你要的&#xff0c;注意尽量小点 ctrl j 复制 然后去掉背景 点击通道 找到明暗对比最大的通道&#xff0c;这里我理解为颜色反差最大的那个&#xff0c;突出你要抠的东西 搜了下说是一般为蓝色 复制通道 ctrll调出色阶 通过移…

MySQL--执行一条 select 语句,期间发生了什么?

执行一条 SQL 查询语句&#xff0c;期间发生了什么&#xff1f; 连接器&#xff1a;建立连接&#xff0c;管理连接、校验用户身份&#xff1b;查询缓存&#xff1a;查询语句如果命中查询缓存则直接返回&#xff0c;否则继续往下执行。MySQL 8.0 已删除该模块&#xff1b;解析 …

java-类和对象

1.面向对象 1.1 区分面向对象与面向过程 举个例子: 在传统的洗衣服过程中,需要经历防水,放衣服,放洗衣粉,搓洗,换水......多个步骤,每个过程都是不可或缺的,关注的是过程. 而现在的洗衣服过程,就需要我们把衣服,洗衣粉放入洗衣机,启动洗衣机即可,并不需要关注洗衣机是如何运行…

长期护理保险可改善老年人心理健康 | CHARLS CLHLS CFPS 公共数据库周报(3.6)...

欢迎报名2024年“真实世界临床研究”课程&#xff01; 本周郑老师开讲&#xff1a;“真实世界临床研究”培训班&#xff0c;3月16-17日两天&#xff0c;欢迎报名&#xff01; CHARLS公共数据库‍ CHARLS数据库简介中国健康与养老追踪调查(China Health and Retirement Longitud…

Upload-labs 靶场通关攻略(全网最全最完整)

一、环境 在github上找upload-labs-0.1环境&#xff0c;部署在小皮面板上 upload靶机包 也可以直接下载他的集成的环境 二、闯关 1、Pass-01&#xff08;前端验证&#xff09; 文件上传漏洞就是利用我们上传的后门文件可以服务器进行解析 首先我们要写一个一句话木马文件…

AI大模型额外学习一:斯坦福AI西部世界小镇笔记

文章目录 一、简单介绍1&#xff09;项目代码介绍2&#xff09;重新播放模拟3&#xff09;适当修改分叉模拟 二、部署斯坦福小镇Demo1&#xff09;准备工作2&#xff09;解决遇到的bug3&#xff09;启动服务器和前端 github链接 一、简单介绍 ①背景介绍 This repository acc…

声明式事务还是编程式事务,如何选择?

(/≧▽≦)/~┴┴ 嗨~我叫小奥 ✨✨✨ &#x1f440;&#x1f440;&#x1f440; 个人博客&#xff1a;小奥的博客 &#x1f44d;&#x1f44d;&#x1f44d;&#xff1a;个人CSDN ⭐️⭐️⭐️&#xff1a;Github传送门 &#x1f379; 本人24应届生一枚&#xff0c;技术和水平有…

[善用佳软]推荐掌握小工具:Json解析的命令行工具jq

前言&#xff1a; 我们在各种生产环境或者开发测试环境中&#xff0c;一定遇到有很多信息都是使用JSON串或者文本文件作为输入的。在没有JQ命令行工具之前&#xff0c;我们要从中获取真正的输入&#xff0c;大都把它复制到文本里头&#xff0c;然后使用文本编辑器进行加工整理…

WSL2执行nvidia-smi报错:Command ‘nvidia-smi‘ not found, but can be installed with

报错信息&#xff1a; Command nvidia-smi not found, but can be installed with: sudo apt install nvidia-utils-390 # version 390.157-0ubuntu0.22.04.2, or sudo apt install nvidia-utils-418-server # version 418.226.00-0ubuntu5~0.22.04.1 sudo apt insta…

LeetCode 热题 100 | 回溯(二)

目录 1 39. 组合总和 2 22. 括号生成 3 79. 单词搜索 菜鸟做题&#xff0c;语言是 C&#xff0c;感冒快好版 关于对回溯算法的理解请参照我的上一篇博客&#xff1b; 在之后的博客中&#xff0c;我将只分析回溯算法中的 for 循环。 1 39. 组合总和 题眼&#xff1a;c…

程序员的知识宝库,100+开源书籍、文档

公众号&#xff1a;【可乐前端】&#xff0c;每天3分钟学习一个优秀的开源项目&#xff0c;分享web面试与实战知识&#xff0c;也有全栈交流学习摸鱼群&#xff0c;期待您的关注! 每天3分钟开源 hi&#xff0c;这里是每天3分钟开源&#xff0c;很高兴又跟大家见面了&#xff0…

代码随想录刷题笔记 Day 52 | 打家劫舍 No.198 | 打家劫舍 II No.213 | 打家劫舍III No.337

文章目录 Day 5201. 打家劫舍&#xff08;No. 198&#xff09;<1> 题目<2> 笔记<3> 代码 02. 打家劫舍 II&#xff08;No. 213&#xff09;<1> 题目<2> 笔记<3> 代码 03.打家劫舍III&#xff08;No. 337&#xff09;<1> 题目<2&g…