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

React 19新特性探索:提升性能与开发者体验

React作为最受欢迎的JavaScript库之一,不断推出新版本以应对日益复杂的应用需求。React 19作为最新的版本,引入了一系列令人兴奋的新特性和改进,旨在进一步提升应用的性能、开发效率和用户体验。

本文将深入探讨React 19的新特性,包括异步操作管理、文档元数据和样式表支持、Server Components与服务器端渲染等,帮助开发者更好地理解和利用这些新特性来构建更强大、更高效的React应用。

一、Actions与异步操作

  1. Actions

    • Actions是React 19引入的一个核心概念,它简化了状态管理、错误处理及表单逻辑。通过支持异步函数,Actions能够自动处理数据变更、加载状态、错误处理和乐观更新。
    • Actions提供了一个挂起状态,从请求开始并在最终状态更新提交时自动重置。
    • Actions支持错误处理功能,可以在请求失败时显示错误边界,并将乐观更新自动恢复到其原始值。
  2. 新钩子

    • useActionState
      • 用于处理Actions的常见情况,如数据变更、加载状态和错误处理。
      • 它接受一个异步函数作为参数,并返回处理后的状态、执行函数和加载状态。
      • 开发者可以利用这个钩子简化待定状态的管理。
    • useOptimistic
      • 在执行数据变更的异步请求时,以乐观方式展示最终状态。
      • 更新完成或出错后,自动切换回原值,优化用户界面反馈。
      • 开发者可以利用这个钩子在请求提交时向用户展示即时反馈。
    • useFormStatus
      • 方便编写设计组件获取所处表单信息,无需层层传递props。
      • 可像读取Context提供者状态一样读取表单状态。

代码示例 使用useActionState和useOptimistic管理表单状态

import React from 'react';
import Head from 'react-helmet'; // 假设使用了react-helmet库来处理<head>部分

function MyComponent() {
  return (
    <div>
      <Head>
        <title>My Page Title</title>
        <meta name="description" content="This is a description of my page" />
        <link rel="stylesheet" href="/path/to/my/stylesheet.css" />
      </Head>
      <h1>Hello, React 19!</h1>
    </div>
  );
}

export default MyComponent;

二、文档元数据和样式表支持

  1. 原生支持元数据标签

    • React 19原生支持如 <title><meta><link>等文档元数据标签。
    • 这些标签可直接在组件中声明,React会自动将它们提升至 <head>部分。
    • 这简化了SEO和元数据管理逻辑,使得开发者可以更方便地控制页面的元数据。
  2. 样式表加载管理

    • React 19提供了对样式表的内置支持,包括外部链接和内联样式。
    • 通过指定 precedence属性,React可以动态调整样式表的插入顺序,确保正确的样式覆盖。

代码示例 在组件中声明元数据标签

import React from 'react';
import Head from 'react-helmet'; // 假设使用了react-helmet库来处理<head>部分

function MyComponent() {
  return (
    <div>
      <Head>
        <title>My Page Title</title>
        <meta name="description" content="This is a description of my page" />
        <link rel="stylesheet" href="/path/to/my/stylesheet.css" />
      </Head>
      <h1>Hello, React 19!</h1>
    </div>
  );
}

export default MyComponent;

三、Server Components与服务器端渲染

  1. Server Components

    • React 19将此功能推向稳定,并引入了相关的API和最佳实践。
    • Server Components提供了一种全新的组件渲染模式,允许在服务器上提前渲染组件。
    • 这减少了客户端的渲染负担,提升了页面的加载速度和性能。
  2. 静态HTML生成

    • React 19新增了 prerenderprerenderToNodeStream两个API,用于静态网站生成。
    • 这些API支持流式环境,如Node.js Streams和Web Streams,使得服务端预渲染组件更为高效。
    • 开发者可以利用这些API在Node.js流环境中更轻松地执行预渲染操作。

代码示例 使用Server Component渲染页面

