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

文字滚动效果组件和按钮组件

今天和大家分享一个vue中好用的组件,是我自己写的,大家也可以自己改,就是文字的循环滚动效果,如下图,文字会向左移动,结束之后也会有一个循环,还有一个按钮组件,基本框架写的差不多了已经,大家可以看着改,如果使用直接拿走就行了

文字: 

相应效果图: 

相应使用方法:

章节使用组件就可以了 

文字滚动源代码:

大家使用只需要改上面的文字就行了,字体样式大家在对应元素的css当中写 

<template><div class="announcement"><!-- 头部图标和标题 --><div class="announcement_icon"><span class="icon iconfont">&#xe506;</span></div><div class="announcement_title">最新公告</div><!-- 滚动区域 --><div class="announcement_text"><!-- 添加滚动容器 --><div ref="scrollDiv" class="scroll-container"><!-- 双份相同内容实现无缝循环 --><div ref="scrollBegin" class="scroll-content"><span class="pad_right">{{ announcementText }}</span></div><div ref="scrollEnd" class="scroll-content"></div></div></div></div>
</template><script setup>
import { ref, onMounted } from 'vue'const announcementText = `在当今数字化时代,人工智能(AI)已经逐渐渗透到我们生活的方方面面。从智能家居设备到自动驾驶汽车,AI的应用正在不断扩展和深化。随着技术的不断进步,AI的能力也在不断提升,它不仅能够处理复杂的计算任务,还能模拟人类的思维和行为模式。 AI的发展带来了许多机遇和挑战。一方面,它极大地提高了生产效率,改善了人们的生活质量。例如,医疗领域中,AI可以帮助医生更准确地诊断疾病,提供个性化的治疗方案。另一方面,AI也引发了一些伦理和社会问题,如隐私保护、数据安全和就业结构的变化。这些问题需要我们在技术发展的过程中不断探索和解决。未来,AI 将继续在更多领域发挥重要作用。教育、金融、交通等行业都将受益于 AI的创新应用。同时,随着 AI 技术的普及,人们对其理解和接受度也在提高。这将有助于推动 AI更好地服务于社会,为人类创造更多的福祉。` // 简化的公告文本const scrollDiv = ref(null)
const scrollBegin = ref(null)
const scrollEnd = ref(null)
let MyMar = null
const speed = 10 // 滚动速度(数值越大越慢)const initMarquee = () => {if (!scrollBegin.value || !scrollEnd.value || !scrollDiv.value) return// 克隆内容实现无缝滚动scrollEnd.value.innerHTML = scrollBegin.value.innerHTMLconst marquee = () => {if (!scrollDiv.value) return// 判断滚动位置重置if (scrollDiv.value.scrollLeft >= scrollBegin.value.offsetWidth) {scrollDiv.value.scrollLeft = 0} else {scrollDiv.value.scrollLeft += 1}}// 设置滚动间隔MyMar = setInterval(marquee, speed)// 鼠标控制scrollDiv.value.addEventListener('mouseenter', () => clearInterval(MyMar))scrollDiv.value.addEventListener('mouseleave', () => {MyMar = setInterval(marquee, speed)})
}onMounted(() => {initMarquee()
})
</script><style scoped>
/* 基础布局 */
.announcement {display: flex;align-items: center;height: 78px;background: #f8f9fa;padding: 0 20px;z-index: -10;
}/* 图标样式 */
.announcement_icon {color: #338bcd;margin-right: 10px;
}
.announcement_icon .iconfont {font-size: 29px;
}/* 标题样式 */
.announcement_title {font-size: 22px;color: #006fc1;white-space: nowrap;margin-right: 20px;
}/* 滚动区域 */
.announcement_text {width: 100%;height: 100%;line-height: 78px;overflow: hidden;position: relative;
}.scroll-container {display: inline-flex; /* 关键:保持内容横向排列 */white-space: nowrap; /* 禁止文字换行 */position: absolute;animation: marquee 40s linear infinite; /* 备用CSS动画 */z-index: 100;
}.scroll-content {display: inline-block;padding-right: 50px; /* 内容间隔 */
}/* 鼠标悬停暂停 */
.scroll-container:hover {animation-play-state: paused;
}/* 备用CSS动画 */
@keyframes marquee {0% {transform: translateX(0);}100% {transform: translateX(-50%);}
}/* 响应式适配 */
@media (max-width: 768px) {.announcement {padding: 0 10px;height: 60px;}.announcement_title {font-size: 16px;margin-right: 10px;}.scroll-content {font-size: 14px;}
}
</style>

 

