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

ahooks.js:一款强大的React Hooks库及其API使用教程(二)

    • 一、ahooks.js简介
    • 二、ahooks.js安装
    • 三、继续ahooks.js API的介绍与使用教程
      • 21. useLocalStorageState
      • 22. useSessionStorageState
      • 23. useClickAway
      • 24. usePersistFn
      • 25. useCreation
      • 26. useFullscreen
      • 27. useInViewport
      • 28. useInfiniteScroll
      • 29. usePagination
      • 30. useDynamicList
      • 31. useVirtualList
      • 32. useHistoryTravel
      • 33. useNetwork
      • 34. useSelections
      • 35. useCountDown
      • 36. useTextSelection
      • 37. useWebSocket
      • 38. useUrlState
      • 39. useCookieState
      • 40. useMap

一、ahooks.js简介

ahooks是一款由阿里巴巴开发团队设计的React Hooks库,提供了一系列实用的React Hooks,以便开发者更好地使用React的功能。ahooks的设计原则是“最小API,最大自由”,旨在提供最小的、最易于理解和使用的API,同时保留最大的使用自由度。

二、ahooks.js安装

使用npm或yarn安装ahooks:

npm install ahooks
# 或者
yarn add ahooks

三、继续ahooks.js API的介绍与使用教程

前面的API:ahooks.js:一款强大的React Hooks库及其API使用教程(一)

21. useLocalStorageState

useLocalStorageState 是一个用于管理 localStorage 中状态的 Hook。

    import { useLocalStorageState } from 'ahooks';function App() {const [value, setValue] = useLocalStorageState('user', 'default');return (<div><p>{value}</p><button onClick={() => setValue('A User')}>Set Name</button></div>);}

在上述代码中,useLocalStorageState接收两个参数。第一个参数是 localStorage 中的键名,第二个参数是默认值。这个 Hook 会返回一个数组,第一个元素是当前的值,第二个元素是一个用于设置该值的函数。

22. useSessionStorageState

useSessionStorageState是一个用于管理 sessionStorage 中状态的 Hook。

import { useSessionStorageState } from 'ahooks';function App() {const [value, setValue] = useSessionStorageState('user', 'default');return (<div><p>{value}</p><button onClick={() => setValue('A User')}>Set Name</button></div>);
}

在上述代码中,useSessionStorageState 接收两个参数。第一个参数是 sessionStorage 中的键名,第二个参数是默认值。这个 Hook 会返回一个数组,第一个元素是当前的值,第二个元素是一个用于设置该值的函数。

23. useClickAway

useClickAway 是一个用于在用户点击元素外部时触发函数的 Hook。

import { useRef } from 'react';
import { useClickAway } from 'ahooks';function App() {const ref = useRef();useClickAway(() => {console.log('User clicked away!');}, ref);return (<div ref={ref}>Click outside this area</div>);
}

在上述代码中,useClickAway 接收一个函数和一个 ref 作为参数。当用户点击 ref 指向的元素外部时,会执行传入的函数。

24. usePersistFn

usePersistFn 是一个可以返回稳定的函数引用的 Hook,即使依赖项改变,返回的函数引用也不会改变。

import { usePersistFn } from 'ahooks';function App() {const show = usePersistFn(() => {console.log('Hello World');});return (<div><button onClick={show}>Show</button></div>);
}

在上述代码中,usePersistFn 接收一个函数作为参数,返回一个稳定的函数引用。这对于避免因函数引用改变而引发的不必要的渲染非常有用。

25. useCreation

useCreation 是一个用于在组件初次渲染时创建并保持稳定的值的 Hook。

import { useCreation } from 'ahooks';function App() {const value = useCreation(() => Math.random(), []);return (<div><p>{value}</p></div>);
}

在上述代码中,useCreation 接收两个参数。第一个参数是一个工厂函数,用于创建初始值,第二个参数是一个数组,包含了所有的依赖项。这个 Hook 会在组件初次渲染时执行工厂函数,并返回创建的值。

对不起,我犯了个错误。让我们继续介绍其他的 Hook:

