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

Vue3之状态管理Vuex

Vuex作为Vue.js的官方状态管理库,在大型或复杂的前端项目中扮演着至关重要的角色。本文将从Vuex的原理、特点、应用场景等多个方面进行深入解析,并通过代码示例展示如何在Vuex中实现特定功能。

一、Vuex原理

Vuex是一个专为Vue.js应用程序开发的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex的核心概念包括state、getters、mutations、actions和modules,这些概念共同构成了一个完整的状态管理框架。

1.1 State(状态)

State是Vuex中的单一状态树,即用一个对象就包含了全部的应用层级状态。它是不可变的,只能通过提交mutations来修改。在Vue组件中,可以通过this.$store.state来访问状态。

1.2 Getters(获取器)

Getters可以认为是store的计算属性,就像组件中的计算属性一样,getters的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。通过getters,可以方便地派生出一些状态,或对数据进行进一步的处理。

1.3 Mutations(变更)

Mutations是Vuex中唯一可以修改state的方法。每个mutation都有一个字符串的事件类型(type)和一个回调函数(handler)。这个回调函数是实际进行状态更改的地方,并且它会接受state作为第一个参数。需要注意的是,mutation必须是同步函数。

1.4 Actions(动作)

Actions类似于mutations,但它们主要用于处理异步操作。Actions可以包含任意异步操作,并在操作完成后提交mutations来修改state。通过actions,我们可以进行异步操作或复杂逻辑的提交,然后调用mutation来变更状态。

1.5 Modules(模块)

当项目比较大时,状态会集中,从而导致项目臃肿。Vuex允许将store分割成模块(module)。每个模块拥有自己的state、mutation、action、getter,甚至是嵌套子模块。这使得状态管理更加模块化和清晰。

二、Vuex特点

Vuex作为Vue.js的状态管理库,具有以下显著特点:

2.1 集中式状态管理

Vuex将应用的状态集中存储在一个单一的状态树中。这样可以方便地管理和追踪状态的变化,避免了状态分散在多个组件中导致的混乱和难以维护的问题。

2.2 组件之间共享状态

在大型应用中,多个组件可能需要共享某些状态,例如用户登录状态、购物车数量等。Vuex提供了一个中央存储库,使得多个组件可以方便地访问和修改共享状态。

2.3 状态的可追踪和可维护性

Vuex使用了响应式的状态管理,当状态发生变化时,相关的组件会自动更新。同时,Vuex提供了一些工具来追踪状态的变化,例如通过插件可以记录每个mutation的变更历史。这样可以更好地追踪和调试状态的变化。

2.4 简化组件通信

在Vue.js中,组件之间的通信可以通过props和事件来实现。但是当应用变得复杂时,组件之间的通信会变得困难和混乱。Vuex提供了一种集中式的数据流模式,使得组件之间的通信更加直观和可控。

三、Vuex应用场景

Vuex适用于多种应用场景,特别是在大型或复杂的前端项目中,其优势更加明显。以下是一些常见的应用场景:

3.1 管理大型应用的状态

在大型应用中,状态管理变得非常复杂。使用Vuex可以集中管理应用的所有状态,使得状态管理和共享变得更加简单和一致。

3.2 方便的状态共享

当多个组件需要共享状态时,使用Vuex可以方便地实现状态共享。例如,用户登录状态、购物车数量等全局状态都可以通过Vuex进行集中管理。

3.3 调试工具支持

Vuex与Vue Devtools无缝集成,提供了强大的调试工具。开发者可以使用Vue Devtools来追踪状态的变化、查看状态的历史记录等,从而更方便地进行调试和问题排查。

3.4 异步操作处理

Vuex的actions支持异步操作,可以方便地处理异步数据请求。通过actions,我们可以在异步操作完成后提交mutations来修改state,从而实现异步状态管理。

3.5 模块化管理

当项目比较大时,状态会集中,从而导致项目臃肿。Vuex允许将store分割成模块(module),每个模块拥有自己的state、mutation、action、getter等。这使得状态管理更加模块化和清晰。

四、代码示例

下面通过一个具体的代码示例来展示如何在Vuex中实现特定功能。

4.1 示例背景

假设我们正在开发一个购物车应用,该应用包含商品列表、购物车和用户个人信息等多个组件。我们需要使用Vuex来管理这些组件之间的共享状态。