// MyComponent.server.js
export default function MyComponent() {
  // 这里可以执行一些服务器端逻辑,如数据获取等
  const data = fetchDataFromServer(); // 假设这是一个异步函数,用于从服务器获取数据

  return (
    <html>
      <body>
        <h1>Server Rendered Content</h1>
        <p>{data}</p>
      </body>
    </html>
  );
}

// 客户端组件中引用Server Component
// MyPage.jsx
import React from 'react';
import MyComponent from './MyComponent.server'; // 注意这里的引用路径和文件扩展名

function MyPage() {
  return (
    <div>
      {/* React会自动处理Server Component的渲染和数据传递 */}
      <MyComponent />
    </div>
  );
}

export default MyPage;

四、错误处理与调试

  1. 改进的错误日志系统

    • React 19减少了重复日志,并添加了更详细的调试信息。
    • 对于SSR和客户端渲染不匹配的问题,提供了差异化日志,帮助开发者更快地定位问题。
  2. 增强错误管理能力

    • React 19支持 onCaughtErroronUncaughtError回调,简化了错误回退逻辑。
    • 开发者可以利用这些回调处理捕获和未捕获的错误,提升应用的稳定性。

五、其他改进与新增功能

  1. 简写

    • React 19引入了更简洁的Context写法,现在可以直接使用 <Context>代替 <Context.Provider>
    • 这简化了Context的使用,使得开发者可以更方便地传递全局状态。
  2. 异步脚本支持

    • React 19改进了对异步脚本的支持,允许在组件树的任何位置渲染它们。
    • React会自动去重异步脚本,避免重复加载。
  3. 资源预加载

    • React 19提供了 prefetchDNSpreconnectpreloadpreinit等API,用于优化资源加载。
    • 这些API可以帮助开发者提前加载资源,提升页面的性能。
  4. 支持自定义元素

    • React 19增加了对自定义元素的全面支持,简化了属性和属性的处理。
    • 这使得开发者可以更方便地在React中使用自定义元素,如Web Components。
  5. ref的改进

    • 在React 19中,函数组件可以直接通过属性访问ref,不再需要依赖forwardRef。
    • 这简化了组件的结构,提高了代码的可读性和可维护性。
    • 同时,React 19还为ref回调增加了清理函数支持,允许在组件卸载时自动执行清理逻辑。
  6. useAPI

    • 这是一个新的钩子,用于在渲染时读取资源。
    • 它可以读取Promise并让React挂起直至其解析,也能读取Context。
    • useAPI还可以条件性调用,提供了更灵活的资源读取方式。
  7. useDeferredValue的初始值

    • React 19为useDeferredValue添加了initialValue选项。
    • 这使得开发者可以为useDeferredValue指定一个初始值,以便在需要时立即使用。
  8. 水合错误改进

    • React 19改进了客户端渲染和服务端渲染之间的水合错误报告。
    • 这使得开发者在调试过程中能够更清晰地了解问题所在,并更快地解决问题。

代码示例 使用useAPI读取资源

import React, { useAPI } from 'react';

function MyComponent() {
  // 使用useAPI读取数据
  const data = useAPI(() => fetch('/api/my-data').then(res => res.json()));

  return (
    <div>
      <h1>Data from API</h1>
      <pre>{JSON.stringify(data, null, 2)}</pre>
    </div>
  );
}

export default MyComponent;

React 19正式版引入的新特性和改进为开发者提供了更好的开发体验和更强大的工具。这些新特性不仅简化了开发流程,还提升了应用的性能和用户体验。

本文由 mdnice 多平台发布

相关文章:

React 19新特性探索:提升性能与开发者体验

React作为最受欢迎的JavaScript库之一&#xff0c;不断推出新版本以应对日益复杂的应用需求。React 19作为最新的版本&#xff0c;引入了一系列令人兴奋的新特性和改进&#xff0c;旨在进一步提升应用的性能、开发效率和用户体验。 本文将深入探讨React 19的新特性&#xff0c;…...

【数据库】SQL语句基础