按钮:

效果图:

相应使用方法:

<el-row>
<MButton type="" >普通</MButton>
<MButton type="primary">主要</MButton>
<MButton type="success">成功</MButton>
<MButton type="info">信息</MButton>
<MButton type="warning">警告</MButton>
MButton type="danger">危险</MButton>
</el-row>
<el-row>
<MButton type="" plain>普通</MButton)
<MButton type="primary" plain>主要</MButton)
<MButton type="success" plain>成功</MButton)
<MButton type="info" plain>信息</MButton>
<MButton type="warning" plain>警告</MButton,
<MButton type="danger"plain>危险</MButton>
</e1-row>
<el-row>
<MButton type="" round>普通</MButton>
<MButton type="primary" round>主要</MButton》
<MButton type="success" round>成功</MButton)
<MButton type="info" round>信息</MButton>
<MButton type="warning" round>警告</MButton:
<MButton type="danger" round>危险</MButton>
</el-row>
<el-row>
<MButton type="" circle icon="fa-trash "></MButton>
<MButton type="primary" circle icon="fa-trash "></MButtonMButton type="success" circle icon="fa-trash "></MButton<MButton type="info" circle icon="fa-trash"></MButton><MButton type="warning" circle icon="fa-trash "></MButton."></MButton>MButton type="danger" circle icon="fa-trash
</el-row>
<MButton type="text">你好</MButton>
>主要</MButton><MButton type="primary"
medium>主要</MButton><MButton type="primary"
MButton type="primary'sma1l>主要</MButton)
mini>主要</MButton><MButton type="primary"
<MButton type="primary":loading="true">加载中</MButton>

 按钮组件源代码:

