JS-12 window定时器方法、setTimeout、setInterval、DOM实战案例(轮播消息提示+关闭隐藏消息+侧边栏展示+tabControl切换标签栏+轮播图);表格信息展示

本文主要是介绍JS-12 window定时器方法、setTimeout、setInterval、DOM实战案例(轮播消息提示+关闭隐藏消息+侧边栏展示+tabControl切换标签栏+轮播图);表格信息展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1_window定时器方法
    • 1.1_setTimeout
    • 1.2_setInterval
  • 2_案例 – 轮播消息提示
  • 3_案例 – 关闭隐藏消息
  • 4_案例 – 侧边栏展示
  • 5_案例 - tabControl切换标签栏
  • 6_案例 - 轮播图
    • 6.1_基本实现
    • 6.2_添加定时器,自动轮播
    • 6.3_代码重构
    • 6.4_优化轮播效果
  • 7_表格信息展示

1_window定时器方法

计划调用(scheduling a call):某些情况不想立即执行一个函数,而是等待特定一段时间之后再执行

两种方式实现:

  • setTimeout 允许将函数推迟到一段时间间隔之后再执行。

  • setInterval 允许重复运行一个函数,从一段时间间隔之后开始运行,之后以该时间间隔连续重复运行该函数。

有对应的取消方法:

  • clearTimeout:取消setTimeout的定时器;

  • clearInterval:取消setInterval的定时器;

大多数运行环境都有内置的调度程序,并提供这些方法:

  • 目前,所有浏览器以及 Node.js 都支持这两个方法;

  • 后续学习Node的时候,可以使用它们;


1.1_setTimeout

语法:let timerId = setTimeout( func | code , [ delay ] , [ arg1 ],[ arg2 ],...)

  • 只执行一次

  • func|code:想要执行的函数或代码字符串。 一般传入的都是函数,由于某些历史原因,支持传入代码字符串,但是不建议这样做;

  • delay:执行前的延时,以毫秒为单位(1000 毫秒 = 1 秒),默认值是 0;

  • arg1,arg2…:要传入被执行函数(或代码字符串)的参数列表;

clearTimeout:在调用时会返回一个“定时器标识符(timer identifier)”,使用它来取消执行


1.2_setInterval

语法:let timerId = setInterval( func | code , [ delay ] , [ arg1 ],[ arg2 ],...)

  • 每间隔给定的时间周期性执行

  • func|code:想要执行的函数或代码字符串。 一般传入的都是函数,由于某些历史原因,支持传入代码字符串,但是不建议这样做;

  • delay:执行前的延时,以毫秒为单位(1000 毫秒 = 1 秒),默认值是 0;

  • arg1,arg2…:要传入被执行函数(或代码字符串)的参数列表;

clearInterval:返回一个“定时器标识符(timer identifier)”,通过clearInterval来取消这个定时器

<body><button class="out">取消setTimeout定时器</button><button class="itv">取消setInterval定时器</button><script>// 1.setTimeoutfunction foo(name, age, height) {console.log("foo被调用----", name, age, height)}var timeoutID = setTimeout(foo, 3000, "hihi", 18, 1.88)var timeoutBtn = document.querySelector(".out")timeoutBtn.onclick = function() {// 取消调度clearTimeout(timeoutID)}// 2.setIntervalfunction bar() {console.log("bar被调用++++")}var itvID = setInterval(bar, 3000)var itvBtn = document.querySelector(".itv")itvBtn.onclick = function() {clearInterval(itvID)}</script></body>


2_案例 – 轮播消息提示

在这里插入图片描述

