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

Vue3实战五、面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

目录

  • 面包屑,收缩菜单,黑夜白夜样式,全屏功能实现
    • 收缩菜单按钮结合pinia功能实现
      • 第一步、定义布局配置的数据类型
      • 第二步、创建布局状态管理文件
      • 第三步、使用布局配置状态
      • 第四步、进行展开/收起左侧菜单逻辑
      • 第五步、动态切换左侧菜单宽度样式
      • 第六步、动态显示系统标题
      • 效果
    • 导航面包屑功能逻辑实现
      • 第一步、获取当前页面路由对象
      • 第二步、过滤出有meta.title且isBreadcrumb为true的路由对象
      • 第三步、渲染跳转面包屑
      • 第四步、编写面包屑手动跳转方法
      • 第五步、面包屑过渡动画样式
      • 整体代码
      • 效果
    • 使用VueUse实现全屏退出全屏效果-VueUse
      • 第一步、安装 `VueUse`
      • 第二步、使用 `useFullscreen` 函数实现全屏效果
      • 第三步、保留到pinia状态中
      • 第四步、修改pinia.d.ts
      • 第五步、模板中使用
      • 效果
    • 实现高亮和暗黑模式
      • 第一步、编写dark.scss文件
      • 第二步、导入暗黑主题css变量文件
      • 第三步、使用VueUse进行高亮/暗黑模式动态切换
      • 第四步、进行pinia持久化存储
      • 效果
    • 监听pinia状态持久化并刷新回显
      • 第一步、监听pinia更新localStorage
      • 第二步、贾汪localStorage更新到pinia中
      • 效果

面包屑,收缩菜单,黑夜白夜样式,全屏功能实现

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现
面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

收缩菜单按钮结合pinia功能实现

菜单收缩只要动态切换el-menu 组件上的 collapse Prop值即可。因为 collapse 状态值在 layoutAside/verticalMenu.vue 中获取后,需要与头部组件layoutHeader/index.vue 共享,多组件共享同一状态值使用 pinia 状态管理。

第一步、定义布局配置的数据类型

创建类型接口文件 src/types/pinia.d.ts ,定义布局配置的数据类型

/*** pinia状态类型定义*/
declare interface layoutConfigState{isCollapse:boolean; // 是否展开菜单globalTitle:string; // 网站主标题
}

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

第二步、创建布局状态管理文件

创建布局状态管理文件: src/stores/layoutConfig.ts