26. useFullscreen

`useFullscreen` 是一个用于控制元素全屏状态的 Hook。
import { useRef } from 'react';
import { useFullscreen } from 'ahooks';function App() {const ref = useRef();const { setFull, exitFull, toggleFull } = useFullscreen(ref);return (<div ref={ref}><button onClick={toggleFull}>Toggle Fullscreen</button></div>);
}

在上述代码中,useFullscreen 接收一个 ref 作为参数,并返回一个对象,该对象包含 setFullexitFulltoggleFull 这些方法,用于控制元素的全屏状态。

27. useInViewport

useInViewport 是一个用于检测元素是否在视口内的 Hook。

import { useRef } from 'react';
import { useInViewport } from 'ahooks';function App() {const ref = useRef();const inViewport = useInViewport(ref);return (<div ref={ref}>{inViewport ? 'In viewport' : 'Not in viewport'}</div>);
}

在上述代码中,useInViewport 接收一个 ref 作为参数,并返回一个布尔值,表示元素是否在视口内。

  1. useMouse

useMouse 是一个用于获取鼠标位置的 Hook。

import { useMouse } from 'ahooks';function App() {const mouse = useMouse();return (<div>Current mouse position: {mouse.x}, {mouse.y}</div>);
}

在上述代码中,useMouse 返回一个对象,该对象包含鼠标的当前 x 和 y 坐标。

非常抱歉之前的误会。让我们从序号28开始,介绍你提到的这些ahooks库中的API:

28. useInfiniteScroll

useInfiniteScroll 是一个实现无限滚动功能的 Hook。

import { useInfiniteScroll } from 'ahooks';function App() {const { list, loading, loadMore, hasMore } = useInfiniteScroll(service);return (<div>{list.map((item, index) => (<div key={index}>{item}</div>))}{loading && <div>Loading...</div>}{!loading && hasMore && <div onClick={loadMore}>Load more</div>}</div>);
}

在上述代码中,useInfiniteScroll 接受一个异步函数 service 作为参数,返回一个包含 listloadingloadMorehasMore 的对象。

29. usePagination

usePagination 是一个实现分页功能的 Hook。

import { usePagination } from 'ahooks';function App() {const { tableProps, paginationProps } = usePagination(service);return (<Table {...tableProps}><Pagination {...paginationProps} /></Table>);
}

在上述代码中,usePagination 接受一个异步函数 service 作为参数,返回一个包含 tablePropspaginationProps 的对象,这些属性可以直接传递给 TablePagination 组件。

30. useDynamicList

useDynamicList 是一个用于处理动态列表的 Hook。

import { useDynamicList } from 'ahooks';function App() {const { list, remove, push } = useDynamicList([1, 2, 3]);return (<div>{list.map((ele, index) => (<div key={index}><span>{ele}</span><button onClick={() => remove(index)}>Remove</button></div>))}<button onClick={() => push(Date.now())}>Add</button></div>);
}

在上述代码中,useDynamicList 接受一个初始列表作为参数,返回一个包含 listremovepush 的对象。

31. useVirtualList

useVirtualList 是一个用于虚拟列表渲染的 Hook。

import { useVirtualList } from 'ahooks';function App() {const { list, containerProps, wrapperProps } = useVirtualList(data, {itemHeight: 60,});return (<div {...containerProps}><div {...wrapperProps}>{list.map((ele, index) => (<div key={index} style={{ height: 60 }}>Row: {ele.data}</div>))}</div></div>);
}

在上述代码中,useVirtualList 接受一个数据列表和一个包含项目高度的对象作为参数,返回一个包含 listcontainerPropswrapperProps 的对象。

32. useHistoryTravel

useHistoryTravel 是一个用于管理历史记录的 Hook,可以实现撤销、重做等功能。

import { useHistoryTravel } from 'ahooks';function App() {const { value, setValue, back, forward, go } = useHistoryTravel();return (<div><inputvalue={value}onChange={e => setValue(e.target.value)}/><button onClick={back}>Back</button><button onClick={forward}>Forward</button><button onClick={() => go(2)}>Go to 2</button></div>);
}

