当前位置: 首页 > news >正文

前端技术(26) : 全年排班日历

来源: 通义千问

效果图

代码

<!DOCTYPE html>
<html lang="zh-CN"><head><meta charset="UTF-8"><title>年度日历</title><style>body {font-family: Arial, sans-serif;}.calendar-container {margin: 20px auto;width: 90%;max-width: 1000px;}h1,h2 {text-align: center;color: #4a148c;}table {width: 100%;border-collapse: collapse;margin-bottom: 20px;}th,td {padding: 10px;text-align: center;border: 1px solid #ddd;position: relative;}th {background-color: #e0e0e0;color: #4a148c;}.workday {background-color: #ffffcc;}/* 浅黄色 */.holiday,.off-day {background-color: white;}/* 默认白色 */.makeup-workday {background-color: #ffffcc;}/* 调休补班时为浅黄色 */.special-date {background-color: #6a1b9a;color: white;}/* 紫色 */.service-day {border: 2px solid #42a5f5 !important;}/* 蓝色 */.today {background-color: #fff25d;}/* 当天日期为紫色边框 */.month-separator {border-top: 2px solid #4a148c;margin: 20px 0;}.today-display {text-align: center;color: #4a148c;margin-bottom: 20px;}.top-right-corner {position: absolute;top: 0;right: 0;background-color: #e3e3e3;/* 确保文字背景与单元格背景一致 */padding: 2px 5px;/* 根据需要调整内边距 */font-size: 0.8em;/* 调整字体大小 */}</style></head><body><div class="calendar-container"><div class="today-display" id="todayDisplay"></div><h1 id="yearTitle">2024年日历</h1><input type="number" id="yearInput" value="2024"><button onclick="updateCalendar()">更新日历</button><div style="float: right;"><table style="width: 300px;"><tbody><tr><td class="workday" style="width: 100px;">工作日</td><td class="service-day workday" style="width: 100px;">服务日</td><td class="workday" style="width: 100px;">驻场'<span class="top-right-corner">上海</span>'</td></tr></tbody></table></div><div id="calendarContainer"></div></div><script>// 法定节假日列表const holidays = [/// 2024年'2024-01-01', // 元旦'2024-02-10', '2024-02-11', '2024-02-12', '2024-02-13', '2024-02-14', '2024-02-15', '2024-02-16','2024-02-17', // 春节'2024-04-04', '2024-04-05', '2024-04-06', // 清明节'2024-05-01', '2024-05-02', '2024-05-03', '2024-05-04', '2024-05-05', // 劳动节'2024-06-08', '2024-06-09', '2024-06-10', // 端午节'2024-09-15', '2024-09-16', '2024-09-17', // 中秋节'2024-10-01', '2024-10-02', '2024-10-03', '2024-10-04', '2024-10-05', '2024-10-06', '2024-10-07', // 国庆节/// 2025年'2025-01-01', // 元旦'2025-01-28', '2025-01-29', '2025-01-30', '2024-01-31', '2025-02-02', '2025-02-03', '2025-02-04', // 春节'2025-04-04', '2025-04-05', '2025-04-06', // 清明节'2025-05-01', '2025-05-02', '2025-05-03', '2025-05-04', '2025-05-05', // 劳动节'2025-05-31', '2024-06-01', '2024-06-02', // 端午节'2025-10-01', '2025-10-02', '2025-10-03', '2025-10-04', '2025-10-05', '2025-10-06', '2025-10-07','2025-10-08', // 国庆节中秋节];// 调休补班列表()const makeupDays = [/// 2024年'2024-02-04', '2024-02-18', // 春节调休补班'2024-04-07', // 清明节调休补班'2024-04-28', '2024-05-11', // 劳动节调休补班'2024-09-14', // 中秋节调休补班'2024-09-29', '2024-10-12', // 国庆节调休补班/// 2025年'2025-01-26', '2025-02-08', // 春节调休补班'2025-04-27', // 劳动节调休补班'2025-09-28', // 中秋节调休补班'2025-10-11', // 国庆节调休补班];// 驻场的日期const inSceneDates = [// 2024['2024-08-11', '2024-08-30'],['2024-09-02', '2024-09-14'],['2024-09-18', '2024-09-30'],['2024-10-08', '2024-10-25'],['2024-10-28', '2024-11-15'],['2024-12-02', '2024-12-20'],// 2025['2025-01-06', '2025-01-17'],['2025-02-17', '2025-03-07'],['2025-03-24', '2025-04-03'],['2025-04-21', '2025-04-30'],['2025-05-19', '2025-05-30'],['2025-06-16', '2025-07-04'],['2025-07-21', '2025-08-08'],]const finalInSceneDates = flattenDateRanges(inSceneDates);// 服务开始日期和天数const serviceStartDate = '2024-08-12'; // 示例:服务从3月1日开始const serviceWorkdaysCount = 7 * 30; // 示例:20个工作日var serviceWorkdaysPassed = 0;const serviceDays = []function updateCalendar() {const year = document.getElementById('yearInput').value;document.getElementById('yearTitle').innerText = `${year}年日历`;document.getElementById('calendarContainer').innerHTML = ''; // 清空旧日历for (let month = 1; month <= 12; month++) {if (month > 1) {document.getElementById('calendarContainer').insertAdjacentHTML('beforeend','<hr class="month-separator">');}createMonthCalendar(year, month);}// 更新今天日期显示const today = new Date();document.getElementById('todayDisplay').textContent = `今天是:${today.toLocaleDateString()}`;}function createMonthCalendar(year, month) {const container = document.getElementById('calendarContainer');const table = document.createElement('table');const thead = document.createElement('thead');const tbody = document.createElement('tbody');// Create header row with days of weekconst headerRow = document.createElement('tr');const daysOfWeek = ['周日', '周一', '周二', '周三', '周四', '周五', '周六'];daysOfWeek.forEach(day => {const th = document.createElement('th');th.textContent = day;headerRow.appendChild(th);});thead.appendChild(headerRow);table.appendChild(thead);// Fill in calendar daysconst date = new Date(year, month - 1, 1);const lastDay = new Date(year, month, 0).getDate();const startDay = date.getDay(); // Get the first day of the week (0=Sun, 1=Mon, ...)let day = 1;for (let i = 0;; i++) {for (let j = 0; j < 7; j++) {if (i === 0 && j < startDay || day > lastDay) {} else {const currentDate = `${year}-${String(month).padStart(2, '0')}-${String(day).padStart(2, '0')}`;const isHoliday = holidays.includes(currentDate);const isMakeupDay = makeupDays.includes(currentDate);const isWorkday = !isHoliday && ((j >= 1 && j <= 5) || isMakeupDay);let isServiceDay = falseif (isWorkday) {if (serviceDays.includes(currentDate)) {isServiceDay = trueserviceDays.push(currentDate)} else {if (new Date(currentDate) >= new Date(serviceStartDate)) {if (isWorkday) {serviceWorkdaysPassed++;if (serviceWorkdaysPassed <= serviceWorkdaysCount) {isServiceDay = trueserviceDays.push(currentDate)}}}}}day++;}}if (day > lastDay) break;}let endServiceDay = getMaxDate(serviceDays)console.log(endServiceDay)day = 1;for (let i = 0;; i++) {const row = document.createElement('tr');for (let j = 0; j < 7; j++) {if (i === 0 && j < startDay || day > lastDay) {row.appendChild(document.createElement('td'));} else {const cell = document.createElement('td');const currentDate = `${year}-${String(month).padStart(2, '0')}-${String(day).padStart(2, '0')}`;const isHoliday = holidays.includes(currentDate);const isMakeupDay = makeupDays.includes(currentDate);const isInSceneDay = finalInSceneDates.includes(currentDate);const isWorkday = !isHoliday && ((j >= 1 && j <= 5) || isMakeupDay);const today = new Date().toJSON().slice(0, 10) === currentDate;let isServiceDay = falseif (isWorkday) {cell.classList.add('workday');// Check if this is a service workdayif (serviceDays.includes(currentDate)) {isServiceDay = truecell.classList.add('service-day');} else {if (new Date(currentDate) >= new Date(serviceStartDate)) {if (isWorkday) {serviceWorkdaysPassed++;if (serviceWorkdaysPassed <= serviceWorkdaysCount) {isServiceDay = truecell.classList.add('service-day');serviceDays.push(currentDate)}}}}} else {cell.classList.add('holiday');}let remake = ''if (isInSceneDay) {if (endServiceDay != null && new Date(currentDate) <= new Date(endServiceDay)) {remake += '<span class="top-right-corner">上海</span>'}}if (today) {cell.classList.add('today'); // Add purple border to today's date}cell.innerHTML = day + remake;day++;row.appendChild(cell);}}tbody.appendChild(row);if (day > lastDay) break;}table.appendChild(tbody);// Add month titleconst monthTitle = document.createElement('h2');const monthNames = ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'];monthTitle.textContent = monthNames[month - 1];container.appendChild(monthTitle);container.appendChild(table);}// Initialize the calendar on page loadwindow.onload = function() {updateCalendar();};function generateDateRange(startDate, endDate) {const dateArray = [];let currentDate = new Date(startDate);const end = new Date(endDate);while (currentDate <= end) {dateArray.push(currentDate.toISOString().split('T')[0]);currentDate.setDate(currentDate.getDate() + 1);}return dateArray;}function flattenDateRanges(dateRanges) {return dateRanges.reduce((acc, [start, end]) => {acc.push(...generateDateRange(start, end));return acc;}, []);}function getMaxDate(dateArray) {if (dateArray.length === 0) return null;// 将日期字符串数组映射为时间戳数组,并找到最大值const maxTimestamp = Math.max(...dateArray.map(dateStr => Date.parse(dateStr)));// 将最大时间戳转换回日期字符串const maxDate = new Date(maxTimestamp).toISOString().split('T')[0];return maxDate;}</script></body>
</html>

相关文章:

前端技术(26) : 全年排班日历

来源: 通义千问 效果图 代码 <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><title>年度日历</title><style>body {font-family: Arial, sans-serif;}.calendar-container {margin: 20px au…...

Linux网络——TCP的运用

系列文章目录 文章目录 系列文章目录一、服务端实现1.1 创建套接字socket1.2 指定网络接口并bind2.3 设置监听状态listen2.4 获取新链接accept2.5 接收数据并处理&#xff08;服务&#xff09;2.6 整体代码 二、客户端实现2.1 创建套接字socket2.2 指定网络接口2.3 发起链接con…...

Elasticsearch 数据存储底层机制详解

Elasticsearch 数据存储底层机制详解 Elasticsearch 的底层存储机制依赖 Lucene 来实现数据的组织和管理。下面从数据存储的 流转过程 和 管理机制 两个方面来详细说明。 1. 数据存储流程 当一个文档通过 REST API 被写入 Elasticsearch 时&#xff0c;会经历以下流程&#x…...

Spring Boot 中 Map 的最佳实践

在Spring Boot中使用Map时&#xff0c;请遵循以下最佳实践: 1.避免在Controller中 直接使用Map。应该使用RequestBody 接收-个DTO对象或者 RequestParam接收参数&#xff0c;然后在Service中处 理Map。 2.避免在Service中 直接使用原始的Map。应该使用Autowired 注入-个专门…...

es6 字符串每隔几个中间插入一个逗号

const insertCommaEveryNChars (str, n) > {// 将字符串转换为数组&#xff0c;以便我们可以更容易地操作每个字符const chars str.split();// 使用map遍历数组&#xff0c;并在每隔n个字符后插入逗号const result chars.map((char, index) > {// 检查当前位置是否是n…...

区块链共识机制深度揭秘:从PoW到PoS,谁能主宰未来?

区块链的技术背后&#xff0c;最大的挑战之一就是如何让多个分布在全球各地的节点在没有中心化管理者的情况下达成一致&#xff0c;确保数据的一致性和安全性。这一切都依赖于区块链的核心——共识机制。共识机制不仅决定了区块链的安全性、效率和去中心化程度&#xff0c;还对…...

SQL Server 新建 用户 登录失败。 (Microsoft SQL Server,错误: 18456)

新建用户后用SQLserver shen身份验证一直提示用户登录用户 登录失败。 (Microsoft SQL Server,错误: 18456)。 问题&#xff1a; 新建标题: 连接到服务器 无法连接到 DESKTOP-GKBXLEE。 其他信息: 用户 ‘’ 登录失败。 (Microsoft SQL Server&#xff0c;错误: 18456) 解…...

AW36518芯片手册解读(3)

接前一篇文章&#xff1a;AW36518芯片手册解读&#xff08;2&#xff09; 二、详述 3. 功能描述 &#xff08;1&#xff09;上电复位 当电源电压VIN降至预定义电压VPOR&#xff08;典型值为2.0V&#xff09;以下时&#xff0c;该设备会产生复位信号以执行上电复位操作&#x…...

有没有免费提取音频的软件?音频编辑软件介绍!

出于工作和生活娱乐等原因&#xff0c;有时候我们需要把音频单独提取出来&#xff08;比如歌曲伴奏、人声清唱等、乐器独奏等&#xff09;。要提取音频必须借助音频处理软件&#xff0c;那么有没有免费提取音频的软件呢&#xff1f;下面我们将为大家介绍几款免费软件&#xff0…...

一次医院RIS系统的升级

2020-03-11 目录 数据库升级... 1 数据结构升级... 1 系统配置... 2 WEB服务器准备... 3 启动ASP.NET State Service服务... 3 检查IIS. 4 发布站点... 4 添加应用程序池... 4 发布网站... 5 处理打印模板... 6 web.config的配置... 6 处理图片文件目录... 6 修改W…...

clickhouse测试报告

​一、背景 针对当前实施的项目&#xff0c;面临着两个主要挑战&#xff1a;一是需要存储更详细的原始数据和中间数据&#xff0c;二是现有基于MySQL的数据存储解决方案在数据量增长时性能受限&#xff0c;特别是在进行跨年历史数据的即时分析时。为了解决这些问题&#xf…...

Elasticsearch安装和数据迁移

Elasticsearch安装和数据迁移 Elasticsearch安装 下载并解压Elasticsearch 首先下载Elasticsearch的tar.gz文件&#xff0c;并将其解压&#xff1a; wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-8.8.2-linux-x86_64.tar.gz tar -xzf elastics…...

K8s证书过期

part of the existing bootstrap client certificate is expired: 2023-11-27 12:44:12 0000 UTC 查看运行日志&#xff1a; journalctl -xefu kubelet 重新生成证书&#xff1a; #重新生成证书 kubeadm alpha certs renew all #备份旧的配置文件 mv /etc/kubernetes/*.conf…...

JSONException:java.lang.String cannot be converted to JSONObject异常的解决方法

在用org.json.JSONObject解析从网络获取的json数据时&#xff0c;遇到JSONException:java.lang.String cannot be converted to JSONObject&#xff0c;打印字符串&#xff0c;查看json字符串没有问题&#xff0c;研究了好长时间&#xff0c;终于找到问题&#xff0c;造成问题的…...

[源码解析] 模型并行分布式训练Megatron (2) --- 整体架构

link [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构 目录 [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构 0x00 摘要0x01 启动 1.1 分布式启动1.2 构造基础 1.2.1 获取模型1.2.2 获取数据集1.2.3 步进函数 1.2.3.1 广播数据0x02 Pretrain0x03 初始化 3.1 …...

kubeadm搭建k8s集群

前置环境&#xff1a; 准备三台虚拟机 192.168.1.104&#xff08;用来做k8s的mater节点&#xff09; 192.168.1.105&#xff08;节点node2&#xff09; 192.168.1.109&#xff08;节点node3&#xff09; 关闭防火墙 systemctl stop firewalld systemctl disable firewalld安装…...

家用无线路由器的 2.4GHz 和 5GHz

家中的无线路由器 WiFi 名称有两个&#xff0c;一个后面带有 “5G” 的标记&#xff0c;这让人产生疑问&#xff1a;“连接带‘5G’的 WiFi 是不是速度更快&#xff1f;” 实际上&#xff0c;这里的 “5G” 并不是移动通信中的 5G 网络&#xff0c;而是指路由器的工作频率为 5G…...

#渗透测试#漏洞挖掘#红蓝攻防#漏洞挖掘#未授权漏洞-Es未授权漏洞

免责声明 本教程仅为合法的教学目的而准备&#xff0c;严禁用于任何形式的违法犯罪活动及其他商业行为&#xff0c;在使用本教程前&#xff0c;您应确保该行为符合当地的法律法规&#xff0c;继续阅读即表示您需自行承担所有操作的后果&#xff0c;如有异议&#xff0c;请立即停…...

Windows 使用 非安装版MySQL 8

1.下载MySQL 8 https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.40-winx64.zip 2.创建my.ini 下载解压后&#xff0c;发现根目录没有my.ini文件&#xff0c;需手动创建 my.ini # For advice on how to change settings please see # http://dev.mysql.com/doc/refma…...

nginx Rewrite 相关功能

一、Nginx Rewrite 概述 定义 Nginx 的 Rewrite 模块允许对请求的 URI 进行重写操作。它可以基于一定的规则修改请求的 URL 路径&#xff0c;然后将请求定向到新的 URL 地址&#xff0c;这在很多场景下都非常有用&#xff0c;比如实现 URL 美化、网站重构后的 URL 跳转等。主要…...

2024年AI相关的论文写作经验(附实践资料下载)

在撰写AI相关的论文时&#xff0c;以下是一些实用的经验和技巧&#xff1a; 明确写作目标&#xff1a;在开始写作之前&#xff0c;明确你的论文类型&#xff08;期刊论文、毕业论文等&#xff09;和目标&#xff0c;这将影响你的写作方式和工具选择。 AI辅助文献检索&#xff…...

List详解

List详解 在Java中&#xff0c;List是一个接口&#xff0c;它继承自Collection接口。List接口为数据的有序集合提供了操作接口&#xff0c;其中可以包含重复的元素。这个接口的实现类以特定的方式存储元素&#xff0c;允许元素根据索引进行访问&#xff0c;同时还支持通过迭代…...

Flutter实现可拖拽操作Draggable

文章目录 1. Draggable 控件的构造函数主要参数&#xff1a; 2. Draggable 的工作原理3. 常见用法示例 1&#xff1a;基本的拖拽控件解释&#xff1a;示例 2&#xff1a;与 DragTarget 配合使用解释&#xff1a; 4. Draggable 的回调详解5. 总结 Draggable 是 Flutter 中一个用…...

【QSS样式表 - ⑥】:QPushButton控件样式

文章目录 QPushBUtton控件样式QSS示例 QPushBUtton控件样式 常用子控件 常用伪状态 QSS示例 代码&#xff1a; QPushButton {background-color: #99B5D1;color: white;font-weigth: bold;border-radius: 20px; }QPushButton:hover {background-color: red; }QPushButton:p…...

DPO(Direct Preference Optimization)算法解释:中英双语

中文版 DPO paper: https://arxiv.org/pdf/2305.18290 DPO 算法详解&#xff1a;从理论到实现 1. 什么是 DPO&#xff1f; DPO&#xff08;Direct Preference Optimization&#xff09;是一种直接基于人类偏好进行优化的算法&#xff0c;旨在解决从人类偏好数据中训练出表现…...

springboot495基于java的物资综合管理系统的设计与实现(论文+源码)_kaic

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统物资综合管理系统信息管理难度大&#xff0c;容错率低&am…...

JavaScript语言的编程范式

JavaScript&#xff1a;面向对象与函数式编程的双重奏 在编程世界中&#xff0c;JavaScript 无疑是一颗璀璨的明星&#xff0c;它不仅主宰着前端开发领域&#xff0c;还在后端、桌面应用、甚至物联网设备上展现出了强大的生命力。JavaScript 的魅力在于其灵活多变的编程范式&a…...

MyBatis动态 SQL 的执行原理

MyBatis 动态 SQL 是 MyBatis 框架中的一个重要特性&#xff0c;它允许开发者根据条件动态地生成不同的 SQL 语句。通过使用动态 SQL&#xff0c;开发者可以根据传入的参数动态地构建 SQL 查询&#xff0c;这样就避免了写多个 SQL 语句&#xff0c;提升了代码的灵活性和可维护性…...

PostgreSQL自带的一个命令行工具pg_waldump

pg_waldump是PostgreSQL自带的一个命令行工具&#xff0c;用于以人类可读的形式显示PostgreSQL数据库集簇的预写式日志&#xff08;Write-Ahead Logging&#xff0c;WAL&#xff09;。以下是对pg_waldump的详细介绍&#xff1a; 一、主要用途 pg_waldump主要用于调试或教育目…...

K8s 常用资源介绍

在 Kubernetes 中&#xff0c;资源指的是可以在集群中管理的对象&#xff08;Objects&#xff09;。这些资源用来定义和控制应用、服务、以及集群的状态。以下是 Kubernetes 中常见的资源及其用途介绍&#xff1a; 1. 工作负载资源&#xff08;Workloads Resources&#xff09;…...

基于 Python 大数据的拼团购物数据分析系统的设计与实现

标题:基于 Python 大数据的拼团购物数据分析系统的设计与实现 内容:1.摘要 本文设计并实现了一个基于 Python 大数据的拼团购物数据分析系统。通过对拼团购物数据的收集、清洗和分析&#xff0c;系统能够为商家提供用户行为分析、商品销售情况分析等功能&#xff0c;帮助商家更…...

finalshell密码解密

finalshell密码解密 在线网站运行java https://c.runoob.com/compile/10/ import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; import java.math.BigInteger; import java.security.MessageDigest; import java.security.N…...

利用Java爬虫速卖通按关键字搜索AliExpress商品

在这个信息爆炸的时代&#xff0c;数据的价值日益凸显。对于电商领域的从业者来说&#xff0c;能够快速获取商品信息成为了一项重要的技能。速卖通&#xff08;AliExpress&#xff09;作为全球领先的跨境电商平台&#xff0c;拥有海量的商品数据。本文将介绍如何使用Java语言编…...

每天40分玩转Django:Django缓存

一、Django缓存概述 在高并发的Web应用中,缓存是提高性能的重要手段。通过缓存频繁访问的数据,可以显著减少数据库查询和渲染模板的时间,从而加快响应速度,提升用户体验。Django提供了多层级的缓存方案,可以灵活地满足不同场景下的缓存需求。 Django支持的缓存方式包括: 视图…...

matrix-breakout-2-morpheus

将这一关的镜像导入虚拟机&#xff0c;出现以下页面表示导入成功 以root身份打开kali终端&#xff0c;输入以下命令&#xff0c;查看靶机ip arp-scan -l 根据得到的靶机ip&#xff0c;浏览器访问进入环境 我们从当前页面没有得到有用的信息&#xff0c;尝试扫描后台 发现有一个…...

第七节:GLM-4v-9b模型的视觉模型源码解读

文章目录 前言一、EVA2CLIPModel视觉编码模块结构二、PatchEmbedding图像分块源码解读三、GLM的transformer结构源码解读四、GLU映射方法源码解读前言 清华智普的GLM-4v-9b模型,作为优化的多模态大模型,特别适用于国内应用场景,解决了国外模型本地化不足的问题。本专栏提供…...

@RestControllerAdvice和@ControllerAdvice的区别

RestControllerAdvice 和 ControllerAdvice 都是 Spring 框架中的注解&#xff0c;用于定义全局的异常处理、数据绑定、模型属性共享等功能。它们的区别主要体现在返回值的处理和适用的场景。 1. ControllerAdvice 功能&#xff1a; ControllerAdvice 是 Spring MVC 提供的全局…...

c++ 类似与c# 线程 AutoResetEvent 和 ManualResetEvent的实现

在 C 中&#xff0c;没有直接类似于 C# 的 AutoResetEvent 和 ManualResetEvent 的类&#xff0c;但可以通过一些线程同步机制来实现类似的功能。C 提供了一些线程同步原语&#xff0c;如 std::condition_variable 和 std::mutex&#xff0c;这些可以用来模拟类似于 C# 中 Auto…...

简单贪吃蛇小游戏的设计与实现

文章目录 1、知识预备1.1 WIN32 API1.1.1 什么是WIN32 API1.1.2 了解部分WIN32 API1.1.2.1 控制台坐标1.1.2.2 控制台光标1.1.2.3 获取键盘按键情况 2.1 宽字符2.1.1 C语言的国际化2.1.2 宽字符的打印 2、 贪吃蛇游戏设计2.1 游戏开始2.2 游戏运行2.2.1 更新分数2.2.2 按键检测…...

动态规划<五> 子数组问题(含对应LeetcodeOJ题)

目录 引例 经典LeetcodeOJ题 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 6.第六题 7.第七题 引例 OJ传送门 Leetcode<53> 最大子数组和 画图分析: 使用动态规划解决 1.状态表示 dp[i]表示以i位置为结尾的所有子数组中的最大和 2.状态转移方程 子数组的问题可以…...

计算机网络——期末复习(4)协议或技术汇总、思维导图

思维导图 协议与技术 物理层通信协议&#xff1a;曼彻斯特编码链路层通信协议&#xff1a;CSMA/CD &#xff08;1&#xff09;停止-等待协议&#xff08;属于自动请求重传ARQ协议&#xff09;&#xff1a;确认、否认、重传、超时重传、 &#xff08;2&#xff09;回退N帧协…...

在 RK3568 Linux 系统上使用 TUN 设备:详细教程

RK3568 是一个基于 ARM 架构的处理器,广泛应用于嵌入式系统和物联网设备。Linux 系统上的 TUN(网络隧道)设备提供了一个虚拟的网络接口,允许用户空间程序通过内核与网络栈进行交互。本文将详细介绍如何在 RK3568 上配置和使用 TUN 设备,适用于搭建 VPN 或容器网络等应用场…...

记录一次前端绘画海报的过程及遇到的几个问题

先看效果 使用工具 html2canvas import html2canvas from html2canvas// 绘画前的内容 我就不过多写了<div class"content" ref"contentRef" v-show"!imgShow"><img :src"getReplaceImg(friendObj.coverUrl)" alt"&qu…...

费舍尔信息矩阵全面讲述

费舍尔信息矩阵&#xff08;Fisher Information Matrix&#xff09; 费舍尔信息矩阵是统计学中一个非常重要的概念&#xff0c;尤其在参数估计、最大似然估计&#xff08;MLE&#xff09;和贝叶斯推断中具有广泛的应用。它反映了参数估计的不确定性程度&#xff0c;也可以用来…...

【CSS in Depth 2 精译_094】16.2:CSS 变换在动效中的应用(下)——导航菜单的文本标签“飞入”特效与交错渲染效果的实现

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第五部分 添加动效 ✔️【第 16 章 变换】 ✔️ 16.1 旋转、平移、缩放与倾斜 16.1.1 变换原点的更改16.1.2 多重变换的设置16.1.3 单个变换属性的设置 16.2 变换在动效中的应用 16.2.1 放大图标&am…...

webpack3 webpack4 webpack5 有什么区别

性能优化 Webpack 3 性能优化主要依赖开发者手动配置各种插件。例如&#xff0c;在代码分割方面&#xff0c;需要通过CommonsChunkPlugin来实现公共模块的提取&#xff0c;其配置相对复杂。如果配置不当&#xff0c;可能会导致模块重复打包等问题&#xff0c;影响构建效率和最终…...

vue2 升级为 vite 打包

VUE2 中使用 Webpack 打包、开发&#xff0c;每次打包时间太久&#xff0c;尤其是在开发的过程中&#xff0c;本文记录一下 VUE2 升级Vite 步骤。 安装 Vue2 Vite 依赖 dev 依赖 vitejs/plugin-vue2": "^2.3.3 vitejs/plugin-vue2-jsx": "^1.1.1 vite&…...

[创业之路-206]:《华为战略管理法-DSTE实战体系》- 6-关键成功因素法CSF

目录 一、概述 1、定义与起源 2、关键成功因素的定义 3、关键成功因素的来源 4、关键成功因素的确认方法 5、关键成功因素法的步骤 6、关键成功因素法的应用 7、关键成功因素法的优势与局限性 二、 关键成功因素法CSF的应用 1、企业战略管理 2、项目管理 3、绩效管…...

WebRTC服务质量(08)- 重传机制(05) RTX机制

WebRTC服务质量&#xff08;01&#xff09;- Qos概述 WebRTC服务质量&#xff08;02&#xff09;- RTP协议 WebRTC服务质量&#xff08;03&#xff09;- RTCP协议 WebRTC服务质量&#xff08;04&#xff09;- 重传机制&#xff08;01) RTX NACK概述 WebRTC服务质量&#xff08;…...

Go的select的运行原理

Go语言中的select语句是一种专门用于处理多个通道&#xff08;channel&#xff09;操作的控制结构。其运行原理可以概括为以下几点&#xff1a; 1. 监听多个通道 select语句能够同时监听多个通道上的操作&#xff0c;这些操作可以是发送操作或接收操作。每个通道操作都对应se…...