4.2 创建Vuex Store

首先,我们需要在Vuex中定义一个状态树来存储所有需要共享的状态,如商品列表、购物车和用户个人信息等。然后,在Vue组件中通过this.$store.statethis.$store.getters等方式访问这些状态。

// store/index.js
import { createStore } from 'vuex'export default createStore({state: {cart: [],  // 购物车商品列表userInfo: {  // 用户个人信息name: '',email: ''}},mutations: {// 添加商品到购物车ADD_TO_CART(state, product) {const existItem = state.cart.find(item => item.id === product.id)if (existItem) {existItem.quantity += 1} else {state.cart.push({ ...product, quantity: 1 })}},// 从购物车中移除商品REMOVE_FROM_CART(state, productId) {state.cart = state.cart.filter(item => item.id !== productId)},// 更新用户信息UPDATE_USER_INFO(state, payload) {state.userInfo = { ...state.userInfo, ...payload }}},actions: {// 异步操作:从服务器获取用户信息并更新到store中fetchUserInfo({ commit }) {// 假设这里有一个异步请求获取用户信息setTimeout(() => {const userInfo = {name: 'John Doe',email: 'john.doe@example.com'}commit('UPDATE_USER_INFO', userInfo)}, 1000)}},getters: {// 获取购物车中商品的总数量cartItemCount: state => {return state.cart.reduce((total, item) => total + item.quantity, 0)},// 获取购物车中商品的总价格cartTotalPrice: state => {return state.cart.reduce((total, item) => total + item.price * item.quantity, 0)}}
})

4.3 在Vue组件中使用Vuex

接下来,我们需要在Vue组件中通过this.$store.statethis.$store.gettersthis.$store.committhis.$store.dispatch等方式访问和修改状态。

4.3.1 商品列表组件

商品列表组件用于展示商品列表,并提供将商品添加到购物车的功能。

<!-- src/components/ProductList.vue -->
<template><div><h1>商品列表</h1><ul><li v-for="product in products" :key="product.id">{{ product.name }} - ¥{{ product.price }}<button @click="addToCart(product)">添加到购物车</button></li></ul></div>
</template><script>
export default {data() {return {products: [{ id: 1, name: '商品A', price: 100 },{ id: 2, name: '商品B', price: 200 },{ id: 3, name: '商品C', price: 300 }]}},methods: {addToCart(product) {this.$store.commit('ADD_TO_CART', product)}}
}
</script>

4.3.2 购物车组件

购物车组件用于展示购物车中的商品列表,并提供移除商品的功能。

<!-- src/components/Cart.vue -->
<template><div><h1>购物车</h1><ul><li v-for="item in cartItems" :key="item.id">{{ item.name }} - ¥{{ item.price }} × {{ item.quantity }}<button @click="removeFromCart(item.id)">移除</button></li></ul><p>总数量: {{ cartItemCount }}</p><p>总价格: ¥{{ cartTotalPrice.toFixed(2) }}</p></div>
</template><script>
export default {computed: {cartItems() {return this.$store.state.cart;},cartItemCount() {return this.$store.getters.cartItemCount;},cartTotalPrice() {return this.$store.getters.cartTotalPrice;}},methods: {removeFromCart(productId) {this.$store.commit('REMOVE_FROM_CART', productId);}}
}
</script>

4.4 用户信息组件

用户信息组件用于展示和更新用户个人信息。

<!-- src/components/UserInfo.vue -->
<template><div><h1>用户信息</h1><p>姓名: {{ userInfo.name }}</p><p>邮箱: {{ userInfo.email }}</p><button @click="fetchUserInfo">更新用户信息</button></div>
</template><script>
export default {computed: {userInfo() {return this.$store.state.userInfo;}},methods: {fetchUserInfo() {this.$store.dispatch('fetchUserInfo');}}
}
</script>

4.5 将Vuex Store注入到Vue应用中

最后,我们需要在Vue应用的入口文件中将Vuex Store注入到Vue实例中,这样我们就可以在所有的Vue组件中通过this.$store来访问和操作Store了。

// src/main.js
import { createApp } from 'vue'
import App from './App.vue'
import store from './store'const app = createApp(App)
app.use(store)
app.mount('#app')

4.6 说明

通过以上步骤,我们成功地在Vuex中实现了购物车应用的状态管理。我们定义了共享的状态树,创建了用于修改状态的mutations和用于异步操作的actions,还定义了方便获取状态的getters。然后,我们在Vue组件中通过this.$store来访问和修改这些状态,实现了组件之间的数据共享和通信。这种集中式状态管理的方式使得我们的应用更加易于维护和扩展。

五、总结

Vuex作为Vue.js的官方状态管理库,为大型或复杂前端项目提供了高效的解决方案。它通过集中式存储管理应用状态,确保状态变化可预测。Vuex的核心包括state、getters、mutations、actions和modules,分别负责状态存储、状态派生、状态修改、异步操作和模块化管理。其特点在于集中式状态管理、组件间状态共享、状态可追踪维护以及简化组件通信。在购物车应用实例中,我们展示了如何在Vuex中定义状态树、创建mutations和actions、定义getters,并在Vue组件中访问和修改状态,实现了组件间的数据共享和通信。Vuex的应用极大地提升了应用的维护性和扩展性,是Vue.js开发中不可或缺的工具。

相关文章:

Vue3之状态管理Vuex

Vuex作为Vue.js的官方状态管理库&#xff0c;在大型或复杂的前端项目中扮演着至关重要的角色。本文将从Vuex的原理、特点、应用场景等多个方面进行深入解析&#xff0c;并通过代码示例展示如何在Vuex中实现特定功能。 一、Vuex原理 Vuex是一个专为Vue.js应用程序开发的状态管…...

优化 invite_codes 表的 SQL 创建语句

-- auto-generated definition create table invite_codes (id int auto_incrementprimary key,invite_code varchar(6) not null comment 邀请码&#xff0c;6位整数&#xff0c;确保在有效期内…...

ctfhub disable_functions关卡

1.CTFHub Bypass disable_function —— LD_PRELOAD 2.CTFHub Bypass disable_function —— ShellShock 3.CTFHub Bypass disable_function —— Apache Mod CGI 4.CTFHub Bypass disable_function —— 攻击PHP-FPM 5.CTFHub Bypass disable_function —— GC UAF 6.CTFHub B…...

Pikachu 漏洞练习平台 XXE漏洞学习记录

懒得自己搭建的可以直接FOFA找别人的靶场玩 FOFA "Pikachu 漏洞练习平台" 开始 随便输入个包含命名实体&#xff08;内部实体&#xff09;的xml数据&#xff08;以下代码中xxe是命名实体的实体名称&#xff09;&#xff1a; <?xml version"1.0"?>…...

机器学习基础 衡量模型性能指标

目录 1 前言 ​编辑1.1 错误率(Error rate)&精度(Accuracy)&误差(Error)&#xff1a; 1.2 过拟合(overfitting): 训练误差小&#xff0c;测试误差大 1.3 欠拟合(underfitting)&#xff1a;训练误差大&#xff0c;测试误差大 1.4 MSE: 1.5 RMSE: 1.6 MAE: 1.7 R-S…...

C#—内建接口: IEnumerable与IEnumerator接口详解

IEnumerable接口 在C#中&#xff0c;IEnumerable 是一个泛型接口&#xff0c;它表示一个可以通过 IEnumerator 迭代器进行迭代枚举的集合。这个接口是非常基础且重要的&#xff0c;因为它允许开发者以一致的方式遍历任何实现了该接口的集合&#xff0c;无论是数组、列表、自定…...

java日志框架:slf4j、jul(java.util.logging)、 log4j、 logback

SLF4J--抽象接口 SLF4J (Simple Logging Facade for Java) 是一个为各种 Java 日志框架提供简单统一接口的库。它的主要目的是将应用程序代码与具体的日志实现解耦&#xff0c;使得在不修改应用程序代码的情况下&#xff0c;可以轻松地切换不同的日志框架。 jul-to-slft4j.ja…...

SpringBoot 事务

事务是一组操作的集合, 是一个不可分割的操作.会把所有的操作作为一个整体, 一起向数据库提交或者是撤销操作请求. 所以这组操作要么同时成功, 要么同时失败. 为什么需要事务? 我们在进行程序开发时, 也会有事务的需求. 比如转账操作: 第一步&#xff1a;A 账户 -100 元. …...

airflow docker 安装

mkdir -p /root/airflow cd /root/airflow && mkdir -p ./dags ./logs ./plugins ./configcd /root/airflow/ wget https://airflow.apache.org/docs/apache-airflow/2.10.4/docker-compose.yaml nano docker-compose.yamlAIRFLOW__CORE__LOAD_EXAMPLES: false #初始化…...

如何用gpt来分析链接里面的内容(比如分析论文链接)和分析包含多个文件中的一块代码

如何用gpt来分析链接里面的内容&#xff0c;方法如下 这里使用gpt4里面有一个网路的功能 点击搜索框下面这个地球的形状即可启动搜索网页模式 然后即可提出问题在搜索框里&#xff1a;发现正确识别和分析了链接里面的内容 链接如下&#xff1a;https://arxiv.org/pdf/2009.1…...

linux 常用 Linux 命令指南

常用 Linux 命令指南 以下是一些常用的 Linux 命令,分类并附带简单说明,适合日常操作和快速参考。 1. 文件与目录操作 ls: 列出当前目录下的文件和子目录ls -l # 显示详细信息 ls -a # 显示隐藏文件cd: 切换目录cd /path/to/directorypwd: 显示当前工作目录pwdmkdir: 创…...

《战神:诸神黄昏》游戏运行时提示找不到emp.dll怎么办?emp.dll丢失如何修复?

《战神&#xff1a;诸神黄昏》游戏运行时提示找不到emp.dll怎么办&#xff1f;emp.dll丢失的修复方法 在畅游《战神&#xff1a;诸神黄昏》这款史诗级游戏的过程中&#xff0c;如果突然遭遇“找不到emp.dll”的错误提示&#xff0c;无疑会打断你的冒险之旅。作为一名深耕软件开…...

PHP中替换某个包或某个类

在使用composer组件时&#xff0c;有时候需要对包进行一些自定义修改&#xff0c;有一些教程中写需要修改composer.json&#xff0c;然后发布到Packagist&#xff0c;但如果只是适应自己需求所作的小修改&#xff0c;其实并没有必要发布到Packagist&#xff0c;而这样做也是Pac…...

亚信安全春节14天双倍假期通告

亚信安全14天双倍假期来袭 “网安福利王”再次实至名归 2024年 8773小时&#xff0c;31582680秒 亚信安全一直驰骋于云网安世界 奋战在“安全 数智化”的壮阔征途上 如今&#xff0c;新春的脚步渐近 长达14天的春节长假 能让我们暂且放下忙碌的工作 去除班味&#xff0c…...

kubernetes存储架构之PV controller源码解读

​ kubernetes存储之PV controller源码解读 摘要 本文介绍kubernetes存储架构的基础&#xff0c;并重点对PV controller的源码进行了学习 引入 从一个业务场景出发&#xff0c;假如你所在的公司&#xff0c;有个物理机&#xff0c;上面部署了web服务器&#xff0c;随着业务…...

Kubernates

kubernates是一个开源的&#xff0c;用于管理云平台中多个主机上的容器化的应用&#xff0c;Kubernetes的目标是让部署容器化的应用简单并且高效&#xff08;powerful&#xff09;,Kubernetes提供了应用部署&#xff0c;规划&#xff0c;更新&#xff0c;维护的一种机制。 架构…...

1.使用 Couchbase 数仓和 Temporal(一个分布式任务调度和编排框架)实现每 5 分钟的增量任务

在使用 Couchbase 数仓和 Temporal&#xff08;一个分布式任务调度和编排框架&#xff09;实现每 5 分钟的增量任务时&#xff0c;可以按照以下步骤实现&#xff0c;同时需要注意关键点。 实现方案 1. 数据层设计&#xff08;Couchbase 增量存储与标记&#xff09; 在 Couchb…...

设计模式的主要分类是什么?请简要介绍每个分类的特点。

大家好&#xff0c;我是锋哥。今天分享关于【设计模式的主要分类是什么&#xff1f;请简要介绍每个分类的特点。】面试题。希望对大家有帮助&#xff1b; 设计模式的主要分类是什么&#xff1f;请简要介绍每个分类的特点。 1000道 互联网大厂Java工程师 精选面试题-Java资源分…...

Webpack学习笔记(5)

1.拆分开发环境和生产环境配置 很多配置在开发环境和生产环境存在不一致的情况&#xff0c;比如开发环境没有必要设置缓存&#xff0c;生产环境需要设置公共路径等等。 2.公共路径 使用publicPath配置项&#xff0c;可以通过它指定应用程序中所有资源的基础路径。 webpack.…...

Unity 6 中的新增功能

Unity 6 是 Unity 的最新版本。 一、编辑器和工作流程 Unity 6 中引入的更改 在 Linux 上实现了将文件和资源从 Unity 拖放到外部应用程序的功能。将 Asset Manager for Unity 包添加到 Package Manager > Services > Content Management 部分中。此包允许用户轻松浏览…...

【前端 Uniapp】使用Vant打造Uniapp项目(避坑版)

一、基本介绍 Uniapp 是基于 Vue.js 的开发框架&#xff0c;通过一套代码可以同时发布到多个平台的应用框架。而 Vant 是针对移动端 Vue.js 的组件库。通过这样的组合&#xff0c;我们可以快速构建出一个跨平台的移动应用。Vant 已经支持多种小程序和 H5 平台&#xff0c;也对…...

JVM 详解

一. JVM 内存区域的划分 1. 程序计数器 程序计数器是JVM中一块比较小的空间, 它保存下一条要执行的指令的地址. [注]: 与CPU的程序计数器不同, 这里的下一条指令不是二进制的机器语言, 而是Java字节码. 2. 栈 保存方法中的局部变量, 方法的形参, 方法之间的调用关系. 栈又…...

代码加入SFTP JAVA ---(小白篇3)

在 Java 中&#xff0c;您可以使用 JSch&#xff08;Java Secure Channel&#xff09;库 来连接和操作 SFTP 服务器。以下是一个完整的示例代码&#xff0c;展示如何使用 Java 接入 SFTP 服务器并上传文件。 1.服务器上加入SFTP------(小白篇 1) 2.加入SFTP 用户------(小白篇…...

机器人C++开源库The Robotics Library (RL)使用手册(一)

强大的、完整的C机器人开源库 1、是否可以免费商用&#xff1f;2、支持什么平台&#xff1f;3、下载地址4、开始&#xff01; 1、是否可以免费商用&#xff1f; Robotics Library&#xff08;RL&#xff09;是一个独立的C库&#xff0c;用于机器人运动学、运动规划和控制。它涵…...

Linux高级--2.6 网络面试问题

tcp 与 udp的区别 1.tcp 是基于连接的 UDP是基于数据包 2.处理并发的方式不通 a.tcp用epoll进行监听的 b. udp是模拟tcp的连接过程&#xff0c;服务端开放一个IP端口&#xff0c;收到连接后&#xff0c;服务端用另一个IP和端口发包给客户端。 3.tcp根据协议MTU黏包及…...

HTML 画布:创意与技术的融合

HTML 画布:创意与技术的融合 HTML 画布(<canvas>)元素是现代网页设计中的一个强大工具,它为开发者提供了一个空白画布,可以在上面通过JavaScript绘制图形、图像和动画。这种技术不仅为网页增添了视觉吸引力,还极大地丰富了用户的交互体验。本文将深入探讨HTML画布…...

python EEGPT报错:Cannot cast ufunc ‘clip‘ output from dtype(‘float64‘)

今天在运行EEGPT的时候遇见了下面的问题&#xff0c;首先是nme报错&#xff0c;然后引起了numpy的报错&#xff1a; numpy.core._exceptions._UFuncOutputCastingError: Cannot cast ufunc clip output from dtype(float64)在网上找了好久的教程&#xff0c;但是没有找到。猜测…...

揭秘区块链隐私黑科技:零知识证明如何改变未来

文章目录 1. 引言&#xff1a;什么是零知识证明&#xff1f;2. 零知识证明的核心概念与三大属性2.1 完备性&#xff08;Completeness&#xff09;2.2 可靠性&#xff08;Soundness&#xff09;2.3 零知识性&#xff08;Zero-Knowledge&#xff09; 3. 零知识证明的工作原理4. 零…...

mysql之MHA

MHA 1.概述 MHA&#xff08;Master High Availability&#xff09;是一种用于MySQL数据库的高可用性解决方案&#xff0c;旨在实现自动故障切换和最小化数据丢失。它由MHA Manager和MHA Node组成&#xff0c;适用于一主多从的架构。 是建立在主从复制基础之上的故障切换的软件…...

《XML》教案 第2章 使第4章 呈现XML文档

《XML》教案 第2章 使第4章 呈现XML文档 主讲人&#xff1a; 回顾上一章: [10分钟] 2 课程知识点讲解&#xff1a; 2 通过级联样式表转换XML文档&#xff1a;[15分钟] 3 通过可扩展样式表语言转换XML文档 &#xff1a;[5分钟] 4 嵌套 for 循环 &#xff1a;[20分钟] 5 本章总结…...

Centos7离线安装Docker脚本

1、文件结构 docker_install/ ├── docker-27.4.1.tgz ├── docker-compose-linux-x86_64 └── docker_install.sh 2、下载docker安装包 wget https://download.docker.com/linux/static/stable/x86_64/docker-27.4.1.tgz 3、下载docker-compose wget https://githu…...

Linux -- 互斥的底层实现

lock 和 unlock 的汇编伪代码如下&#xff1a; lock:movb $0,%alxchgb %al,mutexif(al 寄存器的内容>0)return 0;else挂起等待&#xff1b;goto lock;unlock:movb $1,mutex唤醒等待 mutex 的线程&#xff1b;return 0; 我们来理解以下上面的代码。 首先线程 1 申请锁&…...

hhdb客户端介绍(57)

技术选型 选择 MySQL 数据库的原因 开源免费&#xff1a; MySQL 作为一款开源数据库&#xff0c;不仅免费提供给用户&#xff0c;还具备强大的功能和灵活性&#xff0c;有效降低了企业的软件许可成本。 卓越的性能&#xff1a; 在处理大规模数据集和高并发访问时&#xff0c;…...

elasticsearch 杂记

8.17快速安装与使用 系统&#xff1a;ubuntu 24 下载地址&#xff1a; https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-8.17.0-linux-x86_64.tar.gz 解压后进入目录&#xff1a;cd ./elasticsearch-8.17.0 运行&#xff1a;./bin/elasticsearch 创…...

大功率LED基础学习笔记

大功率 LED 基础学习笔记 一、 LED发光原理 &#xff08;1&#xff09;传统白炽灯发光原理 大家从小听说爱迪生发明&#xff08;改良&#xff09;电灯&#xff0c;其白炽灯工作原理为&#xff1a;灯丝通电加热到白炽状态&#xff0c;利用热辐射发出可见光的电光源。由于发光…...

EdgeX Core Service 核心服务之 Core Command 命令

EdgeX Core Service 核心服务之 Core Command 命令 一、概述 Core-command(通常称为命令和控制微服务)可以代表以下角色向设备和传感器发出命令或动作: EdgeX Foundry中的其他微服务(例如,本地边缘分析或规则引擎微服务)EdgeX Foundry与同一系统上可能存在的其他应用程序…...

Debian12使用RKE2离线部署3master2node三主两从的k8s集群详细教程

一、前提步骤 1、在各个节点执行&#xff08;所有 Server 和 Agent 节点&#xff09; apt install apparmor -y apt install curl -y2、设置各节点Host文件&#xff08;所有 Server 和 Agent 节点&#xff09; 192.168.144.175 master01 192.168.144.167 master02 192.168.1…...

【Redis】配置序列化器

1. 配置FastJSON2 FastJSON2相比与FastJSON更安全&#xff0c;更推荐使用。 import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSONReader; import com.alibaba.fastjson2.JSONWriter; import com.alibaba.fastjson2.filter.Filter;import org.springframew…...

数字IC后端设计实现十大精华主题分享

今天小编给大家分享下吾爱IC社区星球上周十大后端精华主题。 Q1:星主&#xff0c;请教个问题&#xff0c;长tree的时候发现这个scan的tree 的skew差不多400p&#xff0c;我高亮了整个tree的schematic&#xff0c;我在想是不是我在这一系列mux前边打断&#xff0c;设置ignore p…...

【Docker】部署MySQL容器

关于docker&#xff0c;Windows上使用Powershell/CMD执行指令&#xff0c;Linux系统直接使用终端执行指令。 拉取MySQL 也可以跳过拉取步骤&#xff0c;直接run&#xff0c;这样本地容器不存在的话&#xff0c;会自动拉取最新/指定的版本。 # 默认拉取最新版本 docker pull …...

go语言中的字符串详解

目录 字符串的基本特点 1.字符串的不可变性 2.其他基本特点 字符串基本操作 1. 创建字符串 2. 获取字符串长度 3. 字符串拼接 4. 遍历字符串 5. 字符串比较 字符串常用函数 1. 判断子串 2. 查找与索引 3. 字符串替换 4. 分割与连接 5. 修剪字符串 6. 大小写转换…...

数据中台从centos升级为国产操作系统后,资源增加字段时,提交报500错误

文章目录 背景一、步骤1.分析阶段2.查看nginx3.修改用户&#xff08;也可以修改所有者权限&#xff09; 背景 故障报错&#xff1a; nginx报错信息&#xff1a; 2024/12/19 15:25:31 [crit, 500299#0: *249 onen0 " /var/lib/nginx/tmp/cient body/0000000001" f…...

centos-stream9系统安装docker

如果之前安装过docker需要删除之前的。 for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo yum -y remove $pkg; done 安装yum-utils工具&#xff1a; dnf -y install yum-utils dnf-plugins-core 设置存储库&…...

计算机网络基础20道选择题,你能答对几题?

大家好&#xff0c;我是阿祥。今天给大家准备了一场关于计算机网络基础知识的小测验&#xff0c;包含20道精选的选择题。这不仅是对大家网络知识的一次检验&#xff0c;也是一次有趣的学习机会。 IPv4地址的长度是多少位&#xff1f;A. 16位 B. 32位 C. 64位 D. 128位答案&…...

分布式协同 - 分布式事务_2PC 3PC解决方案

文章目录 导图Pre2PC&#xff08;Two-Phase Commit&#xff09;协议准备阶段提交阶段情况 1&#xff1a;只要有一个事务参与者反馈未就绪&#xff08;no ready&#xff09;&#xff0c;事务协调者就会回滚事务情况 2&#xff1a;当所有事务参与者均反馈就绪&#xff08;ready&a…...

虚幻引擎结构之UWorld

Uworld -> Ulevel ->Actors -> AActor 在虚幻引擎中&#xff0c;UWorld 类扮演着至关重要的角色&#xff0c;它就像是游戏世界的总指挥。作为游戏世界的核心容器&#xff0c;UWorld 包含了构成游戏体验的众多元素&#xff0c;从游戏实体到关卡设计&#xff0c;再到物…...

牛客网刷题 ——C语言初阶——BC114 小乐乐排电梯

1.牛客网 &#xff1a;BC114 小乐乐排电梯 题目描述&#xff1a; 小乐乐学校教学楼的电梯前排了很多人&#xff0c;他的前面有n个人在等电梯。电梯每次可以乘坐12人&#xff0c;每次上下需要的时间为4分钟&#xff08;上需要2分钟&#xff0c;下需要2分钟&#xff09;。请帮助…...

43. Three.js案例-绘制100个立方体

43. Three.js案例-绘制100个立方体 实现效果 知识点 WebGLRenderer&#xff08;WebGL渲染器&#xff09; WebGLRenderer是Three.js中最常用的渲染器之一&#xff0c;用于将3D场景渲染到网页上。 构造器 WebGLRenderer(parameters : Object) 参数类型描述parametersObject…...

验证 Dijkstra 算法程序输出的奥秘

一、引言 Dijkstra 算法作为解决图中单源最短路径问题的经典算法,在网络路由、交通规划、资源分配等众多领域有着广泛应用。其通过不断选择距离源节点最近的未访问节点,逐步更新邻居节点的最短路径信息,以求得从源节点到其他所有节点的最短路径。在实际应用中,确保 Dijkst…...

springboot 3 websocket react 系统提示,选手实时数据更新监控

构建一个基于 Spring Boot 3 和 WebSocket 的实时数据监控系统&#xff0c;并在前端使用 React&#xff0c;可以实现选手实时数据的更新和展示功能。以下是该系统的核心设计和实现思路&#xff1a; 1. 系统架构 后端 (Spring Boot 3): 提供 WebSocket 服务端&#xff0c;处理…...