【数据库】SQL语句基础 文章目录 【数据库】SQL语句基础一、SQL与数据库二、 SQL语句类型2.1 数据定义语言&#xff08;DDL&#xff09;1. 创建数据库&#xff1a;CREATE DATABASE2. 创建表&#xff1a;CREATE TABLE3. 删除表&#xff1a;DROP TABLE4. 修改表结构&#xff1a;A…...

性能】JDK和Jmeter的安装与配置

一、JDK环境配置 1. 下载JDK 官网下载地址&#xff1a;http://www.oracle.com/technetwork/java/javase/downloads/java-archive-downloads-javase7-521261.html 选择对应系统的安装包&#xff0c;下载后安装&#xff0c;安装中记录JDK安装的地址&#xff0c;之后一直点击下一…...

Hadoop、Hbase使用Snappy压缩

1. 前期准备 系统环境&#xff1a;centos7.9 配置信息&#xff1a;8C8G100G hadoop和hbase为单节点部署模式 jdk版本jdk1.8.0_361 1.1. 修改系统时间 timedatectl set-timezone <TimeZone> 1.2. 修改主机名以及主机名和IP的映射 vim /etc/hosts #将自己的主机名以及…...

初试Docker

1. 查看版本 docker --version2. 拉取镜像并查看当前存在的镜像 docker pull hello-world查看是否成功拉取到docker docker images在Docker Desktop 可视化查看 3. 删除镜像 docker rmi xxx4. 启动容器 以下命令使用 mysql镜像启动一个容器&#xff0c;参数为以命令行模…...

【Rust自学】4.5. 切片(Slice)

4.5.0. 写在正文之前 这是第四章的最后一篇文章了&#xff0c;在这里也顺便对这章做一个总结&#xff1a; 所有权、借用和切片的概念确保 Rust 程序在编译时的内存安全。 Rust语言让程序员能够以与其他系统编程语言相同的方式控制内存使用情况&#xff0c;但是当数据所有者超…...

番外:ubuntu 下的sqlite3

What Is SQLite? SQLite is a C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine. SQLite is the most used database engine in the world ps:SQLite Home Page sqlite3 的安装&#xff1a; user…...

全脐点曲面当且仅当平面或者球面的一部分

S 是全脐点曲面当且仅当 S 是平面或者球面的一部分。 S_\text{ 是全脐点曲面当且仅当 }{S_\text{ 是平面或者球面的一部分。}} S 是全脐点曲面当且仅当 ​S 是平面或者球面的一部分。​ 证&#xff1a; 充分性显然&#xff0c;下证必要性。 若 r ( u , v ) r(u,v) r(u,v)是…...

Vue之版本演进

一、引言 Vue.js&#xff0c;发音为 /vjuː/&#xff0c;是一款轻量级的用于构建用户界面的渐进式JavaScript框架。自2014年由前Google工程师尤雨溪&#xff08;Evan You&#xff09;发布以来&#xff0c;Vue.js凭借其简洁的API、灵活的组件系统以及高效的性能&#xff0c;迅速…...

四川托普信息技术职业学院教案1

四川托普信息技术职业学院教案 【计科系】 周次 第 1周&#xff0c;第1次课 备 注 章节名称 第1章 XML语言简介 引言 1.1 HTML与标记语言 1.2 XML的来源 1.3 XML的制定目标 1.4 XML概述 1.5 有了HTML了&#xff0c;为什么还要发展XML 1.5.1 HTML的缺点 1.5.2 XML的特点 1.6 X…...

《Java核心技术I》Swing中的边框

边框 BorderFactory静态方法创建边框&#xff0c;凹斜面&#xff0c;凸斜面&#xff0c;蚀刻&#xff0c;直线&#xff0c;蒙版&#xff0c;空白。 边框添加标题&#xff0c;BorderFactory.createTitledBorder 组合边框&#xff0c;BorderFactory.createCompoundBorder JCo…...

xlua中自定义lua文件加载的一种方式