在上述代码中,useHistoryTravel 返回一个包含 valuesetValuebackforwardgo 的对象。

33. useNetwork

useNetwork 是一个用于获取网络状态的 Hook。

import { useNetwork } from 'ahooks';function App() {const networkState = useNetwork();return (<div><span>Network type: {networkState.type}</span><span>Online: {String(networkState.online)}</span></div>);
}

在上述代码中,useNetwork 返回一个包含网络状态的对象,对象包括 type(网络类型)和 online(是否在线)。

34. useSelections

useSelections 是用于管理一组条目的选中状态的 Hook。

import { useSelections } from 'ahooks';function App() {const { selected, allSelected, isSelected, toggle, toggleAll, partiallySelected } = useSelections(['a', 'b', 'c'], ['a']);return (<div><div>Selected: {selected.join(', ')}</div><div>AllSelected: {String(allSelected)}</div><div>PartiallySelected: {String(partiallySelected)}</div><button onClick={() => toggle('b')}>Toggle b</button><button onClick={toggleAll}>Toggle All</button></div>);
}

在上述代码中,useSelections 接受一个所有条目的数组和一个初始选中条目的数组,返回一个包含 selectedallSelectedisSelectedtoggletoggleAllpartiallySelected 的对象。

35. useCountDown

useCountDown 是一个倒计时的 Hook。

import { useCountDown } from 'ahooks';function App() {const [targetDate, setTargetDate] = useState(Date.now() + 5000);const { days, hours, minutes, seconds, milliseconds, start, pause, resume, reset } = useCountDown(targetDate);return (<div><p>{`${days} days, ${hours} hours, ${minutes} minutes, ${seconds} seconds, ${milliseconds} milliseconds`}</p><button onClick={start}>Start</button><button onClick={pause}>Pause</button><button onClick={resume}>Resume</button><button onClick={() => reset(targetDate)}>Reset</button></div>);
}

在上述代码中,useCountDown 接受一个目标日期,返回一个包含 dayshoursminutessecondsmillisecondsstartpauseresumereset 的对象。

36. useTextSelection

useTextSelection 是一个用于获取用户选中文本信息的 Hook。

import { useTextSelection } from 'ahooks';function App() {const selectionInfo = useTextSelection();return (<div><p>Select some text from this page.</p><p>Selection: {selectionInfo.text}</p></div>);
}

在上述代码中,useTextSelection 不需要任何参数,返回一个包含选中文本信息的对象。

37. useWebSocket

useWebSocket 是一个用于 WebSocket 连接的 Hook。

import { useWebSocket } from 'ahooks';function App() {const {latestMessage,sendMessage,connect,disconnect,readyState,readyStateLabel,} = useWebSocket('wss://echo.websocket.org');return (<div><p>Latest message: {latestMessage?.data || 'None'}</p><button onClick={() => sendMessage({ msg: 'Hello' })}>Send Message</button><button onClick={connect}>Connect</button><button onClick={disconnect}>Disconnect</button><p>Ready state: {readyStateLabel}</p></div>);
}

在上述代码中,useWebSocket 接受一个 WebSocket URL,返回一个包含 latestMessagesendMessageconnectdisconnectreadyStatereadyStateLabel 的对象。

38. useUrlState

useUrlState 是一个用于管理 URL 状态的 Hook。

import { useUrlState } from 'ahooks';function App() {const [state, setState] = useUrlState({ name: 'ahooks' });return (<div><p>Name: {state.name}</p><button onClick={() => setState({ name: 'newName' })}>Set Name</button></div>);
}

在上述代码中,useUrlState 接受一个初始状态对象,返回一个类似 useState 的元组。

39. useCookieState

useCookieState 是一个用于管理 cookie 状态的 Hook。

import { useCookieState } from 'ahooks';function App() {const [value, setValue] = useCookieState('my-cookie');return (<div><p>Value: {value}</p><button onClick={() => setValue('newValue')}>Set Value</button></div>);
}

在上述代码中,useCookieState 接受一个 cookie 名称,返回一个类似 useState 的元组。