<style>.tip-bar {display: inline-flex;align-items: center;height: 30px;background-color: rgba(0,0,0,.4);border-radius: 16px;}img {width: 30px;height: 30px;border-radius: 50%;margin-right: 5px;}span {font-size: 13px;color: white;margin-right: 8px;}</style><body><div class="tip-bar"><img src="https://bfs.biyao.com/group1/M01/A2/67/rBACVGA_iOuAYaTxAAAPbted3yE165.png" alt=""><span>183***138对这件商品感兴趣</span></div><script>// 1.从服务器拿到数据ajax/fetch请求let tipList = [{icon: 'https://bfs.biyao.com/group1/M01/A6/97/rBACYWBCHqyAFH5tAAANZXX5Eww646.png',title: 'haha对这件商品感兴趣'},{icon: 'https://bfs.biyao.com/group1/M01/A2/67/rBACVGA_iOuAYaTxAAAPbted3yE165.png',title: '123***814对这件商品感兴趣'},{icon: 'https://bfs.biyao.com/group1/M00/7F/4E/rBACYV16HseAP-PnAAAW9bbVoKE463.png',title: '刘军对这件商品感兴趣'}]// 2.动态的切换数据// 2.1.获取元素var tipBar = document.querySelector(".tip-bar")var imgEl = tipBar.querySelector("img")var spanEl = tipBar.querySelector("span")// 2.2.3s切换一次数据var currentIndex = 0 // 记录当前展示到的索引位置setInterval(function() {// 1> 根据索引获取itemvar tipItem = tipList[currentIndex]// 2> 给DOM设置内容imgEl.src = tipItem.iconspanEl.textContent = tipItem.title// 3> 重新计算索引currentIndex++if (currentIndex === tipList.length) {currentIndex = 0}}, 3000)// 随机// Math.floor(Math.random() * tipList.length)</script></body>



3_案例 – 关闭隐藏消息

在这里插入图片描述