此种方法来自LoxodonFramework&#xff0c;这里只做记录 定义一个LoaderBase类&#xff0c;做一个到CustomLoader的隐式类型转换 public abstract class LoaderBase {protected abstract byte[] Load(ref string fileName);/// <summary>/// 隐式类型转换&#xff0c;将…...

Suno Api V4模型无水印开发「高清音频WAV下载」 —— 「Suno Api系列」第6篇

历史文章 Suno AI API接入 - 将AI音乐接入到自己的产品中&#xff0c;支持120并发任务 Suno Api V4模型无水印开发「灵感模式」 —— 「Suno Api系列」第1篇 Suno Api V4模型无水印开发「自定义模式」 —— 「Suno Api系列」第2篇 Suno Api V4模型无水印开发「AI生成歌词」…...

EE308FZ_Sixth Assignment_Beta Sprint_Sprint Essay1

AssignmentBeta SprintCourseEE308FZ[A] — Software EngineeringClass Link2401_MU_SE_FZURequirementsSixth Assignment——Beta SprintTeam NameFZUGOObjectiveSprint Essay 1_Day1-Day2 (12.11-12.12)Other Reference1. WeChat Mini Program Design Guide 2. Javascript St…...

github如何给本机绑定 ssh密钥(MACOS)

生成 SSH 密钥 如果没有现成的密钥&#xff0c;执行以下命令来生成一个新的 SSH 密钥&#xff1a; ssh-keygen -t rsa -b 4096 -C "替换为你的邮箱" 添加 SSH 密钥到 SSH 代理 在终端中运行以下命令&#xff0c;启动 SSH 代理&#xff1a; eval "$(ssh-agen…...

使用Python实现基于AR的教育应用:打破课堂的墙壁

友友们好! 我的新专栏《Python进阶》正式启动啦!这是一个专为那些渴望提升Python技能的朋友们量身打造的专栏,无论你是已经有一定基础的开发者,还是希望深入挖掘Python潜力的爱好者,这里都将是你不可错过的宝藏。 在这个专栏中,你将会找到: ● 深入解析:每一篇文章都将…...

【数据分析】层次贝叶斯

文章目录 一、 贝叶斯推理二、 层次贝叶斯模型三、 层次贝叶斯的特点四、 数学表述五、推断方法六、应用领域 层次贝叶斯&#xff08;Hierarchical Bayesian&#xff09;方法是一种基于贝叶斯推理的统计模型&#xff0c;用于处理具有多个层次结构的数据模型。 它允许我们在同一…...

linux top命令刷新速度的原理

top命令刷新速度的原理 top命令默认会按照一定的时间间隔&#xff08;通常是3秒&#xff09;更新系统资源使用情况的显示内容。它通过读取系统的/proc文件系统中的相关文件&#xff08;如/proc/stat用于CPU信息、/proc/meminfo用于内存信息等&#xff09;来获取最新的进程和资源…...

bestphp‘s revenge

bestphp’s revenge 知识点 php session反序列化 解题 <?php highlight_file(__FILE__); $b implode; call_user_func($_GET[f], $_POST); //参数二的位置固定为 $_POST 数组&#xff0c;我们很容易便想到利用 extract 函数进行变量覆盖&#xff0c;以便配合后续利用…...

中化信息与枫清科技深化合作:共探“AI+”产业新生态

随着数字化转型的浪潮席卷全球&#xff0c;数据已成为推动创新和经济增长的关键力量。为持续深化数据要素价值挖掘与应用实践&#xff0c;推动打造行业交流平台&#xff0c;驱动产业创新共荣&#xff0c;2024 年 12 月 18 日 -19 日&#xff0c;由中国通信标准化协会主办的“20…...

Java性能测试Benchmark使用总结

如何测量Java代码的性能 在 Java 中&#xff0c;可以使用多种方法来测量一段代码的执行性能。使用 System.currentTimeMillis()是最常见的方法 long startTime System.currentTimeMillis();// 需要测量的代码块 for (int i 0; i < 1000000; i) {// 示例代码 }long endTi…...

完整微服务设计 功能实现