40. useMap

useMap 是一个用于管理 Map 状态的 Hook。

import { useMap } from 'ahooks';function App() {const [map, { set, setAll, remove, reset, has }] = useMap(new Map([['hello', 'world']]));return (<div><p>Value: {map.get('hello')}</p><button onClick={() => set('hello', 'newWorld')}>Set Value</button></div>);
}

在上述代码中,useMap 接受一个 Map,返回一个包含 Map 和一些操作方法的元组。

更多关于ahooks.js的API介绍,请查看专栏:ahooks.js:一款强大的React Hooks库

相关文章:

ahooks.js:一款强大的React Hooks库及其API使用教程(二)

一、ahooks.js简介二、ahooks.js安装三、继续ahooks.js API的介绍与使用教程21. useLocalStorageState22. useSessionStorageState23. useClickAway24. usePersistFn25. useCreation26. useFullscreen27. useInViewport28. useInfiniteScroll29. usePagination30. useDynamicLi…...

ARM 配置晶振频率

文章目录 前言串口乱码问题定位内核修改晶振频率uboot 修改晶振频率番外篇 前言 上篇文章《ARM DIY 硬件调试》介绍了 DIY ARM 板的基础硬件焊接&#xff0c;包括电源、SOC、SD 卡座等&#xff0c;板子已经可以跑起来了。 但是发现串口乱码&#xff0c;今天就来解决串口乱码问…...

最强自动化测试框架Playwright(37)-网络

介绍 Playwright 提供 API 来监控和修改浏览器网络流量&#xff0c;包括 HTTP 和 HTTPS。页面执行的任何请求&#xff0c;包括 XHR 和获取请求&#xff0c;都可以被跟踪、修改和处理。 模拟接口 查看我们的 API 模拟指南&#xff0c;了解有关如何 模拟 API 请求&#xff0c…...

Ant Design Pro 前端脚手架 配置混合导航

Ant Design Pro脚手架 点击查看阅读 混合导航&#xff1a; 顶部导航和侧边栏导航实现联动效果&#xff0c;点击不同的顶部导航按钮会显示对应的子菜单项。 实现点&#xff1a; 1. 路由的配置 菜单展示 我们可以在 route 中进行 menu 相关配置&#xff0c;来决定当前路由是否…...

tcl学习之路(五)(Vivado时序约束)

1.主时钟约束 主时钟通常是FPGA器件外部的板机时钟或FPGA的高速收发器输出数据的同步恢复时钟信号等。下面这句语法大家一定不会陌生。该语句用于对主时钟的名称、周期、占空比以及对应物理引脚进行约束。 create_clock -name <clock_name> -periood <period> -wa…...

Hlang-中英双语言编程语言使用手册

文章目录 介绍Hlang基本使用下载配置环境变量特性中文关键字支持中文符号混合编程中文错误提示终端多行输入基本数据类型整数浮点数列表字符串基本操作变量定义逻辑判断基本运算条件判断循环函数介绍 Hlang是一款基于Python编写的支持中英文混合编程的动态语言。其简单易上手,…...

centos 7 安装docker

系统配置&#xff1a; CentOS关闭selinux sed -i s/SELINUXenforcing/SELINUXdisabled/g /etc/selinux/config关闭防火墙(可选)或者放行相应端口 systemctl stop firewalld.service && systemctl disable firewalld.service配置内核IP 转发 net.ipv4.ip_forward1 dock…...

Spring环境搭建、SpringIOC容器基础、SpringDI基础

文章目录 Spring环境搭建、SpringIOC容器基础、SpringDI基础一、SpringIOC核心思想二、搭建Spring环境步骤三、SpringIOC容器使用步骤四、SpringIOC 总结五、SpringDI&#xff08;依赖注入&#xff09;1、基本概念2、实现方式&#xff08;1&#xff09;set 注入&#xff08;2&a…...

CentOS7.9手工配置静态网络流程