<template><button :class="[classColorType, classStyleType, classSizeType, classDisable]"><i v-if="loading" class="fa fa-spinner fa-spin"></i><i v-else :class="['fa', icon]"></i><span><slot></slot></span></button>
</template><script>
export default {props: {type: {type: String,default: 'default'},loading: {typeof: Boolean,default: false},icon: {type: String,default: '' // 默认没有图标},mini: {type: Boolean,default: false // 不传则默认为 false},small: {type: Boolean,default: false},medium: {type: Boolean,default: false},plain: {type: Boolean,default: false},round: {type: Boolean,default: false},circle: {type: Boolean,default: false},disabled: {type: Boolean,default: false}},data () {return {myType: this.type}},methods: {changeType () {this.myType = '' // 修改本地数据而不是 prop}},computed: {classDisable () {if (this.disabled) {return 'disabled-button'}return ''},classColorType () {const map = {primary: 'primary-button',success: 'success-button',info: 'info-button',warning: 'warning-button',danger: 'danger-button',text: 'text-button',default: 'color-default-button'}if (this.plain) {return map.default}return map[this.type] || map.default},classStyleType () {if (this.plain) {if (this.type === 'primary') {return 'plain-primary-button'}if (this.type === 'success') {return 'plain-success-button'}if (this.type === 'info') {return 'plain-info-button'}if (this.type === 'warning') {return 'plain-warning-button'}if (this.type === 'danger') {return 'plain-danger-button'}if (this.type === 'default') {return 'color-default-button'}}if (this.round) return 'round-button'if (this.circle) return 'circle-button'return ''},classSizeType () {if (this.medium && !this.circle && this.type !== 'text') return 'medium-button'if (this.small && !this.circle && this.type !== 'text') return 'small-button'if (this.mini && !this.circle && this.type !== 'text') return 'mini-button'return 'size-default-button'}}
}
</script><style scoped lang="less">
button{display: inline-block;border: 1px solid rgb(225, 225, 225);white-space: nowrap;cursor: pointer;text-align: center;box-sizing: border-box;outline: none;font-weight: 500;border-radius: 4px;transition: 0.1s;
}
.fa{display: inline-block;// vertical-align: middle; /* 将图标垂直居中 */margin-bottom: 2px;margin: 0px 2px;
}
.size-default-button{font-size: 14px;height: 40px;line-height: 40px;padding: 1px 20px;
}
.medium-button{font-size: 13px;height: 36px;padding: 0px 18px;line-height: 36px;
}
.small-button{font-size: 12px;height: 32px;padding: 1px 17px;line-height: 32px;
}
.mini-button{font-size: 10px;padding: 0px 16px;height: 28px;
}
.text-button{background-color: #ffffff00;border: none;color: #626262;
}
.text-button:hover{color: #347eff;
}
.color-default-button{background-color: #ffffff;color: #606266;
}
.primary-button{background-color: #5593ff;color: #ffffff;
}
.success-button{background-color: #7fd06d;color: #ffffff;
}
.info-button{background-color: #4d596d;color: #ffffff;
}
.warning-button{background-color: #efb136;color: #ffffff;
}
.danger-button{background-color: #cd5353;color: #ffffff;
}
.primary-button {background-color: #3697ff;color: #ffffff;
}
.success-button {background-color: #28a745;color: #ffffff;
}
.danger-button {background-color: #dc3545;color: #ffffff;
}
/* 不同颜色按钮的 hover 效果 */
.color-default-button:hover {background-color: rgba(202, 228, 255, 0.5); /* 最后一个参数 0.5 表示透明度 */color: #2a7cee;
}
.primary-button:hover {background-color: #0076f5;opacity: 0.5;
}
.info-button:hover {background-color: #5f6861;opacity: 0.5;
}
.warning-button:hover {background-color: #ebc04b;opacity: 0.5;
}
.success-button:hover {background-color: #429d56;opacity: 0.5;
}
.danger-button:hover {background-color: #c82333;opacity: 0.5;
}
.plain-primary-button{color: #0076f5;background-color: rgba(223, 238, 255, 0.5);
}
.plain-success-button{color: #33b847;background-color: rgba(223, 255, 225, 0.5);
}
.plain-info-button{color: #606060;background-color: rgba(228, 228, 228, 0.5);
}
.plain-warning-button{color: #ff9913;background-color: rgba(255, 245, 223, 0.5);
}
.plain-danger-button{color: #f53100;background-color: rgba(255, 223, 223, 0.5);
}
.plain-primary-button:hover{background-color: #5589e3;color: #ffffff;
}
.plain-success-button:hover{background-color: #8adc78;color: #ffffff;
}
.plain-info-button:hover{background-color: #606a7b;color: #ffffff;
}
.plain-warning-button:hover{background-color: hsl(35, 68%, 64%);color: #ffffff;
}
.plain-danger-button:hover{background-color: #e76262;color: #ffffff;
}
.round-button{border-radius: 50% / 100%;
}
.circle-button{width: 40px !important;height: 40px !important;border-radius: 50%;padding-bottom: 1px;align-items: center !important;
}.circle-button i{margin-left: -5px;
}.circle-button span{margin-left: -8px;
}
.disabled-button {cursor: not-allowed !important;opacity: 0.5;pointer-events: none;
}
/* 不同颜色按钮的 active 效果(点击时变淡) */
.color-default-button:active {border: 1px solid rgb(142, 159, 255);color: #659eff;background-color: #c0dbff5c;
}
.primary-button:active {background-color: rgb(39, 117, 195);opacity: 1;
}
.info-button:active {background-color: rgb(65, 62, 62);opacity: 1;
}
.warning-button:active {background-color: rgb(221, 169, 25);opacity: 1;
}
.success-button:active {background-color: rgb(19, 208, 60);opacity: 1;
}
.danger-button:active {background-color: rgb(204, 26, 44);opacity: 1;
}
.plain-primary-button:active {background-color: rgb(52, 106, 198);color: rgb(255, 255, 255);
}
.plain-success-button:active {background-color: rgb(41, 190, 63);color: rgb(255, 255, 255);
}
.plain-info-button:active {background-color: rgb(96, 96, 96);color: rgb(255, 255, 255);
}
.plain-warning-button:active {background-color: rgb(220, 145, 46);color: rgb(255, 255, 255);
}
.plain-danger-button:active {background-color: rgb(215, 89, 89);color: rgb(255, 255, 255);
}
</style>

相关文章:

文字滚动效果组件和按钮组件

今天和大家分享一个vue中好用的组件&#xff0c;是我自己写的&#xff0c;大家也可以自己改&#xff0c;就是文字的循环滚动效果&#xff0c;如下图&#xff0c;文字会向左移动&#xff0c;结束之后也会有一个循环&#xff0c;还有一个按钮组件&#xff0c;基本框架写的差不多了…...

Sqlserver安全篇之_TLS的证书概念

证书的理解 参考Sqlserver的官方文档https://learn.microsoft.com/zh-cn/sql/database-engine/configure-windows/certificate-overview?viewsql-server-ver16 TLS(Transport Layer Security)传输层安全和SSL(Secure Sockets Layer)安全套接字层协议位于应用程序协议层和TCP/…...

VS Code 如何搭建CC++开发环境

VS Code 如何搭建C/C开发环境 文章目录 VS Code 如何搭建C/C开发环境1. VS Code是什么2. VS Code的下载和安装2.1 下载和安装2.2 环境的介绍 3. VS Code配置C/C开发环境3.1 下载和配置MinGW-w64编译器套件3.2 安装C/C插件3.3 重启VS Code 4. 在VS Code上编写C语言代码并编译成功…...

计算机网络之传输层(传输层的功能)

一、数据分段与重组 传输层从会话层接收数据&#xff0c;并将其分割成较小的数据段&#xff0c;以适应网络层的最大传输单元&#xff08;MTU&#xff09;限制。在目的端&#xff0c;传输层负责将这些数据段重新组合成原始数据&#xff0c;确保数据的完整性和正确性。 二、端口…...

中科大计算机网络原理 1.5 Internt结构和ISP

一、互联网的层次化架构 ‌覆盖范围分层‌ ‌主干网&#xff08;Tier-1级&#xff09;‌ 国家级或行业级核心网络&#xff0c;承担跨区域数据传输和全球互联功能。例如中国的四大主干网&#xff08;ChinaNET、CERNET等&#xff09;以及跨国运营商&#xff08;如AT&T、Deuts…...

【网络安全 | 渗透工具】小程序反编译分析源码 | 图文教程

未经许可,禁止转载。 本文仅供学习使用,严禁用于非法渗透测试,笔者不承担任何责任。 文章目录 1、下载Proxifier2、下载反编译工具unveilr3、寻找小程序文件包4、对文件包进行反编译5、对源码进行分析6、渗透思路6.1、查找敏感信息泄露6.2、解析加解密逻辑6.3、枚举 API 接口…...

在鸿蒙HarmonyOS手机上安装hap应用

一、下载工具 安装hap包需要用到小工具 。 二、解压到目录后&#xff0c;进入该文件夹&#xff0c;打开命令行&#xff0c;如下图 三、将下载好的hap包放入刚才解压的文件夹内&#xff08;假设hap包文件名为app.hap&#xff09; 四、连接好手机和电脑&#xff0c;手机需要打…...

SQLAlchemy系列教程:SQLAlchemy快速入门示例项目

SQLAlchemy是与数据库交互的Python开发人员不可或缺的库。这个强大的ORM允许使用python结构进行简单的数据库操作。设置过程很简单&#xff0c;并且允许可扩展的数据库应用程序开发。本文通过入门项目完整介绍SQLAlchemy的应用过程&#xff0c;包括安装依赖包&#xff0c;创建连…...

【大模型系列篇】DeepSeek开源周,解锁AI黑科技

&#x1f525; Day1&#xff1a;FlashMLA —— GPU推理加速器 专为处理长短不一的AI推理请求而生&#xff0c;就像给Hopper GPU装上了智能导航&#xff0c;让数据在芯片上跑出3000GB/s的"磁悬浮"速度。✅ 已支持BF16格式&#xff5c;580万亿次浮点运算/秒FlashMLA G…...

【Java 基础(人话版)】Java SE vs Java EE

Java SE vs Java EE&#xff1a;有什么区别&#xff1f; 最近在学习 Java 的时候&#xff0c;总是会看到 Java SE 和 Java EE 这两个概念。刚开始有点迷糊&#xff0c;后来查了资料、做了一些实验&#xff0c;终于弄清楚了它们的区别。这里记录一下&#xff0c;希望对以后复习…...

Nmap使用指南

Nmap使用指南 Nmap (网络映射器) 是一款强大的应用网络扫描和安全核查工具&#xff0c;适合于网络管理和安全专家。本文将介绍Nmap的基本使用方法&#xff0c;包括基本命令和常用功能。 1. 基本使用方式 Nmap的基本命令格式如下&#xff1a; nmap [选项] 目标地址目标地址 可…...

C#-委托

Action 无返回值&#xff0c;多线程常用 Action<string> action1 (name) > Console.WriteLine($"hello {name}"); action1("tom"); Func 有返回值&#xff0c;扩展方法常用&#xff0c;最后一个参数是输出参数 Func<int, int, double>…...

Qt中如果槽函数运行时间久,避免阻塞主线程的做法

Qt中如果槽函数运行时间久&#xff0c;避免阻塞主线程的做法 一、解决步骤 创建一个工作线程类&#xff1a;继承自QObject&#xff0c;并在其中实现槽函数的逻辑。将工作线程类的实例移动到单独的线程中&#xff1a;通过moveToThread()方法将对象移动到新线程。启动线程&…...

SQLark 数据迁移|断点续迁已上线(Oracle-达梦)

数据迁移是 SQLark 最受企业和个人用户欢迎的功能之一&#xff0c;截止目前已帮助政府、金融、能源、通信等 50 家单位完成从 Oracle、MySQL 到达梦的全量迁移&#xff0c;自动化迁移成功率达 96% 以上。 在 Oracle 到达梦数据库迁移过程中&#xff0c;SQLark V3.3 新增 断点续…...

【学术会议论文投稿】Spring Boot实战:零基础打造你的Web应用新纪元

第七届人文教育与社会科学国际学术会议&#xff08;ICHESS 2024&#xff09;_艾思科蓝_学术一站式服务平台 更多学术会议请看&#xff1a;https://ais.cn/u/nuyAF3 目录 一、Spring Boot简介 1.1 Spring Boot的诞生背景 1.2 Spring Boot的核心特性 二、搭建开发环境 2.1…...

【Multipath网络层协议】MPTCP工作原理

常见网络层多路径协议介绍 MPTCP&#xff08;Multipath TCP&#xff09; MPTCP 是在传统 TCP 基础上进行扩展的协议&#xff0c;它允许在源端和目的端之间建立多个 TCP子流&#xff0c;这些子流可以通过不同的网络路径传输数据。 例如&#xff0c;一台笔记本电脑同时连接了 W…...

【网络安全】从NA到P1,我是如何扩大思路的?

未经许可,不得转载。 本文涉及漏洞均已修复。 文章目录 正文正文 在这篇文章中,我将向大家展示一个我发现的漏洞,该漏洞利用了一个硬编码的 Basic 认证头,获取了管理员权限。 首先,假设公司域名为“target.com”。 第一步是使用多种工具(如 Amass、subfinder、findoma…...

使用 Postman 访问 Keycloak 端点

1. 引言 在本教程中&#xff0c;我们将首先快速回顾 OAuth 2.0、OpenID 和 Keycloak。然后&#xff0c;我们将了解 Keycloak REST API 以及如何在 Postman 中调用它们。 2. OAuth 2.0 OAuth 2.0 是一个授权框架&#xff0c;它允许经过身份验证的用户通过令牌向第三方授予访问…...

[AI机器人] Web-AI-Robot机器人前瞻版--比奇堡海之霸凯伦

文章目录 简述开源Web-AI-Robot 项目-比奇堡-海之霸-凯伦 技术架构效果预览 简述 本项目配合前端项目bikini_bottom_karen_ui运行&#xff0c;来源于柒杉工作室&#xff08;截止2025.2&#xff0c;目前我自己&#xff09;。 打造一个只需要在浏览器上运行的AI智能机器人&#…...

FastAPI 学习笔记

简介&#xff1a; FastAPI 是一个用于构建 API 的现代、快速&#xff08;高性能&#xff09;的 web 框架&#xff0c;使用 Python 并基于标准的 Python 类型提示。 关键特性: 快速&#xff1a;可与 NodeJS 和 Go 并肩的极高性能&#xff08;归功于 Starlette 和 Pydantic&…...

CineMaster: 用于电影文本到视频生成的 3D 感知且可控的框架。

CineMaster是一种 3D 感知且可控的文本到视频生成方法允许用户在 3D 空间中联合操纵物体和相机&#xff0c;以创作高质量的电影视频。 相关链接 论文&#xff1a;cinemaster-dev.github.io 论文介绍 CineMaster是一种用于 3D 感知和可控文本到视频生成的新型框架。目标是让用…...

Linux上用C++和GCC开发程序实现两个不同PostgreSQL实例下单个数据库中多个Schema稳定高效的数据迁移到其它PostgreSQL实例

设计一个在Linux上运行的GCC C程序&#xff0c;同时连接三个不同的PostgreSQL实例&#xff0c;其中两个实例中分别有两个数据库中多个Schema的表结构分别与第三实例中两个数据库中多个Schema个结构完全相同&#xff0c;同时复制两个实例中两个数据库中多个Schema里的所有表的数…...

【Qt】ffmpeg照片提取、视频播放▲

目录 一、图像的成像原理&#xff1a; RGB成像原理&#xff1a; YUV成像原理&#xff1a; 二、多线程 三、ffmpeg解码&#xff08;照片提取&#xff09; 1.准备工作 &#xff08;1&#xff09;在工程文件夹里面新建三个文件夹 &#xff08;2&#xff09;在main函数中加…...

大语言模型中的 Token:它们是什么,如何工作?

引言 如果你使用过 ChatGPT 这样的 AI 工具&#xff0c;你可能会好奇&#xff1a;它是如何理解并生成文字的&#xff1f;大语言模型&#xff08;LLM&#xff0c;Large Language Model&#xff09;并不是直接处理整个句子或文章&#xff0c;而是拆分成一个个 Token&#xff08;…...

如何评估所选择的PHP后端框架的性能?

大家在选择PHP后端框架的时候&#xff0c;如果想评估其性能如何&#xff0c;能不能扛得住你的项目&#xff1f;可以根据以下几点进行分析&#xff0c;帮助大家选择到更符合自己心目中的PHP后端框架。 1. 基准测试 基准测试是评估框架性能的基础方法&#xff0c;主要通过模拟高…...

从UNIX到Linux:操作系统进化史与开源革命

从UNIX到Linux&#xff1a;操作系统进化史与开源革命 一、操作系统&#xff1a;数字世界的基石 1.1 什么是操作系统&#xff1f; 操作系统&#xff08;OS&#xff09;是计算机系统的核心管理者&#xff0c;承担着三大核心使命&#xff1a; 硬件指挥官&#xff1a;直接管理C…...

神经网络 - 激活函数(Sigmoid 型函数)

激活函数在神经元中非常重要的。为了增强网络的表示能力和学习能力&#xff0c;激活函数需要具备以下几点性质: (1) 连续并可导(允许少数点上不可导)的非线性函数。可导的激活函数可以直接利用数值优化的方法来学习网络参数. (2) 激活函数及其导函数要尽可能的简单&#xff0…...

【AD】3-10 原理图PDF导出

文件—智能PDF 多页原理图导出 导出设置时选择工程&#xff0c;可自行选择导出一页或多页原理图&#xff0c;一般PCB不用导出...

Linux上用C++和GCC开发程序实现两个不同MySQL实例下单个Schema稳定高效的数据迁移到其它MySQL实例

设计一个在Linux上运行的GCC C程序&#xff0c;同时连接三个不同的MySQL实例&#xff0c;其中两个实例中分别有两个Schema的表结构分别与第三实例中两个Schema个结构完全相同&#xff0c;同时复制两个实例中两个Schema里的所有表的数据到第三个实例中两个Schema里&#xff0c;使…...

C进阶 自定义类型

目录 前言 一 结构体 二 结构体的存储 三 位段 四 枚举 五 联合体 总结 前言 我们之前学习的int char double ......都是内置类型&#xff0c;但是我们今天所学习的是自定义类型&#xff0c;比如联合体&#xff0c;结构体&#xff0c;枚举 一 结构体 结构体是一…...

010 rocketmq批量消息

文章目录 批量消息BatchProducer.javaBatchConsumer.java 批量消息 批量发送可以提⾼发送性能&#xff0c;但有⼀定的限制&#xff1a; topic 相同 waitStoreMsgOK 相同 &#xff08;⾸先我们建设消息的iswaitstoremsgoktrue(默认为true), 如果没有异常,我们将始终收到"O…...

【华三】从零开始掌握SR技术:原理、架构与应用全解析

【华三】从零开始掌握SR技术&#xff1a;原理、架构与应用全解析 一、初识SR&#xff1a;路由技术的新革命1.1 传统网络的困扰&#xff1a;从真实案例看技术瓶颈1.1.1 企业网络运维之痛问题2&#xff1a;流量工程实现困难问题3&#xff1a;网络智能化缺失 1.2 SR的诞生意义&…...

安全模块设计:token服务、校验注解(开启token校验、开启签名校验、允许处理API日志)、获取当前用户信息的辅助类

文章目录 引言pom.xmlI 校验注解ApiValidationII token服务TokenService获取当前用户信息的辅助类III 域登录接口响应数据登陆用户信息引言 pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/PO…...

考虑复杂遭遇场景下的COLREG,基于模型预测人工势场的船舶运动规划方法附Matlab代码

考虑复杂遭遇场景下的COLREG&#xff0c;基于模型预测人工势场的船舶运动规划方法附Matlab代码 一、引言 1.1、研究背景和意义 随着全球航运业的迅猛发展&#xff0c;船舶交通密度不断增大&#xff0c;海上交通事故频发&#xff0c;严重威胁到海上航行的安全。国际海上避碰规…...

构建高效系统:API接口设计规范详解

在当今的数字化时代&#xff0c;应用程序接口&#xff08;API&#xff0c;Application Programming Interface&#xff09;已成为连接不同软件系统和服务的桥梁&#xff0c;是推动数字化转型的关键技术之一。无论是企业内部系统集成、第三方服务接入&#xff0c;还是面向开发者…...

【文献阅读】A Survey Of Resource-Efficient LLM And Multimodal Foundation Models

发表时间&#xff1a;二〇二四年九月二十三日 摘要 大型基础模型&#xff0c;包括大语言模型&#xff08;LLMs&#xff09;、视觉Transformer&#xff08;ViTs&#xff09;、扩散模型以及基于大语言模型的多模态模型&#xff0c;正在革新整个机器学习的生命周期&#xff0c;…...

mysql 全方位安装教程

下载 MySQL 【官网下载地址】 注意要选择较大的哪个安装包&#xff0c;小的安装包是一个安装器。 我们不用登录&#xff0c;直接下载 直接运行下载好的安装包 MySQL如果是 安装包安装, 可以图形化界面自主配置 如果是压缩包解压, 可以配置 配置文件, 可以解压安装到指定的…...

【Linux】Linux的进程控制

目录 1. 学习思维导图 2.进程创建&#xff08;fork&#xff09; 2.1 fork创建进程失败 3.进程终止 3.1 进程退出情况 3.1.1main函数 3.1.2 退出码 3.2 exit/_exit函数 1. exit() 函数 2. _exit() 函数 4.进程等待 4.1 实现进程等待的方法 wait/waitpid方法 区别&a…...

金融支付行业技术侧重点

1. 合规问题 第三方支付系统的平稳运营&#xff0c;严格遵循《非银行支付机构监督管理条例》的各项条款是基础与前提&#xff0c;其中第十八条的规定堪称重中之重&#xff0c;是支付机构必须牢牢把握的关键准则。 第十八条明确指出&#xff0c;非银行支付机构需构建起必要且独…...

Django模型管理器/QuerySet 常见的方法

模型管理器/QuerySet 常见的方法 get([**kwargs]) 方法 用途&#xff1a;获取满足条件的唯一对象。参数&#xff1a;关键字参数&#xff0c;指定查询条件。返回值&#xff1a;模型对象。异常&#xff1a;如果找到多个对象或未找到对象&#xff0c;将分别抛出 MultipleObjects…...

QT播放视频保持视频宽高比消除黑边

QT播放视频保持视频宽高比消除黑边 1、问题 在播放视频的时候&#xff0c;由于框架的大小发生变化&#xff0c;导致视频出现黑边很不好看。 因此需要像一种方法消除黑边 2、处理 1、读取视频的宽高比 2、设置视频的Widget的大小固定&#xff0c;Widget的宽高比和视频宽高比…...

在Ubuntu中,某个文件的右下角有一把锁的标志是什么意思?

在Ubuntu中&#xff0c;某个文件的右下角有一把锁的标志是什么意思&#xff1f; 在 Ubuntu&#xff08;或其他基于 GNOME 文件管理器的 Linux 发行版&#xff09;中&#xff0c;文件或文件夹的右下角出现一把“锁”标志&#xff0c;通常表示 你当前的用户没有该文件/文件夹的写…...

聊聊Java的SPI机制

个人自建博客地址 什么是SPI呢&#xff1f; SPI全称Service Provider Interface&#xff0c;翻译过来就是服务提供者接口。调用方提供接口声明&#xff0c;服务提供方对接口进行实现&#xff0c;提供服务的一种机制&#xff0c;服务提供方往往是第三方或者是外部扩展。 下面…...

【 实战案例篇三】【某金融信息系统项目管理案例分析】

大家好,今天咱们来聊聊金融行业的信息系统项目管理。这个话题听起来可能有点专业,但别担心,我会尽量用大白话给大家讲清楚。金融行业的信息系统项目管理,说白了就是如何高效地管理那些复杂的IT项目,确保它们按时、按预算、按质量完成。咱们今天不仅会聊到一些理论,还会通…...

go并发编程

https://www.bilibili.com/video/BV16A4y1f7EX sync包工具 Mutex&#xff1a;同一时间只有一个goroutine持有锁&#xff0c;其它申请该锁的goroutine会被阻塞。RWMutex&#xff1a;允许多个协程同时读取共享数据&#xff0c;但写入时需要独占锁。WaitGroup&#xff1a;等待一组…...

使用Python开发以太坊智能合约:轻松入门与深度探索

使用Python开发以太坊智能合约&#xff1a;轻松入门与深度探索 随着区块链技术的快速发展&#xff0c;以太坊作为最为成熟和广泛使用的智能合约平台&#xff0c;成为了开发去中心化应用&#xff08;DApp&#xff09;的核心工具。智能合约不仅是区块链技术的基础&#xff0c;更…...

Python从0到100(八十九):Resnet、LSTM、Shufflenet、CNN四种网络分析及对比

前言&#xff1a; 零基础学Python&#xff1a;Python从0到100最新最全教程。 想做这件事情很久了&#xff0c;这次我更新了自己所写过的所有博客&#xff0c;汇集成了Python从0到100&#xff0c;共一百节课&#xff0c;帮助大家一个月时间里从零基础到学习Python基础语法、Pyth…...

密码学(哈希函数)

4.1 Hash函数与数据完整性 数据完整性&#xff1a; 检测传输消息&#xff08;加密或未加密&#xff09;的修改。 密码学Hash函数&#xff1a; 构建某些数据的简短“指纹”&#xff1b;如果数据被篡改&#xff0c;则该指纹&#xff08;以高概率&#xff09;不再有效。Hash函数…...

设计模式Python版 备忘录模式

文章目录 前言一、备忘录模式二、备忘录模式示例1三、备忘录模式示例2 前言 GOF设计模式分三大类&#xff1a; 创建型模式&#xff1a;关注对象的创建过程&#xff0c;包括单例模式、简单工厂模式、工厂方法模式、抽象工厂模式、原型模式和建造者模式。结构型模式&#xff1a…...

CES Asia 2025聚焦量子计算,多领域进展引关注

作为亚洲地区极具影响力的科技盛会&#xff0c;CES Asia 2025第七届亚洲消费电子技术贸易展&#xff08;赛逸展&#xff09;将在首都北京举办。本届展会以“创新、智能、互联”为主题&#xff0c;将全方位展示全球消费科技领域的最新成果与发展趋势。其中&#xff0c;量子计算作…...