我们将以一个简单的电商系统为例&#xff0c;实现微服务架构&#xff0c;逐步用Java代码详细实现每个模块&#xff0c;并配合注释帮助小白理解。在这个实现中&#xff0c;我们使用以下工具和框架&#xff1a; Spring Boot&#xff1a;用于构建微服务。Spring Cloud&#xff1a…...

【Java基础面试题025】什么是Java的Integer缓存池?

回答重点 Java的Integer缓存池&#xff08;Integer Cache&#xff09;是为了提升性能和节省内存。根据实践发现大部分的数据操作都集中在值比较小的范围&#xff0c;因此缓存这些对象可以减少内存分配和垃圾回收的负担&#xff0c;提升性能 在 -128到127范围内的Integer对象会…...

道可云人工智能元宇宙每日资讯|浙江工商大学发布“人工智能时代创新型人才培养行动计划”

道可云元宇宙每日简报&#xff08;2024年12月20日&#xff09;讯&#xff0c;今日元宇宙新鲜事有&#xff1a; 浙江工商大学发布“人工智能时代创新型人才培养行动计划” 12月18日&#xff0c;浙江工商大学发布了《人工智能时代创新型人才培养行动计划》&#xff0c;提出人工…...

树莓派4B 搭建openwrt内置超多插件docker,nas等等使用教程

刷入固件 (想要固件的加我vx wyy7293) bleachwrt-plus-20241112-bcm27xx-bcm2711-rpi-4-squashfs-factory.img上电,并且把网线两头分别插在pi网口上和电脑的网口上(电脑必须断网) 等待网口灯亮,进入192.168.1.1 默认账密 root password 进入系统后更改openwrt的网关地址相关…...

excel 列名是数据表 的字段名 ,单元格的值 是数据表对应字段的值,生成sql插入语句

在 Excel 中&#xff0c;按 Alt F11 打开 VBA 编辑器。在菜单栏选择 插入 -> 模块&#xff0c;在新模块中粘贴以下代码。 VBA 代码 Sub GenerateSQLInsertStatementsToFile()Dim ws As WorksheetDim lastRow As Long, lastCol As Long, i As Long, j As LongDim sql As S…...

【Rust自学】4.3. 所有权与函数

4.3.0 写在正文之前 在学习了Rust的通用编程概念后&#xff0c;就来到了整个Rust的重中之重——所有权&#xff0c;它跟其他语言都不太一样&#xff0c;很多初学者觉得学起来很难。这个章节就旨在让初学者能够完全掌握这个特性。 本章有三小节&#xff1a; 所有权&#xff1…...

OpenShift 4 - 多云管理(2) - 配置多集群观察功能

《OpenShift / RHEL / DevSecOps 汇总目录》 本文在 OpenShift 4.17 RHACM 2.12 环境中进行验证。 文章目录 多集群观察技术架构安装多集群观察功能监控多集群的运行状态监控多集群的应用运行在被管集群监控应用运行在管理集群监控被管集群的应用运行 参考 多集群观察技术架构…...

【机器学习】机器学习的基本分类-强化学习(Reinforcement Learning, RL)

强化学习&#xff08;Reinforcement Learning, RL&#xff09;是一种基于试错的方法&#xff0c;旨在通过智能体与环境的交互&#xff0c;学习能够最大化累积奖励的策略。以下是强化学习的详细介绍。 强化学习的核心概念 智能体&#xff08;Agent&#xff09; 执行动作并与环境…...

Docker 设置代理的三种方法(2024年12月19日亲自测试)

Docker 设置代理的三种方法 在 Docker 中设置代理是非常常见的需求&#xff0c;尤其是在某些需要通过代理访问外部资源的网络环境下。本文将介绍三种配置 Docker 使用代理的常见方法&#xff1a;通过 daemon.json 配置镜像加速器、通过 daemon.json 配置 HTTP/HTTPS 代理、以及…...

Pycharm配置Python开发环境

Pycharm配置Python开发环境 在之前的文章中,安装好了Pyhton和Pycharm。 打开Pycharm,如下图 配置完成之后,如下图所示:...