进入网卡配置文件 vim /etc/sysconfig/network-scripts/ifcfg-ens33 配置 TYPE"Ethernet" PROXY_METHOD"none" BROWSER_ONLY"no" BOOTPROTO"static" //static 配置静态网络 DEFROUTE"yes" IPV4_FAILURE_FATAL"no…...

JVM面试题-1

1、什么是JVM内存结构&#xff1f; jvm将虚拟机分为5大区域&#xff0c;程序计数器、虚拟机栈、本地方法栈、java堆、方法区&#xff1b; 程序计数器&#xff1a;线程私有的&#xff0c;是一块很小的内存空间&#xff0c;作为当前线程的行号指示器&#xff0c;用于记录当前虚拟…...

漫谈红黑树:红黑树的奇妙演化

漫谈红黑树&#xff1a;红黑树的奇妙演化 一、红黑树的提出二、红黑树性质的简单推导三、结论 博主简介 &#x1f4a1;一个热爱分享高性能服务器后台开发知识的博主&#xff0c;目标是通过理论与代码实践的结合&#xff0c;让世界上看似难以掌握的技术变得易于理解与掌握。技能…...

docker启动rabbitmq,但是页面加载不出来问题解决

首先docker启动rabbitmq docker run -d -p 5672:5672 -p 15672:15672 --name rabbitmq rabbitmq -d 后台运行 -p 映射外部端口 -- name 取名&#xff08;方便管理&#xff09; 然后发现&#xff0c;成功启动rabbitmq&#xff0c;却加载不进去 因为你下载的是rabbitmq的latest…...

Qt项目报错:Cannot run compiler ‘clang++‘. /bin/sh: 1: clang++: not found

在一台旧电脑上装了深度系统&#xff0c;装了Qt&#xff0c;导入项目&#xff0c; build提示 clang找不到&#xff1a; Project ERROR: Cannot run compiler clang. Output: /bin/sh: 1: clang: not found Maybe you forgot to setup the environment? Error while parsing …...

奇舞周刊第503期:图解串一串 webpack 的历史和核心功能

记得点击文章末尾的“ 阅读原文 ”查看哟~ 下面先一起看下本期周刊 摘要 吧~ 奇舞推荐 ■ ■ ■ 图解串一串 webpack 的历史和核心功能 提到打包工具&#xff0c;可能你会首先想到 webpack。那没有 webpack 之前&#xff0c;都是怎么打包的呢&#xff1f;webpack 都有哪些功能&…...

6.redis面试题和坑

1.哨兵模式 多少个节点多少个哨兵(如果全部哨兵检测到已经master dead,重新选举)写sentinel.conf,监控的主机 票数 sentinel monitor myredis 127.0.0.1 6379 1启动哨兵 redis-sentinel sentinel.conf关闭主机 failover sdown info replication shutdown优点 1.基于主从复制模式…...

【ES6】—使用 const 声明

一、不属于顶层对象window 使用const关键字 声明的变量&#xff0c;不会挂载到window属性上 const a 5 console.log(a) console.log(window.a) // 5 // undefined二、不允许重复声明 使用const关键字不允许重复声明相同的变量 cosnt a 5 cosnt a 6 // Uncaught SyntaxEr…...

iOS开发 - Swift Codable协议实战:快速、简单、高效地完成JSON和Model转换!

前言 Codable 是 Swift 4.0 引入的一种协议&#xff0c;它是一个组合协议&#xff0c;由 Decodable 和 Encodable 两个协议组成。它的作用是将模型对象转换为 JSON 或者是其它的数据格式&#xff0c;也可以反过来将 JSON 数据转换为模型对象。 Encodable 和 Decodable 分别定…...

RabbitMq:Topic exchange(主题交换机)的理解和使用

RabbitMq:Topic exchange(主题交换机)的理解和使用 在RabbitMq中&#xff0c;生产者的消息都是通过交换机来接收&#xff0c;然后再从交换机分发到不同的队列中去&#xff0c;在分发的过程中交换机类型会影响分发的逻辑&#xff0c;下面主要讲解一下主题交换机。 ​ 主题交换…...