<style>.top-bar {display: flex;flex-direction: row;align-items: center;height: 45px;width: 375px;background-color: black;/* 关键 动画*/overflow: hidden;transition: all .5s ease-out;}.delete {display: flex;flex-direction: row;justify-content: center;align-items: center;height: 100%;width: 30px;cursor: pointer;}.delete img {height: 10px;width: 10px;}.logo {height: 30px;width: 30px;margin-left:3px;margin-right: 30px;cursor: pointer;}span {color: white;font-size: 14px;flex: 1;white-space: nowrap;overflow: hidden;text-overflow: ellipsis;}.btn {width: 94px;height: 100%;line-height: 45px;text-align: center;font-size: 14px;color: #fff;background-color: #F63515;}</style><body><div class="top-bar"><div class="delete"><img src="./img/delete.png" alt=""></div><img class="logo" src="./img/logo.png" alt=""><span>打开京东App,购物更轻松</span><div class="btn">立即打开</div></div><script>// 1.获取元素var topBar = document.querySelector(".top-bar")var deleteEl = topBar.querySelector(".delete")// 2.监听delete的点击deleteEl.onclick = function() {//只是把高度归零,但是代码存在topBar.style.height = 0//下面这种方法不推荐,人为依赖于css样式动画的时间// setTimeout(function() {//   topBar.remove()// }, 300)}// 3.监听过渡动画结束   【推荐使用】 不用人为依赖时间topBar.ontransitionend = function() {//直接把代码移除topBar.remove()}</script></body>



4_案例 – 侧边栏展示

在这里插入图片描述

  <style>.tool-bar {position: fixed;top: 30%;right: 0;display: flex;flex-direction: column;align-items: center;width: 35px;}.item {position: relative;width: 35px;height: 35px;margin-bottom: 1px;background-color: #7a6e6e;border-radius: 3px 0 0 3px;}.icon {display: inline-block;width: 100%;height: 100%;cursor: pointer;background-image: url(./img/toolbars.png);}/*原始方法,在CSS设置.icon01 {background-position: -48px 0;}.icon02 {background-position: -48px -50px;}.icon03 {background-position: -48px -100px;}.icon04 {background-position: -48px -150px;} */.name {position: absolute;z-index: -1;right: 35px;/* left: -62px; */top: 0;width: 0;height: 35px;line-height: 35px;color: #fff;text-align: center;font-size: 12px;background-color: #7a6e6e;cursor: pointer;border-radius: 3px 0 0 3px;transition: width .2s ease;}.item:hover,.item:hover .name {background-color: #cd1926;}</style><body><div class="tool-bar"><div class="item"><i class="icon icon01"></i><div class="name">购物车</div></div><div class="item"><i class="icon icon02"></i><div class="name">收藏</div></div><div class="item"><i class="icon icon03"></i><div class="name">限时活动</div></div><div class="item"><i class="icon icon04"></i><div class="name">大礼包</div></div></div><script>//改进方法// 1.for循环 动态给icon设置backgroundPositionvar iconEls = document.querySelectorAll(".icon")for (var i = 0; i < iconEls.length; i++) {var iconEl = iconEls[i]iconEl.style.backgroundPosition = `-48px -${50*i}px`}// 2.实现鼠标进入动画// 方案一: mouseenter(不能使用事件委托) 【推荐】var itemEls = document.querySelectorAll(".item")for (var itemEl of itemEls) {itemEl.onmouseenter = function() {var nameEl = this.children[1]nameEl.style.width = "62px"}itemEl.onmouseleave = function() {var nameEl = this.children[1]nameEl.style.width = "0"}}// 方案二: mouseover(使用事件委托)// var toolbarEl = document.querySelector(".tool-bar")// toolbarEl.onmouseover = function(event) {//   handleMouseEvent(event, 62)// }// toolbarEl.onmouseout = function(event) {//   handleMouseEvent(event, 0)// }// function handleMouseEvent(event, width) {//   if (event.target !== toolbarEl) {//     // var itemEl = event.target.classList.contains("item") ? event.target: event.target.parentElement//     // 1.获取唯一的item//     var itemEl = null//     if (event.target.classList.contains("item")) {//       itemEl = event.target//     } else {//       itemEl = event.target.parentElement//     }//     // 2.根据item获取nameElement//     var nameEl = itemEl.children[1]//     // 3.设置宽度//     nameEl.style.width = `${width}px`//   }// }</script></body>



5_案例 - tabControl切换标签栏

在这里插入图片描述

  <link rel="stylesheet" href="./css/reset.css"><link rel="stylesheet" href="./css/common.css"><style>.main .section-content {display: flex;justify-content: space-between;}.main .section-content .left-content {width: 872px;height: 1000px;}.main .section-content .right-content {width: 295px;height: 500px;}</style><body><div class="main main_wrapper"><div class="section-content"><div class="left-content"><div class="content-center"><div class="section_header"><div class="header_left"><h3 class="title">内容中心</h3></div><div class="header_right" href="#"><a class="more" href="#">更多</a></div></div><div class="tab_control"><div class="item active">精品栏目</div><div class="line"></div><div class="item">赛事精品</div><div class="line"></div><div class="item">英雄攻略</div></div></div></div></div><script>// 1.获取元素var tabControl = document.querySelector(".tab_control")// 2.监听鼠标进入(事件委托)var activeLiEl = tabControl.querySelector(".active")tabControl.onmouseover = function(event) {// 1.拿到事件发生的对象var itemEl = event.targetif (itemEl.classList.contains("item")) {           // 方案一 for循环所有的item// 方案二 querySelector(".active")// 方案三 变量记录当前的active对应的item【推荐】// 取消其他的activeactiveLiEl.classList.remove("active")// 当前进入的item变成activeitemEl.classList.add("active")// 将最新的itemEl变成activeLiElactiveLiEl = itemEl}}</script>
</body>



6_案例 - 轮播图

在这里插入图片描述

6.1_基本实现

<link rel="stylesheet" href="./css/reset.css"><link rel="stylesheet" href="./css/common.css"><style>.main {height: 100px;}.news-section {display: flex;height: 342px;}.news-section .banner {width: 605px;background-color: #000;overflow: hidden;}.news-section .banner .image-list {display: flex;width: 604px;/* overflow: hidden; */}.news-section .banner .image-list .item {flex-shrink: 0;width: 100%;}.news-section .banner .image-list .item a {display: block;}.news-section .banner .image-list .item a img {width: 100%;}.news-section .banner .title-list {display: flex;height: 44px;line-height: 44px;}.news-section .banner .title-list .item {flex: 1;text-align: center;}.news-section .banner .title-list .item a {display: block;font-size: 14px;color: #b1b2be;}.news-section .banner .title-list .item.active a,.news-section .banner .title-list .item a:hover {color: #f3c258;background-color: rgba(255,255,255,.15);}.news-section .news {flex: 1;background-color: purple;}.news-section .download {width: 236px;background-color: skyblue;}.news-section .download a {display: block;background: url(./img/main_sprite.png) no-repeat;}.news-section .download a.download-btn {height: 128px;background-position: 0 -219px;}.news-section .download a.guard-btn {height: 106px;background-position: 0 -350px;}.news-section .download a.experience-btn {height: 108px;background-position: 0 -461px;}</style><body><div class="main main_wrapper"><div class="news-section"><div class="banner"><ul class="image-list"><li class="item"><a href=""><img src="./img/banner_01.jpeg" alt=""></a></li><li class="item"><a href=""><img src="./img/banner_02.jpeg" alt=""></a></li><li class="item"><a href=""><img src="./img/banner_03.jpeg" alt=""></a></li><li class="item"><a href=""><img src="./img/banner_04.jpeg" alt=""></a></li><li class="item"><a href=""><img src="./img/banner_05.jpeg" alt=""></a></li></ul><ul class="title-list"><li class="item active"><a href="#">桑启的旅途故事</a></li><li class="item"><a href="#">启示之音抢先听</a></li><li class="item"><a href="#">谁成为版本之子</a></li><li class="item"><a href="#">观赛体验升级</a></li><li class="item"><a href="#">季后赛开战</a></li></ul></div><div class="news"></div><div class="download"><a class="download-btn" href="#"></a><a class="guard-btn" href="#"></a><a class="experience-btn" href="#"></a></div></div></div><script>// 1.获取元素var titleListEl = document.querySelector(".title-list")var activeItemEl = document.querySelector(".active")var imageListEl = document.querySelector(".image-list")// 2.底部titles的切换, 同时进行轮播titleListEl.onmouseover = function(event) {// 1.1.确定发生鼠标进入的元素var itemEl = event.target.parentElementif (!itemEl.classList.contains("item")) return// 1.2.移除之前的activeactiveItemEl.classList.remove("active")// 1.3.将active添加到鼠标进入的元素itemEl.classList.add("active")// 1.4.让activeItemEl指向最新的元素activeItemEl = itemEl// 1.5.移动对应的imageListEl// 1.5.1. 获取itemEl所在的索引// for (var i = 0; i < titleListEl.children.length; i++) {//   if (titleListEl.children[i] === itemEl) break// }var index = Array.from(titleListEl.children).findIndex(function(item) {return item === itemEl})imageListEl.style.transform = `translateX(${-604 * index}px)`imageListEl.style.transition = `all 300ms ease`}</script></body>

6.2_添加定时器,自动轮播

 <script>// 1.获取元素var titleListEl = document.querySelector(".title-list")var imageListEl = document.querySelector(".image-list")// 定义变量保存 状态var activeItemEl = document.querySelector(".active")var currentIndex = 0// 2.鼠标 底部titles的切换, 同时进行轮播titleListEl.onmouseover = function(event) {// 1.1.确定发生鼠标进入的元素var itemEl = event.target.parentElementif ( ! itemEl.classList.contains("item")) return// 1.2.移除之前的activeactiveItemEl.classList.remove("active")// 1.3.将active添加到鼠标进入的元素itemEl.classList.add("active")// 1.4.让activeItemEl指向最新的元素activeItemEl = itemEl// 1.5.移动对应的imageListEl//获取鼠标所在的索引var index = Array.from( titleListEl.children ).findIndex( function ( item )  {return item === itemEl})//根据 索引 移动对应到图片imageListEl.style.transform = `translateX(${-604 * index}px)`imageListEl.style.transition = `all 300ms ease`currentIndex = index}// 3.定时器: 定时轮播setInterval(function() {currentIndex++if (currentIndex === titleListEl.children.length) {currentIndex = 0}imageListEl.style.transform = `translateX(${-604 * currentIndex}px)`imageListEl.style.transition = `all 300ms ease`// 处理titles中的li的active// 1> 移除之前的activeactiveItemEl.classList.remove("active")// 2> 添加新的activevar currentItemEl = titleListEl.children[currentIndex]currentItemEl.classList.add("active")// 3> 记录新的activeLiactiveItemEl = currentItemEl}, 3000);</script>

6.3_代码重构

抽取重复逻辑的代码,构成函数

<script>// 1.获取元素var titleListEl = document.querySelector(".title-list")var imageListEl = document.querySelector(".image-list")// 定义变量保存一些的状态var activeItemEl = document.querySelector(".active")var currentIndex = 0// 2.底部titles的切换, 同时进行轮播titleListEl.onmouseover = function(event) {//2.1.确定发生鼠标进入的元素var itemEl = event.target.parentElementif ( ! itemEl.classList.contains("item")) return// 2.2.获取对应的索引indexvar index = Array.from(titleListEl.children).findIndex(function(item) {return item === itemEl})currentIndex = index// 2.3.调用切换的函数switchBanner()}// 3.定时器: 定时轮播setInterval(function() {currentIndex++if (currentIndex === titleListEl.children.length) {currentIndex = 0}// 调用切换的函数switchBanner()}, 3000);// 封装一个切换轮播的函数function switchBanner() {// 第一件事情: 让imageListEl滚动// 1.1.让imageListEl修改transformimageListEl.style.transform = `translateX( ${ -604 * currentIndex } px )`imageListEl.style.transition = `all 300ms ease`// 第二件事情: 改变title选中// 1.2.移除之前的activeactiveItemEl.classList.remove("active")// 1.3.将active添加到鼠标进入的元素var currentItemEl = titleListEl.children[currentIndex]currentItemEl.classList.add("active")// 1.4.让activeItemEl指向最新的元素activeItemEl = currentItemEl}</script>

6.4_优化轮播效果

(无论什么顺序切换,看起来只有前后两张图进行切换)

 <script>// 1.获取元素var titleListEl = document.querySelector(".title-list")var imageListEl = document.querySelector(".image-list")var bannerEl = document.querySelector(".banner")// 定义变量保存一些的状态var activeTitleEl = titleListEl.querySelector(".active")var currentIndex = 0var previousIndex = 0var timerID = null// 2.底部titles的切换, 同时进行轮播titleListEl.onmouseover = function(event) {// 1.1.确定发生鼠标进入的元素var itemEl = event.target.parentElementif (!itemEl.classList.contains("item")) return// 1.2.获取对应的索引indexvar index = Array.from(titleListEl.children).findIndex(function(item) {return item === itemEl})previousIndex = currentIndex   //上一个节点的索引currentIndex = index      //当前节点的索引// 1.3.调用切换的函数switchBanner()}// 3.定时器: 定时轮播startTimer()// 监听banner的事件  bannerEl.onmouseenter = function() {clearInterval(timerID)   //鼠标进入了索引栏区域,停止定时轮播}bannerEl.onmouseleave = function() {startTimer()     //鼠标离开了索引栏区域,开启定时轮播}// 封装一个切换轮播的函数function switchBanner() {// 第一件事情: 让imageListEl迅速移动// 1.1.让imageListEl修改transform// 其他内容需要调整//for循环 遍历每一张图片for (var i = 0; i < imageListEl.children.length; i++) {var itemEl = imageListEl.children[i]if (i === currentIndex) { // 当前要展示的imageItemitemEl.style.transition = "left 300ms ease"itemEl.style.left = "0"} else if (i < currentIndex) { // 需要放到左侧的imageItemif (i !== previousIndex) {itemEl.style.transition = "none"  //取消切换效果}itemEl.style.left = "-100%"  //放到展示框左边} else { // 需要放到右侧的imageItemif (i !== previousIndex) {itemEl.style.transition = "none"  //取消切换效果}itemEl.style.left = "100%"  //放到展示框右边}}// 第二件事情: 改变title选中状态// 1.2.移除之前的activeactiveTitleEl.classList.remove("active")// 1.3.将active添加到鼠标进入的元素var currentItemEl = titleListEl.children[currentIndex]currentItemEl.classList.add("active")// 1.4.让activeItemEl指向最新的元素activeTitleEl = currentItemEl}// 封装一个添加定时器的函数function startTimer() {timerID = setInterval(function() {previousIndex = currentIndexcurrentIndex++if (currentIndex === titleListEl.children.length) {currentIndex = 0}// 调用切换的函数switchBanner()}, 3000);}</script>



7_表格信息展示

在这里插入图片描述

<style>table {border-collapse: collapse;}thead {background-color: #f5f5f5;}th, td {border: 1px solid #aaa;padding: 8px 12px;text-align: center;}</style><body><table><thead><tr><th>编号</th><th>书籍名称</th><th>出版日期</th><th>价格</th><th>购买数量</th><th>操作</th></tr></thead><tbody></tbody></table><h2 class="price">总价格: ¥<span class="price-count">0</span></h2><script>// 1.从服务器获取数据 ajax/fetchvar books = [{id: 1,name: '《算法导论》',date: '2006-09',price: 85.00,count: 3},{id: 2,name: '《UNIX编程艺术》',date: '2006-02',price: 59.00,count: 2},{id: 3,name: '《编程珠玑》',date: '2008-10',price: 39.00,count: 5},{id: 4,name: '《代码大全》',date: '2006-03',price: 128.00,count: 8}]// 2.对数据展示// 到底通过html直接编写, 还是通过JavaScriptDOM操作创建元素// 1> 对于固定的, 直接通过html编写(能通过html编写, 尽量通过html直接编写)// 2> 对于哪些大量的数据, 有规律的数据, 可以通过JavaScript编写var tbodyEl = document.querySelector("tbody")// 2.2.  for循环 动态添加tr以及内部数据for (var i = 0; i < books.length; i++) {var trowEl = document.createElement("tr")// 2.3. 放具体数据var book = books[i]var bookKeys = Object.keys(book)for (var m = 0; m < bookKeys.length; m++) {var key = bookKeys[m]var value = book[key]var tdEl = document.createElement("td")if (key === "price") {value = "¥" + value}tdEl.textContent = valuetrowEl.append(tdEl)}// 2.4. 添加删除按钮var deleteTdEl = document.createElement("td")var deleteBtnEl = document.createElement("button")deleteBtnEl.textContent = "删除"deleteTdEl.append(deleteBtnEl)trowEl.append(deleteTdEl)// 2.5.监听删除按钮的点击deleteBtnEl.onclick = function() {// 1.删除对应的trowvar deleteTRowEl = this.parentElement.parentElementvar deleteTrIndex = deleteTRowEl.sectionRowIndexdeleteTRowEl.remove()// 2.删除对应books中的数据books.splice(deleteTrIndex, 1)// 3.重新计算一次价格calcTotalPrice()}tbodyEl.append(trowEl)}// 3.计算总价格var priceCountEl = document.querySelector(".price-count")calcTotalPrice()// 封装计算价格的函数function calcTotalPrice() {var totalPrice = books.reduce(function(preValue, item) {return preValue + item.count * item.price}, 0)priceCountEl.textContent = totalPrice}</script></body>

这篇关于JS-12 window定时器方法、setTimeout、setInterval、DOM实战案例(轮播消息提示+关闭隐藏消息+侧边栏展示+tabControl切换标签栏+轮播图);表格信息展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/234310

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、