【信息系统项目管理师】高分论文:论信息系统项目的进度管理(一体化智能公共数据平台)

更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 论文1、规划进度管理2、定义活动3、排列活动顺序5、制定进度计划6、控制进度论文 2022年9月,我作为项目经理参加了XX市的一体化智能公共数据平台项目的建设工作,2022年是XX市政府数字化改革的元年,全市上下…...

Chromium CDP 开发(十):Chromium 中增加自己的Domain

1. 引言 在深入了解了 Chromium CDP&#xff08;Chrome DevTools Protocol&#xff09;的开发过程之后&#xff0c;接下来我们将探讨如何创建一个自定义的 CDP Domain。通过为特定功能创建自己的 CDP Domain&#xff0c;可以避免对已有的 CDP 进行侵入式修改&#xff0c;从而更…...

《基于 Python 的网页爬虫详细教程》

一、引言 在当今信息时代&#xff0c;从互联网上获取大量有价值的数据对于许多领域的研究和分析至关重要。网页爬虫是一种自动化程序&#xff0c;可以从网页上抓取所需的数据。Python 作为一种强大的编程语言&#xff0c;拥有丰富的库和工具&#xff0c;使得网页爬虫的开发变得…...

前端知识图谱 - JavaScript基础(变量和类型)

变量和类型 1. JavaScript 规定了几种语言类型&#xff1f; JavaScript 语言的每一个值都属于某一种数据类型&#xff0c;它规定了 7 种语言类型。语言类型广泛用于变量、函数参数、表达式、函数返回值等场合&#xff0c;根据最新的语言标准&#xff0c;这 7 种语言类型如下&…...

五十个网络安全学习项目——(九)无线网络安全分析

五十个网络安全学习项目——&#xff08;九&#xff09;无线网络安全分析 这个系列灵感来源是&#xff1a;50个网络安全项目创意&#xff1a;覆盖新手至专家级&#xff0c;本人打算把这些项目都做一遍&#xff0c;做好记录&#xff0c;也算是对自己的提升。 本文将对WAPI 协议…...

10. 考勤信息

题目描述 公司用一个字符串来表示员工的出勤信息 absent:缺勤late: 迟到leaveearly: 早退present: 正常上班 现需根据员工出勤信息&#xff0c;判断本次是否能获得出勤奖&#xff0c;能获得出勤奖的条件如下: 缺勤不超过一次&#xff0c;没有连续的迟到/早退:任意连续7次考勤&a…...

预览和下载 (pc和微信小程序)

1.微信小程序 预览pdf 或者 图片等 //utils.js 文件//通过接口返回文件链接 打开文档 export default function previewFile({ downLinkUrl, tempFilePath }) {let url "https://" downLinkUrl.replace("http://", "").replace("https:…...

Redis 7.x如何安装与配置?保姆级教程

大家好&#xff0c;我是袁庭新。最新写了一套最新版的Redis 7.x企业级开发教程&#xff0c;今天先给大家介绍下Redis 7.x如何在Linux系统上安装和配置。 1 Redis下载与安装 使用非关系型数据库Redis必须先进行安装配置并开启Redis服务&#xff0c;然后使用对应客户端连接使用…...

序列化和反序列化(一)

因为通过这段时间的学习&#xff0c;发现&#xff0c;序列化和反序列化的考点和漏洞在平时遇到的还是比较多的&#xff0c;而且自己也没有特别去学习过这个知识点&#xff0c;所以在这里写一篇关于这里序列化和反序列话的博客&#xff0c;废话就停止在这里了。 在介绍具体的序列…...

1小时放弃Rust(2): 两数之和

1. 目的 陈越姥姥说&#xff0c;ACM拿奖的人有两类&#xff0c;一类是 NOIP 搞了好几年的&#xff0c;另一类是大学才开始搞 ACM 但是专注度远超常人的人。 学习 Rust 大概也是需要高度的专注度。让我试一下 ACM 的入门题目 AB 吧&#xff01; 2. 题目地址 https://leetcod…...