汽车级36V、4A同步降压转换器MAX20404AFOD/VY、MAX20404AFOC/VY、MAX20404AFOA/VY开关稳压器

MAX20404是小型同步降压转换器&#xff0c;集成了高端和低端开关。这些IC均设计为可在3V到36V的宽输入电压范围内提供高达4A的电流。电压质量可以通过观察PGOOD信号来监测。该器件可以在99%的占空比下运行&#xff0c;非常适合汽车和工业应用。 MAX20404提供可编程输出电压或5…...

C++------利用C++实现二叉搜索树【数据结构】

文章目录 二叉搜索树概念二叉搜索树的操作查找插入删除 二叉搜索树的应用 二叉搜索树 概念 什么是二叉搜索树&#xff0c;二叉搜索树就是指左孩子永远比根小右孩子永远比根大。这个规则适用于所有的子树。 上面的就是一棵二叉搜索树&#xff0c;我们还可以发现这棵树走一个中…...

HotSpot虚拟机之内存模型与线程安全

目录 一、线程内存模型 1. 内存模型 2. 内存模型操作 二、Happens-Before原则 三、Java线程 1. 线程实现方式 2. Java线程状态 四、Java线程安全 1. 线程安全程度 2. 锁优化 五、参考资料 一、线程内存模型 1. 内存模型 内存模型主要目的是定义共享变量的访问规则&…...

TiDB 多集群告警监控-中章-融合多集群 Grafana

作者&#xff1a; longzhuquan 原文来源&#xff1a; https://tidb.net/blog/ac730b0f 背景 随着公司XC改造步伐的前进&#xff0c;越来越多的业务选择 TiDB&#xff0c;由于各个业务之间需要物理隔离&#xff0c;避免不了的 TiDB 集群数量越来越多。虽然每套 TiDB 集群均有…...