import {defineStore} from 'pinia'export const useLayoutConfigStore = defineStore('layoutConfig', {state:():layoutConfigState=>{return {isCollapse:false, // 菜单是否折叠globalTitle:"手撸管理后台", // 网站主标题}},getters:{},actions:{}
})

第三步、使用布局配置状态

layoutAside/verticalMenu.vue中使用布局配置状态模板中使用: :collapse="isCollapse"

<script lang="ts" setup>
import {useRoute} from 'vue-router'
import { storeToRefs } from 'pinia';
import {useLayoutConfigStore} from '@/stores/layoutConfig'
const route = useRoute()
const layoutConfigStore = useLayoutConfigStore()
const { isCollapse } = storeToRefs(layoutConfigStore)
</script>
<template><el-menu :collapse="isCollapse"  :default-openeds="['/system']"	:default-active="route.path" :router="true" background-color="transparent" class="el-menu-vertical-demo">
</template>

第四步、进行展开/收起左侧菜单逻辑

layoutHeader/breadcrumb.vue中实现点击切换图标,进行展开/收起左侧菜单逻辑

<template><div class="layout-header-breadcrumb"><!-- 收缩图标 --><SvgIcon:name="layoutConfig.isCollapse ? 'ele-Expand' : 'ele-Fold'"@click="handleChangeCollapse"class="layout-header-expand-icon"/><!-- 面包屑 --><el-breadcrumb separator="/"><el-breadcrumb-item :to="{ path: '/' }">系统管理</el-breadcrumb-item><el-breadcrumb-item>菜单管理</el-breadcrumb-item><el-breadcrumb-item>promotion detail</el-breadcrumb-item></el-breadcrumb></div>
</template><script lang="ts" setup>
import { useLayoutConfigStore } from "@/stores/layoutConfig";
import { Expand } from "@element-plus/icons-vue";
const layoutConfig = useLayoutConfigStore();
//  点击展开或收起左侧菜单
function handleChangeCollapse() {layoutConfig.isCollapse = !layoutConfig.isCollapse;
}
</script><style>
</style>

第五步、动态切换左侧菜单宽度样式

动态切换左侧菜单宽度样式,在 src\layout\layoutAside\index.vue 实现:

<template><!-- 左侧菜单栏 --><div class="h100"><el-asideclass="layout-container layout-aside layout-aside-menu-200":class="layoutConfig.isCollapse? 'layout-aside-menu-60': 'layout-aside-menu-200'"><logo /><VerticalMenu /></el-aside></div>
</template><script setup lang="ts" name="LayoutAside">
import { useLayoutConfigStore } from "@/stores/layoutConfig";
import { defineAsyncComponent } from "vue";
const Logo = defineAsyncComponent(() => import("./logo.vue"));
const VerticalMenu = defineAsyncComponent(() => import("./verticalMenu.vue"));
const layoutConfig = useLayoutConfigStore();
</script><style>
</style>

第六步、动态显示系统标题

当收起左侧菜单,在 layout/layoutAside/logo.vue 隐藏菜单上方的系统标题,并动态显示系统标题

<template><div class="layout-logo"><img class="layout-logo-img" src="@/assets/logo(1).png" alt="logo" /><span v-if="!layoutConfig.isCollapse">{{ layoutConfig.globalTitle }}</span></div>
</template>
<script lang="ts" setup name="LayoutLogo">
import { useLayoutConfigStore } from "@/stores/layoutConfig";
const layoutConfig = useLayoutConfigStore();
</script>
<style></style>

效果

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

导航面包屑功能逻辑实现

获取当前页面路由对象 route ,从路由对象中获取 matched 可获取当前路由的上N级路由对象,然后将数据渲染到面包屑处。

第一步、获取当前页面路由对象

layoutHeader/breadcrumb.vue 组件中实现:通过onMountedonBeforeRouteUpdate钩子获取

// 用于第一次加载时触发
onMounted(() => {getBreadcrumb(route);
});
// 路由更新时触发,当前目标路由对象
onBeforeRouteUpdate((to) => {getBreadcrumb(to);
});

第二步、过滤出有meta.title且isBreadcrumb为true的路由对象

function getBreadcrumb(to: RouteLocationNormalized) {// 过滤出当前有 meta.title 值且isBreadcrumb不为false的路由对象const matched = to.matched.filter((item) => item.meta && item.meta.title && item.meta.isBreadcrumb !== false);breadcrumbList.value = matched || [];
}

第三步、渲染跳转面包屑

<!-- 面包屑 --><el-breadcrumb separator="/"><!-- v-for过滤效果 --><TransitionGroup name="breadcrumb"><el-breadcrumb-itemv-for="(item, index) in breadcrumbList":key="item.path"><!-- 最后一级路由(当前路由),不可点击跳转 --><span v-if="index === breadcrumbList.length - 1" class="flex-center"><SvgIcon v-if="item.meta.icon" :name="item.meta.icon" :size="14" />{{ item.meta.title }}</span><a v-else @click.prevent="handleLink(item)" class="flex-center"><SvgIcon v-if="item.meta.icon" :name="item.meta.icon" :size="14" />{{ item.meta.title }}</a></el-breadcrumb-item></TransitionGroup></el-breadcrumb>

第四步、编写面包屑手动跳转方法

// 点击面包屑的某标题跳转
function handleLink(_route: RouteRecordNormalized) {const { redirect, path } = _route;if (redirect) {router.push(<string>redirect);} else {router.push(path);}
}

第五步、面包屑过渡动画样式

.breadcrumb-enter-active,
.breadcrumb-leave-active {transition: all .5s;
}
.breadcrumb-enter-from,.breadcrumb-leave-active {opacity: 0;transform: translateX(20px);
}
// 因为 TransitionGroup 不支持 mode="out-in",通过下面方式防止显示和隐藏效果同时出现。.breadcrumb-leave-active {position: absolute;z-index: -1;}

整体代码

<template><div class="layout-header-breadcrumb"><!-- 收缩图标 --><SvgIcon:name="layoutConfig.isCollapse ? 'ele-Expand' : 'ele-Fold'"@click="handleChangeCollapse"class="layout-header-expand-icon"/><!-- 面包屑 --><el-breadcrumb separator="/"><!-- v-for过滤效果 --><TransitionGroup name="breadcrumb"><el-breadcrumb-itemv-for="(item, index) in breadcrumbList":key="item.path"><!-- 最后一级路由(当前路由),不可点击跳转 --><span v-if="index === breadcrumbList.length - 1" class="flex-center"><SvgIcon v-if="item.meta.icon" :name="item.meta.icon" :size="14" />{{ item.meta.title }}</span><a v-else @click.prevent="handleLink(item)" class="flex-center"><SvgIcon v-if="item.meta.icon" :name="item.meta.icon" :size="14" />{{ item.meta.title }}</a></el-breadcrumb-item></TransitionGroup></el-breadcrumb></div>
</template><script lang="ts" setup>
import { useLayoutConfigStore } from "../../stores/layoutConfig";
import { onMounted, ref } from "vue";
import { useRoute, useRouter, onBeforeRouteUpdate } from "vue-router";
import type {RouteLocationNormalized,RouteRecordNormalized,
} from "vue-router";
const route = useRoute();
const router = useRouter();
// 面包屑渲染数据
const breadcrumbList = ref<RouteRecordNormalized[]>([]);
// 用于第一次加载时触发
onMounted(() => {getBreadcrumb(route);
});
// 路由更新时触发,当前目标路由对象
onBeforeRouteUpdate((to) => {getBreadcrumb(to);
});
function getBreadcrumb(to: RouteLocationNormalized) {// 过滤出当前有 meta.title 值且isBreadcrumb不为false的路由对象const matched = to.matched.filter((item) => item.meta && item.meta.title && item.meta.isBreadcrumb !== false);breadcrumbList.value = matched || [];
}const layoutConfig = useLayoutConfigStore();
//  点击展开或收起左侧菜单
function handleChangeCollapse() {layoutConfig.isCollapse = !layoutConfig.isCollapse;
}
// 点击面包屑的某标题跳转
function handleLink(_route: RouteRecordNormalized) {const { redirect, path } = _route;if (redirect) {router.push(<string>redirect);} else {router.push(path);}
}
</script><style>
</style>

效果

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

使用VueUse实现全屏退出全屏效果-VueUse

VueUse 基于Vue组合式API的实用工具集,官网、中文网。

第一步、安装 VueUse

 npm i @vueuse/core

第二步、使用 useFullscreen 函数实现全屏效果

用法参考。

<script lang="ts" setup>
import { useFullscreen } from "@vueuse/core";
import { useLayoutConfigStore } from "../../stores/layoutConfig";
const layoutConfig = useLayoutConfigStore();
// 全屏切换
const { isFullscreen, toggle: toggleFullscreen } = useFullscreen();
// 点击切换全屏
async function handleToggleFullscreen() {await toggleFullscreen();// 更新状态layoutConfig.isFullscreen = isFullscreen.value;
}
</script>

第三步、保留到pinia状态中

import { defineStore } from 'pinia'
export const useLayoutConfigStore = defineStore('layoutConfig', {state: (): layoutConfigState => {return {isCollapse: false, // 菜单是否折叠globalTitle: "手撸管理后台", // 网站主标题isFullscreen: false, // 是否全屏isDark: false, // 黑暗模式}},getters: {},actions: {  }
})

第四步、修改pinia.d.ts

/*** pinia状态类型定义*/
declare interface layoutConfigState{isCollapse:boolean; // 是否展开菜单globalTitle:string; // 网站主标题isFullscreen: boolean;isDark: boolean; 
}

第五步、模板中使用

n面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

<template><div class="layout-header-user"><div class="layout-header-user-icon mr5" @click="handleToggleFullscreen"><SvgIcon name="ele-FullScreen" /></div></div>
</template>

效果

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

实现高亮和暗黑模式

Element Plus 2.2.0+版本支持暗黑模式,导入暗黑样式文件,然后在index.htmlhtml标签上添加一个class="dark" 的类名即可切换为暗黑模式。

第一步、编写dark.scss文件

/* 暗黑样式
--------------------------- */
html[class='dark'] {--wyk-color-white: #fff;--wyk-color-black: #0f121d;--wyk-color-primary: #1966ff;--wyk-border-color: #333333;--wyk-color-hover: #3c3c3c;--wyk-color-hover-rgba: rgba(0, 0, 0, .9);// 左侧菜单--wyk-bg-menuMainColor: var(--wyk-color-black) !important;--wyk-bg-menuActiveColor: var(--wyk-color-primary) !important;--wyk-bg-menuHoverColor: #2e436e !important;--wyk-text-menuMainColor: var(--wyk-color-white) !important;--wyk-text-menuActiveColor: var(--wyk-color-white) !important;--wyk-text-menuHoverColor: var(--wyk-color-white) !important;// 头部导航--wyk-bg-headerBarColor: var(--wyk-color-black) !important;// 头部右侧图标光标浮动--wyk-color-user-hover: var(--wyk-color-hover-rgba) !important;// 边框--wyk-border-color-light: var(--wyk-border-color) !important;/* wangeditor 富文本编辑器 - css vars--------------------------- */--w-e-toolbar-bg-color: var(--el-bg-color) !important;--w-e-toolbar-color: var(--el-text-color-primary) !important;// // 工具栏浮动显示--w-e-toolbar-active-color: var(--el-text-color-primary) !important;--w-e-toolbar-active-bg-color: var(--el-color-primary-light-9) !important;--w-e-toolbar-border-color: var( --wyk-border-color) !important;// // 内容区域--w-e-textarea-bg-color: var(--el-bg-color) !important;--w-e-textarea-color: var(--el-text-color-primary) !important;// .el-switch {//   --el-switch-on-color: red !important;// }
}

第二步、导入暗黑主题css变量文件

src\styles\index.scss 中导入暗黑主题css变量文件

// ElementPlus 组件所有样式
@use 'element-plus/dist/index.css';
@use './app.scss';
@use './transition.scss';
// 暗黑主题-ElementPlus-CSS变量 
@use 'element-plus/theme-chalk/dark/css-vars.css';
// 暗黑主题-自定义CSS样式 
@use './dark.scss';

第三步、使用VueUse进行高亮/暗黑模式动态切换

建议使用 useDark | VueUse。

<script lang="ts" setup>
import { useLayoutConfigStore } from "../../stores/layoutConfig";
import { onMounted, ref } from "vue";
import { useRoute, useRouter, onBeforeRouteUpdate } from "vue-router";
import type {RouteLocationNormalized,RouteRecordNormalized,
} from "vue-router";
const route = useRoute();
const router = useRouter();
// 面包屑渲染数据
const breadcrumbList = ref<RouteRecordNormalized[]>([]);
// 用于第一次加载时触发
onMounted(() => {getBreadcrumb(route);
});
// 路由更新时触发,当前目标路由对象
onBeforeRouteUpdate((to) => {getBreadcrumb(to);
});
function getBreadcrumb(to: RouteLocationNormalized) {// 过滤出当前有 meta.title 值且isBreadcrumb不为false的路由对象const matched = to.matched.filter((item) => item.meta && item.meta.title && item.meta.isBreadcrumb !== false);breadcrumbList.value = matched || [];
}
const layoutConfig = useLayoutConfigStore();
//  点击展开或收起左侧菜单
function handleChangeCollapse() {layoutConfig.isCollapse = !layoutConfig.isCollapse;
}
// 点击面包屑的某标题跳转
function handleLink(_route: RouteRecordNormalized) {const { redirect, path } = _route;if (redirect) {router.push(<string>redirect);} else {router.push(path);}
}
</script>

第四步、进行pinia持久化存储

import { defineStore } from 'pinia'
export const useLayoutConfigStore = defineStore('layoutConfig', {state: (): layoutConfigState => {return {isCollapse: false, // 菜单是否折叠globalTitle: "手撸管理后台", // 网站主标题isFullscreen: false, // 是否全屏isDark: false, // 黑暗模式}},getters: {},actions: {}
})

效果

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

监听pinia状态持久化并刷新回显

面包屑,收缩菜单,高亮暗黑主题,全屏功能持久化功能实现

第一步、监听pinia更新localStorage

src/stores/layoutConfig.ts 最后添加对 state 的监听器,一旦state更新,则保存到浏览器的
localStorage 中。

import { defineStore } from 'pinia'
import { Local } from '@/utils/storage'
import { nextTick } from 'vue'
export const useLayoutConfigStore = defineStore('layoutConfig', {state: (): layoutConfigState => {return {isCollapse: false, // 菜单是否折叠globalTitle: "手撸管理后台", // 网站主标题isFullscreen: false, // 是否全屏isDark: false, // 黑暗模式}},getters: {},actions: {// 更新状态updateState(state:layoutConfigState){// 将传递的值更新到state状态中this.$patch(state)}}
})
nextTick(() => {const layoutConfig = useLayoutConfigStore()// 监听状态变化,将状态持久化layoutConfig.$subscribe((mutation, state) => {// 保存到浏览器的localStorage中Local.set('layoutConfig', state)})
})

第二步、贾汪localStorage更新到pinia中

App.vue 中的 onMounted 钩子中,当应用加载则读取localStorage中的 layoutConfig 状态值,更新到state 上。

<script setup lang="ts" name="App">
import { onMounted } from 'vue';
import { Local } from './utils/storage';
import { useLayoutConfigStore } from './stores/layoutConfig';
const layoutConfigStore = useLayoutConfigStore();
onMounted(()=>{// 获取localStorage配置const layoutConfig = Local.get('layoutConfig');if(layoutConfig){layoutConfigStore.updateState(layoutConfig);}
})
</script>
<template><div class="h100"><router-view></router-view></div>
</template>
<style scoped>
</style>

效果

面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

相关文章:

Vue3实战五、面包屑,收缩菜单,高亮暗黑主题切换,全屏功能实现

目录 面包屑&#xff0c;收缩菜单&#xff0c;黑夜白夜样式,全屏功能实现收缩菜单按钮结合pinia功能实现第一步、定义布局配置的数据类型第二步、创建布局状态管理文件第三步、使用布局配置状态第四步、进行展开/收起左侧菜单逻辑第五步、动态切换左侧菜单宽度样式第六步、动态…...

Linux内核设计——(二)进程调度

目录 一、进程调度简介 二、多任务 三、调度器 3.1 I/O消耗型和处理器消耗型进程 3.2 进程优先级 3.3 CFS算法 3.4 实时调度策略 3.5 SCHED_FIFO 3.6 SCHED_RR 3.7 调度器入口 四、上下文切换 4.1 睡眠和唤醒 4.2 need_resched标志 4.3 用户抢占 4.4 内核抢占 一…...

【C++初阶】--- string类模拟实现

1.基础函数 1.1成员函数 成员函数主要是_str、_size、_capacity这三个。npos是size_t 的最大值,用于当作后续成员函数的参数的缺省值。 class string { private:char* _str nullptr;//指向字符串的指针size_t _size 0;//字符串长度size_t _capacity 0;//空间大小static c…...

Pythia 使用说明

Pythia 是一个由非营利研究组织 EleutherAI 开发的开源语言模型套件&#xff0c;专注于透明性和可复现性。它是为了推动自然语言处理&#xff08;NLP&#xff09;领域的开放研究而设计&#xff0c;尤其在模型训练过程和性能分析方面提供了详尽的文档和数据。 Pythia 的核心特点…...

python:获取某路径下所有图片的名称

可以使用 Python 的 os 模块或者 pathlib 模块来获取指定路径下所有图片的名称。以下是使用这两种方法实现的代码示例&#xff1a; 使用 os 模块 import osdef get_image_names_os(path):image_extensions (.jpg, .jpeg, .png, .gif, .bmp)image_names []for root, dirs, f…...

一个开源的 VS Code 大模型聊天插件:Light-at

这篇文章是一个开发杂谈。对于有经验的开发者来说&#xff0c;可能这个项目并不算特别复杂或者高技术&#xff0c;只是对我个人来说算一个里程碑&#xff0c;因此写篇杂谈文章记录一下。也许也能给起步者一些参考。 项目地址&#xff1a;https://github.com/HiMeditator/light-…...

图论学习笔记2

请先阅读图论学习笔记 1。 在这篇文章里&#xff0c;我们将继续以前 tarjan 求解的强连通分量和双连通分量&#xff0c;讲解其缩点相关内容。 也会讲解一些特殊的图&#xff1a;基环树与仙人掌图、最小树形图。 缩点 我们知道&#xff0c;将强连通分量、双连通分量缩点之后…...

蓝桥杯备赛---真题训练之15届省赛产品360度展示

题目 介绍 在电子商务网站中&#xff0c;用户可以通过鼠标或手势交互实现 360 度全方位查看产品&#xff0c;提升用户体验。现在需要你设计一个 Pipeline 管道函数&#xff0c;用于控制 360 度展示产品的动画序列&#xff0c;通过管道连接各个动画步骤&#xff0c;使产品以流畅…...

图论:单源最短路(BF算法+迪杰斯特拉算法+spfa算法)

单源最短路 概念 dijkstra实现&#xff08;解决不了负权值&#xff09; P3371 【模板】单源最短路径&#xff08;弱化版&#xff09; - 洛谷 #include<iostream> #include<vector> #include<cstring> using namespace std;typedef pair<int, int> PII…...

嵌入式学习(35)-TTS语音模块FT-VBM-OS支持ModbusRTU

一、概述 FT-TTS-R-01 &#xff08;下简简“模块”&#xff09;是一款可将串口传入的文本信息转成语音播报的控制器。块”可下接收任意字 符或者汉字&#xff0c;并通过 TTS 语音合成功能&#xff0c;清晰、准确、自然的合成并播放音频。该块”还带有 1 路继电器输出&#xff0…...

【Vue-组件】学习笔记

目录 <<回到导览组件1.项目1.1.Vue Cli1.2.项目目录1.3.运行流程1.4.组件的组成1.5.注意事项 2.组件2.1.组件注册2.2.scoped样式冲突2.3.data是一个函数2.4.props详解2.5.data和prop的区别 3.组件通信3.1.父子通信3.1.1.父传子&#xff08;props&#xff09;3.1.2.子传父…...

Github上一些使用技巧(缩写、Issue的Highlight)自用

1. GIthub中的一些缩写 LGTM ! 最近经常看到一些迷之缩写&#xff0c;感觉挺有意思的&#xff0c;但是有时候看到一些没见过的缩写还是有点懵逼&#xff0c;不过缩写确实也是很方便去review&#xff0c;这里就记录汇总一下&#xff1b;顺便加了一些git的基操单词&#xff08;加…...

【团体程序涉及天梯赛】L1~L2实战反思合集(C++)

实战反思汇总记录 仔细审题&#xff0c;想好再写 L1-104 九宫格 - 团体程序设计天梯赛-练习集 易忽略的错误&#xff1a;开始习惯性地看到n就以为是n*n数组了&#xff0c;实际上应该是9*9的固定大小数组&#xff0c;查了半天没查出来 L1-101 别再来这么多猫娘了&#xff01…...

ubuntu下的node.js的安装

安装 node-v22.14.0-linux-x64.tar.xz 的步骤如下&#xff1a; 1. 下载和解压 如果尚未下载文件&#xff0c;可以通过 wget 下载&#xff08;替换为实际下载链接&#xff09;&#xff1a; wget https://nodejs.org/dist/v22.14.0/node-v22.14.0-linux-x64.tar.xz解压文件&…...

VMware-workstation-full-12.5.2 install OS X 10.11.1(15B42).cdr

手把手虚拟机安装苹果操作系统 VMware_workstation_full_12.5.2 unlocker208 Apple Max OS X(M&#xff09;-CSDN博客 vcpu-0:VERIFY vmcore/vmm/main/physMem_monitor.c:1180 FILE: FileCreateDirectoryRetry: Non-retriable error encountered (C:\ProgramData\VMware): Cann…...

Linux下创建svn库 和 svn安装与操作

1.介绍 SVN是Subversion的简称&#xff0c;是一个开放源代码的版本控制系统&#xff0c;相较于RCS、CVS&#xff0c;它采用了分支管理系统&#xff0c;它的设计目标就是取代CVS。适合中小公司的开发人员不多的项目使用,相比git管理工具更简单. 2.安装svn 2.1 国际惯例 首先看…...

React-04React组件状态(state),构造器初始化state以及数据读取,添加点击事件并更改state状态值

1.React组件状态&#xff08;state&#xff09; 组件可以拥有状态&#xff08;state&#xff09;&#xff0c;它是组件数据的私有部分&#xff0c;可以用来管理动态数据。状态仅适用于类组件&#xff0c;或者使用 React 的 Hook 时可以在函数组件中使用。 注意 组件中render方…...

第3课:MCP协议接口定义与开发实践

MCP协议接口开发实战&#xff1a;从标准化设计到跨语言SDK落地 一、引言&#xff1a;为什么接口标准化是多智能体协作的“刚需” 在多智能体系统中&#xff0c;不同语言开发的智能体、异构服务之间的通信效率往往受制于接口兼容性问题。MCP&#xff08;Model Context Protoco…...

Perl语言的WebAssembly

Perl语言的WebAssembly&#xff1a;将古老的语言带入新世纪 引言 在编程语言发展的历史长河中&#xff0c;Perl作为一门早期广泛使用的脚本语言&#xff0c;以其灵活性和丰富的文本处理能力而闻名。然而&#xff0c;随着互联网和Web技术的迅猛发展&#xff0c;许多开发者开始…...

[ISP] ISP 中的 GTM 与 LTM:原理、算法与与 Gamma 校正的对比详解

在现代图像信号处理&#xff08;ISP&#xff09;流水线中&#xff0c;图像增强是提升视觉质量的核心手段之一。尤其是在高动态范围&#xff08;HDR&#xff09;内容、弱光环境或复杂光照条件下&#xff0c;Tone Mapping&#xff08;色调映射&#xff09;技术的引入成为关键。To…...

健身管理小程序|基于java微信开发健身管理小程序的系统设计与实现(源码+数据库+文档)

健身管理小程序目录 基于微信开发健身管理小程序设计与实现 一、前言 二、系统设计 三、系统功能设计 小程序端&#xff1a; 后台 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍&#xff1a;✌️大厂码…...

批量将文本合并成单个文件,支持按文件夹合并文本文档

我们的文件夹中有零零碎碎的多个小的文本文件&#xff0c;这对我们存档记录是非常不方便&#xff0c;不友好的。如果我们能够将多个小的文本文件合并成一个完整的大的文本文件&#xff0c;那不管是在共享还是在存档起来都更加的方便。今天给大家介绍一下如何批量将多个文本文件…...

ROS云课三分钟-差动移动机器人巡逻报告如何撰写-中等报告

评语&#xff1a; 成绩中等&#xff08;70/100&#xff09;&#xff0c;具体如下&#xff1a; 1. 摘要部分 问题描述&#xff1a; 内容空洞&#xff1a;摘要过于简短&#xff0c;仅简要概述了研究内容和实现方法&#xff0c;未突出研究的创新点或重要性。缺乏细节&#xff1…...

forms实现推箱子小游戏

说明: forms实现推箱子小游戏 效果图&#xff1a; step0:游戏规则 # 推箱子游戏规则说明## &#x1f3af; 游戏目标 - 通过控制角色移动&#xff0c;将所有**棕色箱子(3)**推到**红色目标点(4)**上 - 当所有箱子都变为**绿色(7)**时&#xff0c;即完成当前关卡 - 完成全部关…...

图的储存+图的遍历

图的存储 邻接矩阵 #include <iostream>#include <cstring>using namespace std;const int N 1010;int n, m;int edges[N][N];int main() {memset(edges, -1, sizeof edges);cin >> n >> m; // 读⼊结点个数以及边的个数 for(int i 1; i < m; i)…...

蓝桥杯—数字接龙(dfs+减枝)

一.题目 二.思路 一看就是迷宫问题的变种&#xff0c;从左上角到达右下角&#xff0c;要解决 1.8个方向的方向向量&#xff0c;用dx&#xff0c;dy数组代表方向向量 2.要按照一个规律的数值串进行搜索0&#xff0c;1&#xff0c;2&#xff0c;k-1&#xff0c;0&#xff0c;1…...

Solidity智能合约漏洞类型与解题思路指南

一、常见漏洞类型与通俗解释 1. 重入攻击(Reentrancy) 🌀 通俗解释:就像你去银行取钱,柜台人员先给你钱,然后再记账。你拿到钱后立即又要求取钱,由于账还没记,柜台又给你一次钱,这样循环下去你就能拿走银行所有的钱。 漏洞原理:合约在更新状态前调用外部合约,允许…...

临床 不等于 医学-《分析模式》漫谈52

DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 “Analysis Patterns”的第4章“企业财务观察”有这么一句话&#xff1a; An important point about this model——a reflection of its clinical background 2004&#xff08;机械…...

鸿蒙应用开发中的 Stack 布局模式

在鸿蒙(HarmonyOS)应用开发中&#xff0c;Stack 布局模式是一种非常灵活的布局方式&#xff0c;类似于其他开发框架中的 StackPanel 或 AbsoluteLayout。它允许子组件按照层级关系进行堆叠&#xff0c;后添加的组件会覆盖在先添加的组件之上。开发者可以通过设置组件的位置、大…...

仿modou库one thread one loop式并发服务器

源码&#xff1a;田某super/moduo 目录 SERVER模块&#xff1a; Buffer模块&#xff1a; Socket模块&#xff1a; Channel模块&#xff1a; Connection模块&#xff1a; Acceptor模块&#xff1a; TimerQueue模块&#xff1a; Poller模块&#xff1a; EventLoop模块&a…...

【AI学习】初步了解Gradio

Gradio 是一个开源的 Python 库&#xff0c;专注于快速构建交互式 Web 界面&#xff0c;特别适用于机器学习模型、数据科学项目或任意 Python 函数的演示与部署。它通过极简的代码实现前后端一体化&#xff0c;无需前端开发经验即可创建功能丰富的应用。以下是 Gradio 的核心特…...

C++11QT复习 (十四)

文章目录 Day9 数据结构学习笔记&#xff08;2025.04.01&#xff09;一、C基础快速回顾二、STL&#xff08;标准模板库&#xff09;三、常见容器及其对应的数据结构四、容器操作演示1. 基本容器使用2. 异构类型容器 五、迭代器详解特点示例用户自定义结构体访问成员 六、算法库…...

ThreadCache

目录 一、Freelist 二、ThreadCache 三、哈希桶映射规则 一、Freelist 在之前整体框架介绍的时候&#xff0c;我们曾说过ThreadCache是一个哈希桶的结构。每一个桶都要存同一个大小的对象块&#xff08;即最小块的内存&#xff09;。 那么我们使用FreeList来…...

c++中同步和异步,阻塞和非阻塞原理以及机制

在C中&#xff0c;同步与异步、阻塞与非阻塞是并发编程中的重要概念&#xff0c;它们描述了程序在执行任务时的行为模式。理解这些概念对于设计高效、响应良好的并发程序至关重要。下面我将详细介绍这些概念的原理和机制。 1. 同步与异步 同步&#xff08;Synchronous&#x…...

Python项目打包指南:PyInstaller与SeleniumWire的兼容性挑战及解决方案

前言 前段时间做一个内网开发的需求&#xff0c;要求将selenium程序打包成.exe放在内网的win7上运行&#xff0c;在掘金搜了一圈也没有发现相关文章&#xff0c;因此将过程中踩到的坑记录分享一下。 本文涵盖了具体打包操作、不同模块和依赖项的兼容性解决方案&#xff0c;以…...

浅谈微信视频号推荐算法

这次可能会稍微有点干货&#xff0c;但保证不晦涩~ 一、算法推荐的本质&#xff1a;猜你喜欢 vs 社交绑架​ 视频号的推荐系统本质上在做两件事&#xff1a; ​预测你的兴趣​&#xff1a;通过你的浏览、点赞、评论、分享等行为&#xff0c;分析你的偏好。​满足社交需求​&…...

selenium 常用方法

selenium 库的常用方法&#xff1a; 方法说明示例代码webdriver.Chrome()初始化 Chrome 浏览器实例。driver webdriver.Chrome()driver.get(url)访问指定的 URL 地址。driver.get("https://example.com")driver.find_element(By, value)查找第一个匹配的元素。elem…...

springboot中使用async实现异步编程

目录 1.说明 2.实现原理 3.示例 4.总结 1.说明 Async 是 Spring 框架提供的一个注解&#xff0c;用于标记方法为异步执行。被标记的方法将在调用时立即返回&#xff0c;而实际的方法执行将在单独的线程中进行。 Async 注解有一个可选属性&#xff1a;指定要使用的特定线程…...

【2024年蓝桥杯Java B组】省赛真题详细解析

【2024年蓝桥杯Java B组】省赛真题 距离比赛仅剩5天&#xff0c;大多数省份可能完成3-4题即可拿到省奖&#xff0c;2025年想要拿到省奖&#xff0c;需要高效利用时间&#xff0c;重点突破关键知识点和题型。这里以【2024年蓝桥杯Java B组省赛真题】为例&#xff0c;梳理我们最后…...

SQL:DDL(数据定义语言)和DML(数据操作语言)

目录 什么是SQL&#xff1f; 1. DDL&#xff08;Data Definition Language&#xff0c;数据定义语言&#xff09; 2. DML&#xff08;Data Manipulation Language&#xff0c;数据操作语言&#xff09; DDL和DML的区别 什么是SQL&#xff1f; SQL&#xff08;Structured …...

机器学习核心概念、算法分类与应用场景全解析

文章目录 一、基础任务与算法分类1. 分类任务&#xff08;监督学习&#xff09;2. 回归任务&#xff08;监督学习&#xff09;3. 聚类任务&#xff08;无监督学习&#xff09; 二、关键流程与技术细节1. 数据预处理2. 特征工程3. 数据集划分与评估 三、进阶技术1.深度学习2.强化…...

【leetcode】—416.分割等和子集

✏️ 关于专栏&#xff1a;专栏用于记录 LeetCode 中做题与总结 文章目录 分割等和子集▐ 题目描述▐ 题目示例▐ 题目提示▐ 思路&代码方法&#xff1a;动态规划 分割等和子集 ▐ 题目描述 题目链接&#xff1a;分割等和子集 给你一个 只包含正整数 的 非空 数组 nums …...

jemeter 之mysql驱动问题

问题 java.sql.SQLException: No suitable driver found for jdbc:mysql 解决 先把jar放到lib下 检查 JMeter 的 Classpath 在 JMeter 中&#xff0c;JDBC 驱动需要手动添加到 Classpath 中。 打开 JMeter 安装目录下的 bin/jmeter.properties 文件&#xff0c;找到 user.cla…...

隐私计算的崛起:数据安全的未来守护者

在信息技术&#xff08;IT&#xff09;的滚滚浪潮中&#xff0c;一种新兴技术正以惊人速度崭露头角——隐私计算&#xff08;Privacy-Preserving Computation&#xff09;。2025 年&#xff0c;随着数据泄露事件频发、全球隐私法规日益严格&#xff0c;以及企业对数据协作需求的…...

Excel计数、求和、统计、计算类函数

目录 一、计数函数1. COUNT2. COUNTA3. COUNTBLANK4. COUNTIF5. COUNTIFS 二、求和函数1. SUM2. SUMIF3. SUMIFS4. SUMPRODUCT 三、统计函数1. AVERAGE2. AVERAGEA3. AVERAGEIF 函数4. AVERAGEIFS 函数 四、其他常用计算函数1. MAX 与 MIN2. RANK3. MOD4. ROUND5. FLOOR6. INT7…...

解决 Kubernetes 中容器 `CrashLoopBackOff` 问题的实战经验

在 Kubernetes 集群中&#xff0c;容器状态为 CrashLoopBackOff 通常意味着容器启动失败&#xff0c;并且 Kubernetes 正在不断尝试重启它。这种状态表明容器内可能存在严重错误&#xff0c;如应用异常、依赖服务不可用、配置错误等。本文将分享一次实际排障过程&#xff0c;并…...

北师大具身AI的虚拟世界扩展!UNREALZOO:为具身智能打造高逼真度的虚拟世界

作者&#xff1a;Fangwei Zhong, Kui Wu, Churan Wang, Hao Chen, Hai Ci, Zhoujun Li, Yizhou Wang 单位&#xff1a;北京师范大学&#xff0c;北京航空航天大学&#xff0c;北京大学&#xff0c;BIGAI&#xff0c;澳门城市大学&#xff0c;新加坡国立大学 论文标题&#xf…...

2025 年浙江保安员职业资格考试高效备考指南​

浙江以创新活力著称&#xff0c;保安行业也在不断革新。2025 年考试报考条件常规&#xff0c;报名主要通过浙江省保安服务监管信息系统&#xff0c;方便快捷。​ 理论考试在传统知识基础上&#xff0c;加大对智能安防技术应用的考查&#xff0c;如人脸识别系统、智能监控报警系…...

创意设计:动态彩色数学爱心

设计理念 数学之美&#xff1a;使用心形线的数学方程&#xff08;心形曲线&#xff09;生成爱心形状。视觉吸引力&#xff1a;通过 Python 的 colorama 库添加颜色渐变效果。动态感&#xff1a;加入简单的动画&#xff0c;让爱心“跳动”。技术魅力&#xff1a;结合模块化编程…...

C++动态内存管理完全指南:从基础到现代最佳实践

一、动态内存基础原理 1.1 内存分配层次结构 内存类型生命周期分配方式典型使用场景静态存储区程序整个运行期编译器分配全局变量、静态变量栈内存函数作用域自动分配/释放局部变量堆内存手动控制new/malloc分配动态数据结构 1.2 基本内存操作函数 // C风格 void* malloc(s…...