罗德与施瓦茨NRP33SN,一款独立、特性齐全的功率探头

罗德与施瓦茨NRP33SN功率探头概述 ROHDE & SCHWARZ NRP33S 三路二极管功率传感器 罗德与施瓦茨 NRP33S 三路二极管功率传感器是一款独立 、特性齐全的仪器。它们可以通过罗德与施瓦茨 NRP2 基 本单元、通过 USB 的笔记本电脑/PC 以及许多罗德与施瓦 茨仪器&#xff08;例如…...

【GoF23种设计模式】02_单例模式(Singleton Pattern)

文章目录 前言一、什么是单例模式&#xff1f;二、为什么要用单例模式&#xff1f;三、如何实现单例模式&#xff1f;总结 前言 提示&#xff1a;设计者模式有利于提高开发者的编程效率和代码质量&#xff1a; GoF&#xff08;Gang of Four&#xff0c;四人帮&#xff09;设计…...

springboot452当代中国获奖的知名作家信息管理系统的设计与实现(论文+源码)_kaic

摘 要 计算机网络发展到现在已经好几十年了&#xff0c;在理论上面已经有了很丰富的基础&#xff0c;并且在现实生活中也到处都在使用&#xff0c;可以说&#xff0c;经过几十年的发展&#xff0c;互联网技术已经把地域信息的隔阂给消除了&#xff0c;让整个世界都可以即时通话…...

基于Redis的网关鉴权方案与性能优化

文章目录 前言一、微服务鉴权1.1 前端权限检查1.2 后端权限检查1.3 优缺点 二、网关鉴权2.1 接口权限存储至Redis2.2 网关鉴权做匹配 总结 前言 在微服务架构中&#xff0c;如何通过网关鉴权结合Redis缓存提升权限控制的效率与性能。首先&#xff0c;文章对比了两种常见的权限…...

FutureWarning: `clean_up_tokenization_spaces` was not set.

警告内容&#xff1a; "clean_up_tokenization_spaces was not set. It will be set to True by default. This behavior will be deprecated in transformers v4.45, and will be then set to False by default. For more details check this issue: https://github.com…...

卫星综合电子软件系统

微小卫星星载综合电子系统采用星上总线网络将星载功能模块互相连接&#xff0c;实现微小卫星平台的模块集成、资源重组优化以及内部信息共享和综合利用。综合电子系统是微小卫星的核心组成部分&#xff0c;是整星的信息和控制中心。 包括遥控遥测管理系统、载荷管理系统、 热控…...

M3D: 基于多模态大模型的新型3D医学影像分析框架,将3D医学图像分析从“看图片“提升到“理解空间“的层次,支持检索、报告生成、问答、定位和分割等8类任务

M3D: 基于多模态大模型的新型3D医学影像分析框架&#xff0c;将3D医学图像分析从“看图片“提升到“理解空间“的层次&#xff0c;支持检索、报告生成、问答、定位和分割等8类任务 论文大纲理解1. 确认目标2. 分析过程&#xff08;目标-手段分析&#xff09;核心问题拆解 3. 实…...

开源数字人系统源码短视频文案提取文案改写去水印小程序

应用场景 短视频去水印&#xff1a; 个人用户&#xff1a;在社交媒体上分享短视频时&#xff0c;去除原视频中的水印&#xff0c;以保护个人隐私或避免侵权问题。企业用户&#xff1a;在广告、宣传和营销活动中&#xff0c;使用无水印的短视频以提高品牌知名度和吸引力。 文案提…...

范德蒙矩阵(Vandermonde 矩阵)简介:意义、用途及编程应用

参考&#xff1a; Introduction to Applied Linear Algebra – Vectors, Matrices, and Least Squares Stephen Boyd and Lieven Vandenberghe 书的网站: https://web.stanford.edu/~boyd/vmls/ Vandermonde 矩阵简介&#xff1a;意义、用途及编程应用 在数学和计算科学中&a…...