【图像分类】基于卷积神经网络和主动学习的高光谱图像分类(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…...

notepad++ verilog关键字自动补全

新建verilog.xml放在安装目录下 D:\Program Files (x86)\Notepad\autoCompletion <?xml version"1.0" encoding"Windows-1252" ?> <NotepadPlus><AutoComplete><KeyWord name"accept_on" /><KeyWord name"a…...

C语言知识

C语言知识 链接 C语言中的数组初始化是有三种形式的&#xff0c;分别是&#xff1a; (1)数据类型 数组名称[长度n] {元素1,元素2…元素n}; (2)数据类型 数组名称[] {元素1,元素2…元素n}; (3)数据类型 数组名称[长度n]; 数组名称[0] 元素1; 数组名称[1] 元素2; 数组…...

数据结构基础

将节点构建成树 数据的结构逻辑结构集合线性结构树形结构图状结构 存储结构合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如…...

深度学习中数据处理相关的技巧

文章目录 提取隐蔽特征惰性加载数据集类别分布不均衡 提取隐蔽特征 在某些任务中&#xff0c;一些类别的特征可能相对较为罕见或难以捕捉。由于这些特征在数据集中出现的频率较低&#xff0c;模型可能无法充分学习它们&#xff0c;从而导致对这些类别的辨别能力较弱。为了解决…...

wkhtmltopdf 与 .Net Core

wkhtmltopdf 是使用webkit引擎转化为pdf的开源小插件. 其有.NET CORE版本的组件,DinkToPdf,但该控件对跨平台支持有限 。 是由于各系统平台会产生不同的编译结果,故windows上使用.dll,而Linux上的动态链接库是.so 所以你需要在Linux系统上安装相关wkhtmltox软件。 我这里准备了…...

Linux Mint 21.3 计划于 2023 年圣诞节发布

Linux Mint 项目近日公布了基于 Ubuntu 的 Linux Mint 发行版下一个重要版本的一些初步细节&#xff0c;以及备受期待的基于 Debian 的 LMDE 6&#xff08;Linux Mint Debian Edition&#xff09;版本。 近日&#xff0c;Linux Mint 项目负责人克莱门特-勒菲弗&#xff08;Clem…...

腾讯云3年轻量应用服务器2核4G5M和2核2G4M详细介绍

腾讯云轻量应用服务器3年配置&#xff0c;目前可以选择三年的轻量配置为2核2G4M和2核4G5M&#xff0c;2核2G4M和2核4G5M带宽&#xff0c;当然也可以选择选一年&#xff0c;第二年xufei会比较gui&#xff0c;腾讯云百科分享腾讯云轻量应用服务器3年配置表&#xff1a; 目录 腾…...

rabbitmq中的消息确认

如何保证消息被全部消费 应用场景&#xff1a;我们不想丢失任何任务消息。如果一个工作者&#xff08;worker&#xff09;挂掉了&#xff0c;我们希望任务会重新发送给其他的工作者&#xff08;worker&#xff09;。 为了防止消息丢失&#xff0c;RabbitMQ提供了消息响应&…...

jenkins一键部署github项目

个人目前理解jenkins部署分为两步&#xff1a; 构建项目&#xff0c;如生成jar自动执行sh脚本 如果没有jenkins&#xff0c;我们可能需要将jar移动到服务器&#xff0c;然后执行java -jar跑程序&#xff0c;jenkins可以替代我们执行这些东西&#xff0c;下面从0开始&#xff0…...

岩土工程安全监测隧道中使用振弦采集仪注意要点?

岩土工程安全监测隧道中使用振弦采集仪注意要点&#xff1f; 岩土工程的安全监测是非常重要的&#xff0c;它可以帮助工程师及时发现可能存在的问题&#xff0c;并及时解决&#xff0c;保障施工进度以及施工质量&#xff0c;保障工程的安全运行。其中&#xff0c;振弦采集仪是…...

第四章nginx组件精讲

nginx配件location匹配的规则和优先级&#xff08;重点面试题&#xff09; RUI&#xff1a;统一资源标识符&#xff0c;是一种字符串标识&#xff0c;用于标识抽象的或者物理资源&#xff08;文件&#xff0c;图片&#xff0c;视频&#xff09; nginx当中&#xff1a;uri ww…...

LlamaGPT -基于Llama 2的自托管类chatgpt聊天机器人

LlamaGPT一个自托管、离线、类似 ChatGPT 的聊天机器人&#xff0c;由 Llama 2 提供支持。100% 私密&#xff0c;不会有任何数据离开你的设备。 推荐&#xff1a;用 NSDT编辑器 快速搭建可编程3D场景 1、如何安装LlamaGPT LlamaGPT可以安装在任何x86或arm64系统上。 首先确保…...

常见的跨域解决方案

常见的跨域解决方案&#xff1a; 跨域问题可以分为两种情况&#xff1a;前端跨域和后端跨域。以下是针对这两种情况的跨域解决方案&#xff1a; 前端跨域解决方案&#xff1a; JSONP&#xff1a; 适用于前端向不同域名下的服务器请求数据&#xff0c;通过添加回调函数名称来…...

分布式websocket解决方案

1、websocket问题由来 websocket基础请自行学习,本文章是解决在分布式环境下websocket通讯问题。 在单体环境下,所有web客户端都是连接到某一个微服务上,这样消息都是到达统一服务端,并且也是由一个服务端进行响应,所以不会出现问题。 但是在分布式环境下,我们很容易发现…...

奥威BI财务数据分析方案:借BI之利,成就智能财务分析

随着智能技术的发展&#xff0c;各行各业都走上借助智能技术高效运作道路&#xff0c;财务数据分析也不例外。借助BI商业智能技术能够让财务数据分析更高效、便捷、直观立体&#xff0c;也更有助于发挥财务数据分析作为企业经营管理健康晴雨表的作用。随着BI财务数据分析经验的…...

Android12之com.android.media.swcodec无法生成apex问题(一百六十三)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…...

Xcode build和version

参考 一个叫做Version&#xff0c;一个叫做Build&#xff0c;&#xff08;version是版本号&#xff0c;build是打正式包每次Archive时的都增加的值&#xff09;这两个值都可以在Xcode中选中target&#xff0c;点击“Summary”后看到。 Version在plist文件中的key是“CFBundleSh…...

前端面试:【原型链】代码世界的家族传承

嗨&#xff0c;亲爱的代码探险家&#xff01;在JavaScript的奇妙世界里&#xff0c;有一个令人惊叹的概念&#xff0c;那就是原型链。这个概念就像是代码世界的家族传承&#xff0c;允许对象之间分享属性和方法&#xff0c;让你的代码更加高效和灵活。 1. 什么是原型链&#xf…...

2D应用开发是选择WebGL 还是选择Canvas?

推荐&#xff1a;使用 NSDT场景编辑器 助你快速搭建可二次编辑的3D应用场景 在介绍WebGL和Canvas的区别和联系之前&#xff0c;需要先了解它们各自的定义和特点。 WebGL是一种基于标准HTML5的技术&#xff0c;用于在Web浏览器中实时渲染3D图形。它是由Khronos Group开发的一套…...

Android Framework 常见解决方案(20)UDP广播无效问题

1 现象描述和原理解读 该问题同时存在于android App和Framework系统中。最终效果是在Android系统中直接使用UDP广播无效&#xff0c;有意思的是有的android系统可以&#xff0c;有的Android 系统不行。然而该部分代码自己在Linux上测试时是有效的&#xff0c;代码不变&#xf…...

VINS-Mono中的边缘化与滑窗 (4)——VINS边缘化为何是局部变量边缘化?

文章目录 0.前言1.系统构建1.1.仿真模型1.2.第一次滑窗优化1.3.第二次全局优化 2.边缘化时不同的舒尔补方式2.1.边缘化时舒尔补的意义2.2.不同的边缘化方式 3.边缘化时不同的舒尔补方式实验验证3.1.全局schur的操作方式3.2.VIO或VINS中局部边缘化的方式3.3.两种方式和全局优化方…...

真·VB.NET彻底释放Interop.Excel对象

使用 Microsoft.Office.Interop.Excel 虽然有速度慢的缺点&#xff1b;但是作为自带引用&#xff0c;兼容性最好&#xff0c;而且是COM对象模型也很熟悉(Excel里直接录个宏&#xff0c;很方便把VBA代码转成VB.NET)。所以处理几百上千条的小数据时还是很方便的。 而 Microsoft.…...

记录hutool http通过代理模式proxy访问外面的链接

效果&#xff1a; 代码&#xff1a; public class TestMain {public static void main(String[] args){HttpRequest httpRequest HttpRequest.get("https://www.youtube.com").timeout(30000);httpRequest.setProxy(new Proxy(Proxy.Type.HTTP,new InetSocketAddre…...

Selenium 自动化 | 案例实战篇

Chrome DevTools 简介 Chrome DevTools 是一组直接内置在基于 Chromium 的浏览器&#xff08;如 Chrome、Opera 和 Microsoft Edge&#xff09;中的工具&#xff0c;用于帮助开发人员调试和研究网站。 借助 Chrome DevTools&#xff0c;开发人员可以更深入地访问网站&#xf…...

前端技术栈es6+promise

let入门使用、 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>let 基本使用</title><script type"text/javascript">let name "hspedu教育";//老韩解读//1. conso…...

windows vscode使用opencv

1.windows vscode使用opencv 参考&#xff1a;https://blog.csdn.net/zhaiax672/article/details/88971248 https://zhuanlan.zhihu.com/p/402378383 https://blog.csdn.net/weixin_39488566/article/details/121297536 g -g .\hello_opencv.cpp -stdc14 -I E:\C-software\…...

json文件读取数据报错 AttributeError: ‘str‘ object has no attribute ‘items‘

trans_width_table表如下&#xff1a; {frozenset({2}): {3: 250, 2.5: 100, 1.5: 25, 2: 50, 1.8: 50, 2.75: 200, 5: 350, 4: 350, 2.3: 100, 4.5: 350, 3.5: 300}, frozenset({1, 3, 4, 5}): {2.5: 75, 2.75: 100, 1.5: 25, 4: 300, 3.5: 200, 4.5: 300, 3: 100, 5: 300, 2…...