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

鸿蒙OSUniApp 开发的下拉刷新与上拉加载列表#三方框架 #Uniapp

使用 UniApp 开发的下拉刷新与上拉加载列表

前言

最近在做一个小程序项目时,发现列表的加载体验对用户至关重要。简单的一次性加载全部数据不仅会导致首屏加载缓慢,还可能造成内存占用过大。而分页加载虽然解决了这个问题,但如果没有良好的交互体验,用户可能会感到困惑。所以今天就结合项目实践,和大家分享如何在 UniApp 中实现既美观又高效的下拉刷新与上拉加载功能。

需求分析

一个好的列表加载机制应该满足以下几点:

  1. 首次进入页面时展示加载动画,数据加载完成后隐藏
  2. 支持下拉刷新,更新最新数据
  3. 支持上拉加载更多,分批次加载数据
  4. 在没有更多数据时,给予用户明确提示
  5. 在加载失败时,提供重试机制

技术实现

基本结构搭建

首先,我们需要搭建基本的列表结构。在 UniApp 中,可以使用内置的 <scroll-view> 组件实现滚动列表:

<template><view class="list-container"><scroll-view class="scroll-view" scroll-y :refresher-enabled="true":refresher-triggered="isRefreshing"@refresherrefresh="onRefresh"@scrolltolower="onLoadMore"><!-- 列表内容 --><view class="list-content"><view class="list-item" v-for="(item, index) in dataList" :key="index" @click="onItemClick(item)"><image class="item-image" :src="item.image" mode="aspectFill"></image><view class="item-info"><text class="item-title">{{ item.title }}</text><text class="item-desc">{{ item.description }}</text></view></view></view><!-- 底部加载状态 --><view class="loading-more"><view v-if="isLoading"><view class="loading-spinner"></view><text class="loading-text">加载中...</text></view><text v-else-if="!hasMore" class="no-more-text">— 我也是有底线的 —</text><view v-else-if="loadError" class="load-error"><text>加载失败</text><button size="mini" @click="loadMore">重试</button></view></view></scroll-view></view>
</template>

数据加载和状态管理

接下来,我们需要实现数据加载和状态管理的逻辑:

<script>
export default {data() {return {dataList: [],page: 1,pageSize: 10,hasMore: true,isLoading: false,loadError: false,isRefreshing: false,totalCount: 0}},onLoad() {this.initData();},methods: {// 初始化数据async initData() {uni.showLoading({title: '加载中...'});try {await this.fetchData(1, true);} catch (err) {console.error('初始化数据失败', err);uni.showToast({title: '数据加载失败,请重试',icon: 'none'});} finally {uni.hideLoading();}},// 下拉刷新async onRefresh() {if (this.isLoading) return;this.isRefreshing = true;try {await this.fetchData(1, true);uni.showToast({title: '刷新成功',icon: 'success',duration: 1000});} catch (err) {console.error('刷新数据失败', err);uni.showToast({title: '刷新失败,请重试',icon: 'none'});} finally {this.isRefreshing = false;}},// 上拉加载更多async onLoadMore() {if (this.isLoading || !this.hasMore || this.loadError) return;await this.loadMore();},// 加载更多数据async loadMore() {this.isLoading = true;this.loadError = false;try {const nextPage = this.page + 1;await this.fetchData(nextPage);} catch (err) {console.error('加载更多数据失败', err);this.loadError = true;} finally {this.isLoading = false;}},// 获取数据的核心函数async fetchData(page, isRefresh = false) {// 这里是实际调用后端API的地方// const res = await uni.request({//   url: `https://api.example.com/list?page=${page}&pageSize=${this.pageSize}`,//   method: 'GET'// });// 为了演示,我们使用模拟数据return new Promise((resolve) => {setTimeout(() => {// 模拟API返回的数据const mockTotalCount = 55; // 总数据条数const mockData = this.getMockData(page, this.pageSize, mockTotalCount);if (isRefresh) {this.dataList = mockData;this.page = 1;} else {this.dataList = [...this.dataList, ...mockData];this.page = page;}this.totalCount = mockTotalCount;// 判断是否还有更多数据this.hasMore = this.dataList.length < mockTotalCount;resolve(mockData);}, 1000); // 模拟网络延迟});},// 生成模拟数据(实际项目中会删除这个方法)getMockData(page, pageSize, totalCount) {const startIndex = (page - 1) * pageSize;const endIndex = Math.min(startIndex + pageSize, totalCount);const result = [];for (let i = startIndex; i < endIndex; i++) {result.push({id: i + 1,title: `标题 ${i + 1}`,description: `这是第 ${i + 1} 条数据的详细描述,展示了该条目的主要内容。`,image: `https://picsum.photos/id/${(i % 20) + 1}/200/200`});}return result;},// 列表项点击事件onItemClick(item) {uni.navigateTo({url: `/pages/detail/detail?id=${item.id}`});}}
}
</script>

样式美化

最后,我们添加一些 CSS 样式,让列表看起来更加美观:

<style lang="scss">
.list-container {height: 100vh;background-color: #f5f5f5;
}.scroll-view {height: 100%;
}.list-content {padding: 20rpx;
}.list-item {margin-bottom: 20rpx;background-color: #ffffff;border-radius: 12rpx;overflow: hidden;box-shadow: 0 2rpx 8rpx rgba(0, 0, 0, 0.1);display: flex;
}.item-image {width: 160rpx;height: 160rpx;flex-shrink: 0;
}.item-info {flex: 1;padding: 20rpx;display: flex;flex-direction: column;justify-content: space-between;
}.item-title {font-size: 30rpx;font-weight: bold;color: #333333;margin-bottom: 10rpx;
}.item-desc {font-size: 26rpx;color: #999999;display: -webkit-box;-webkit-box-orient: vertical;-webkit-line-clamp: 2;overflow: hidden;
}.loading-more {height: 100rpx;display: flex;justify-content: center;align-items: center;padding-bottom: env(safe-area-inset-bottom);
}.loading-spinner {width: 40rpx;height: 40rpx;margin-right: 10rpx;border: 4rpx solid #f3f3f3;border-top: 4rpx solid #3498db;border-radius: 50%;animation: spin 1s linear infinite;
}@keyframes spin {0% { transform: rotate(0deg); }100% { transform: rotate(360deg); }
}.loading-text, .no-more-text {font-size: 24rpx;color: #999999;
}.load-error {display: flex;flex-direction: column;align-items: center;
}.load-error text {font-size: 24rpx;color: #ff5500;margin-bottom: 10rpx;
}.load-error button {font-size: 24rpx;height: 60rpx;line-height: 60rpx;color: #ffffff;background-color: #007aff;
}
</style>

适配鸿蒙系统(HarmonyOS)

随着鸿蒙系统的普及,我们也应该考虑让应用在鸿蒙设备上有良好的表现。UniApp宣称了跨平台能力,但在适配鸿蒙时还是有一些细节需要特别注意:

1. 滚动惯性调整

我发现在鸿蒙系统上,默认的滚动惯性与iOS和Android有一些差异,可以通过以下方式优化:

<!-- 在template中为scroll-view添加条件特性 -->
<scroll-view :bounce="isHarmonyOS ? true : false":show-scrollbar="isHarmonyOS ? false : true"<!-- 其他属性 -->
>
// 在script中添加系统检测
data() {return {isHarmonyOS: false,// 其他数据...}
},
onLoad() {// 检测是否为鸿蒙系统const systemInfo = uni.getSystemInfoSync();// 目前UniApp对鸿蒙的判断还不完善,暂时通过一些特征判断if (systemInfo.platform === 'android' && systemInfo.brand === 'HUAWEI' && systemInfo.system.includes('HarmonyOS')) {this.isHarmonyOS = true;}this.initData();
}

2. 下拉刷新动画优化

鸿蒙系统的下拉动效与其他系统有所差异,我们可以微调下拉刷新的视觉效果:

<style lang="scss">
/* 为鸿蒙系统调整的样式 */
.harmony-refresher {height: 80rpx;display: flex;justify-content: center;align-items: center;
}.harmony-refresher-content {width: 40rpx;height: 40rpx;animation: harmony-rotate 1.5s ease infinite;
}@keyframes harmony-rotate {0% { transform: rotate(0deg); }50% { transform: rotate(180deg); }100% { transform: rotate(360deg); }
}
</style>

性能优化技巧

在实际项目中,我发现以下几个优化点对提升列表性能很有帮助:

1. 使用懒加载

对于图片资源,应当使用懒加载:

<image class="item-image" :src="item.image" mode="aspectFill" lazy-load></image>

2. 避免频繁触发加载

防止用户快速滑动时频繁触发加载更多:

// 在methods中添加节流函数
onLoadMore() {if (this.isLoading || !this.hasMore || this.loadError) return;if (this.loadMoreTimer) {clearTimeout(this.loadMoreTimer);}this.loadMoreTimer = setTimeout(() => {this.loadMore();}, 300);
}

3. 内存优化

对于特别长的列表,考虑在数据量过大时移除不可见部分:

// 当数据量超过一定阈值时,可以考虑移除顶部不可见的数据
watch: {dataList(newVal) {if (newVal.length > 100) {// 在用户向下滑动时,可以考虑移除顶部的数据// 但要注意保持滚动位置}}
}

实战案例

我在一个电商应用中使用了这种列表加载方式,每天有近万用户访问。在优化前,用户经常反馈商品列表加载缓慢,而且往往要等很久才能看到全部商品。

优化后,首次加载时间从原来的3.5秒降到了1.2秒,用户可以快速看到第一批商品并开始浏览,同时随着滚动可以无缝加载更多内容。退出-重进场景下,由于添加了简单的页面状态缓存,加载速度更是提升至不足0.5秒。

用户反馈明显改善,应用评分从4.1上升到了4.7,留存率提高了15%。

踩坑记录

在实现过程中,我也遇到了一些值得注意的问题:

  1. iOS下拉刷新问题:在iOS设备上,有时下拉刷新会出现卡顿。解决方法是调整refresher-threshold的值,设为80比较流畅。

  2. 安卓滚动不流畅:在某些低端安卓设备上,滚动可能不够流畅。添加enable-flex-webkit-overflow-scrolling: touch属性可以改善。

  3. 数据重复问题:有时后端分页可能导致数据重复。最好在前端做一次ID去重处理:

// 数据去重
fetchData(page, isRefresh = false) {// ... 获取数据逻辑// 假设后端返回了数据 mockDataif (!isRefresh) {// 数据去重const existingIds = this.dataList.map(item => item.id);const filteredNewData = mockData.filter(item => !existingIds.includes(item.id));this.dataList = [...this.dataList, ...filteredNewData];} else {this.dataList = mockData;}
}

总结

一个好的列表加载机制应该对用户透明,让他们感觉数据是源源不断、丝般顺滑地呈现的。通过本文介绍的下拉刷新与上拉加载方案,我们可以在UniApp中实现既美观又高效的列表体验。

在实际项目中,还需要根据业务特点和用户习惯做一些定制化调整。比如商品列表可能需要添加筛选和排序功能,消息列表可能需要添加未读标记和置顶功能等。但无论如何,本文介绍的基础架构都可以作为你的起点。

最后,随着鸿蒙系统的普及,做好跨平台适配工作也变得越来越重要。希望本文对你的UniApp开发有所帮助!

参考资料

  1. UniApp官方文档 - scroll-view组件
  2. HarmonyOS开发者文档

相关文章:

鸿蒙OSUniApp 开发的下拉刷新与上拉加载列表#三方框架 #Uniapp

使用 UniApp 开发的下拉刷新与上拉加载列表 前言 最近在做一个小程序项目时&#xff0c;发现列表的加载体验对用户至关重要。简单的一次性加载全部数据不仅会导致首屏加载缓慢&#xff0c;还可能造成内存占用过大。而分页加载虽然解决了这个问题&#xff0c;但如果没有良好的…...

VastBase的日常操作记录

---------需要命令启动数据库操作------------------- [vastbasedmz-neo4j01 ~]$ vb_ctl start [2025-05-13 09:41:54.515][10224][][vb_ctl]: vb_ctl started,数据目录是 /home/vastbase/data/vastbase [2025-05-13 09:41:54.728][10224][][vb_ctl]: 等待服务端进程启动 ... …...

企业级IP代理解决方案:负载均衡与API接口集成实践

在全球化业务扩张与数据驱动决策的背景下&#xff0c;企业级IP代理解决方案通过负载均衡技术与API接口集成&#xff0c;可有效应对高频请求、反爬机制及合规风险。以下是基于企业级场景的核心实践要点&#xff1a; 一、负载均衡与IP代理的深度协同 动态IP池的负载均衡策略 轮询…...

智能手表项目风险评估与应对计划书

&#x1f4d8; 智能手表项目风险评估与应对计划书 项目名称&#xff1a;Aurora Watch S1 版本号&#xff1a;v1.0 编制人&#xff1a;XXX&#xff08;项目经理&#xff09; 日期&#xff1a;2025年xx月xx日 一、概述 本计划书旨在识别Aurora Watch S1智能手表项目全过程中可能…...

Java基础之静态代理和动态代理

一、静态代理 定义&#xff1a; 代理类与被代理类在编译期就已确定&#xff0c;代理类需要手动编写并实现与被代理类相同的接口 1.核心角色&#xff1a; Subject&#xff08;抽象主题&#xff09;&#xff1a;定义业务方法的接口 RealSubject&#xff08;真实主题&#xff…...

观成科技:加密C2框架Vshell流量分析

一、工具介绍 Vshell是一款功能全面的红队工具&#xff0c;其设计兼顾隐蔽性与灵活性&#xff0c;尤其适合模拟网络攻击和测试防御体系。该工具支持TCP、UDP、KCP、WebSocket、DNS、DOH、DOT等多种协议。内置隧道代理功能&#xff0c;支持正向和反向连接模式&#xff0c;可以适…...

麒麟环境下Selenium的使用

本文主要介绍了在内网环境下、服务主机无域名的情况下,为了抓取内网其他系统网页数据,安装使用Selenium的方,并详细介绍了离线安装python依赖包的方法。服务主机操作系统为麒麟V10 SP3。 一. 查看可以安装的浏览器安装包 1. 更新软件包索引 首先确保软件包列表是最新的:…...

Protocol Buffers 全流程通俗讲解

Protocol Buffers 全流程通俗讲解&#xff08;从 0 到进阶&#xff09; 目录 序列化到底为什么要选 Protobuf&#xff1f;核心原理&#xff1a;一眼看懂二进制编码10 分钟跑通「写 .proto → 生成代码 → 读写数据」.proto 文件 8 条黄金法则&#xff08;小白友好版&…...

从故障到防护:抗晃电保护装置如何提升电网可靠性?

安科瑞刘鸿鹏 摘要 随着工业自动化水平的提升&#xff0c;生产设备对供电连续性和稳定性的依赖程度越来越高&#xff0c;电网中的电压暂降&#xff08;俗称“晃电”&#xff09;问题对工业生产构成了严重威胁。特别是在化工、冶金、半导体等高敏感行业&#xff0c;晃电引发的…...

Three.js知识框架

一、Three.js 基础概念 1. Three.js 简介 是什么&#xff1f; 基于 WebGL 的 3D JavaScript 库&#xff0c;用于在浏览器中渲染 3D 场景。 核心优势 简化 WebGL 的复杂 API&#xff0c;提供高层封装。 跨平台&#xff08;支持桌面和移动端&#xff09;。 适用场景 3D 可视…...

5.14本日总结

一、英语 背诵list30&#xff0c;复习list1 二、数学 完成30讲第13讲课后题&#xff0c;学习14讲部分内容 三、408 完成计网5.1,5.2题目 四、总结 在高数14讲内容学完之前写完13讲的所有题目&#xff0c;预计20号学完14讲内容&#xff0c;408的进度要加快&#xff0c;本…...

数据结构学习之链表学习:单链表

在之前顺序表的学习过程中&#xff0c;我们知道顺序表中头插和中插的复杂度是O&#xff08;N&#xff09;。那我们可不可以将其降低为O&#xff08;1&#xff09;呢&#xff1f;可不可以不增容想用就用想扔就扔而不会浪费一点空间呢&#xff1f;那就是我们今天的内容&#xff1…...

技术债务积累,如何进行有效管理

识别和评估技术债务、明确技术债务的优先级、制定系统的还债计划、持续监控与预防技术债务产生是有效管理技术债务积累的重要策略。其中尤其要注重识别和评估技术债务&#xff0c;只有准确识别技术债务的种类和严重程度&#xff0c;才能制定出高效且有针对性的解决方案&#xf…...

[20250514] 脑机接口行业调研报告(2024年最新版)

脑机接口行业调研报告&#xff08;2024年最新版&#xff09; 1. 调研报告 2. 相关企业...

【​​HTTPS基础概念与原理​】​​SSL/TLS协议演进史:从SSLv3到TLS 1.3

以下是 SSL/TLS协议演进史 的详细解析&#xff0c;从SSLv3到TLS 1.3&#xff0c;涵盖各版本的核心特点、重大漏洞及淘汰原因&#xff1a; 1. SSLv3&#xff08;Secure Sockets Layer 3.0&#xff09; • 发布时间&#xff1a;1996年&#xff08;Netscape开发&#xff09; • 核…...

JVM 与云原生的完美融合:引领技术潮流

最近佳作推荐&#xff1a; Java 大厂面试题 – 揭秘 JVM 底层原理&#xff1a;那些令人疯狂的技术真相&#xff08;New&#xff09; Java 大厂面试题 – JVM 性能优化终极指南&#xff1a;从入门到精通的技术盛宴&#xff08;New&#xff09; Java 大厂面试题 – JVM 深度剖析&…...

【进程控制二】进程替换和bash解释器

【进程控制二】进程替换 1.exec系列接口2.execl系列2.1execl接口2.2execlp接口2.3execle 3.execv系列3.1execv3.2总结 4.实现一个bash解释器4.1内建命令 通过fork创建的子进程&#xff0c;会继承父进程的代码和数据&#xff0c;因此本质上还是在执行父进程的代码 进程替换可以将…...

如何查看打开的 git bash 窗口是否是管理员权限打开

在 git bash 中输入&#xff1a; net session >nul 2>&1 && (echo Ok) || (echo Failed) 显示 OK 》是管理员权限&#xff1b; 显示 Failed 》不是管理员权限。 如何删除此步生成的垃圾文件&#xff1a; 新建一个 .txt 文件&#xff0c;输入以下代码…...

ubuntu 22.04 wifi网卡配置地址上网

通过network-manager配置 确定是否存在usb网卡的驱动 rootgpu-server:/etc/netplan# lsmod | grep rt2800usbrt2800usb 32768 0rt2x00usb 24576 1 rt2800usbrt2800lib 139264 1 rt2800usbrt2x00lib 73728 3 rt2800us…...

让 Cursor 教我写 MCP Client

文章目录 1. 写在最前面2. 动手实现一个 MCP Client2.1 How 天气查询 Client2.1.1 向 Cursor 提问的艺术2.1.2 最终成功展示2.1.3 client 的代码 3. MCP 协议核心之一总结3.1 SSE vs WebSocket 4. 碎碎念5. 参考资料 1. 写在最前面 学习了 MCP Server 的实现后&#xff0c;刚好…...

GoogleTest:GMock2 EXPECT_CALL

GoogleTest:GMock初识-CSDN博客 简单的介绍了GMock工作的方式 GMock其实是比较复杂的,先上一个例子,然后再仔细的解读: //not_ready_class.hpp #include <string>class Person { public:virtual ~Person() = default;virtual std::string name() = 0;virtual int a…...

自注意力机制(Self-Attention)前向传播手撕

题目 实现Transformer中自注意力机制的前向传播代码 思路与代码 自注意力机制&#xff08;Self-Attention&#xff09;是自然语言处理和深度学习中的一种核心机制&#xff0c;最早在 Transformer 模型中被提出。它的核心思想是&#xff1a;让序列中的每个元素都能动态关注整个…...

华硕服务器-品类介绍

目录 一、核心产品线解析 1. 机架式服务器 2. 塔式服务器 3. 高密度计算服务器 二、关键技术与模组配置 1. 主板与管理模块 2. 电源与散热 3. 存储与网络 三、应用场景与行业解决方案 1. 人工智能与高性能计算 2. 云计算与虚拟化 3. 边缘计算与工业物联网 一、核心…...

【Ansible基础】Ansible设计理念与无代理架构深度解析

目录 1 Ansible概述与核心设计理念 1.1 Ansible的核心设计哲学 1.2 Ansible与其他配置管理工具的对比 2 Ansible无代理架构详解 2.1 无代理架构工作原理 2.2 无代理架构的优势 2.3 无代理架构的局限性 3 Ansible核心组件与架构 3.1 Ansible核心组件架构 组件说明&…...

利用vba替换word中多个表格,相邻单元格的文字

目录 一、效果图1、替换前2、替换后 二、敲代码1、开发者工具→vba编辑器&#xff0c;点击插入模块2、键入以下代码3、代码编辑完成后&#xff0c;开发者工具→运行宏&#xff0c;选择对应名称&#xff0c;运行 一、效果图 标题估计没说明白&#xff0c;上图 1、替换前 2、替…...

动态多因子策略

策略其核心思想是通过多种技术指标的结合&#xff0c;动态调整交易信号&#xff0c;以实现更精准的市场进出和风险管理。 交易逻辑思路 1. 初始化与数据更新&#xff1a; - 在每个Bar的开盘时&#xff0c;更新当日的最高价、最低价和收盘价。 - 计算短期和长期的移动平均线&…...

STC32G12K128实战:串口通信

STC32G12K128芯片写一个按键通过串口1发送字符串的程序。首先&#xff0c;确认芯片的串口1配置。STC32G系列通常使用UART1&#xff0c;相关的寄存器是P_SW1来选择引脚。默认情况下&#xff0c;UART1的TX是P3.1。 接下来是设置定时器作为波特率发生器。通常用定时器2&#xff0c…...

基于javaweb的SpringBoot高校图书馆座位预约系统设计与实现(源码+文档+部署讲解)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…...

一种资源有限单片机处理cJSON数据的方法

一般单片机处理cJSON格式的数据都直接使用cJSON库&#xff0c;但对于Ram较小的单片机&#xff0c;由于资源有限&#xff0c;这并不合适&#xff0c;但我们可以根据cJSON数据的特定格式&#xff0c;使用土方法&#xff0c;直接对字符进行查找裁剪即可 //截取字符串str中字符a与…...

【2025版】Spring Boot面试题

文章目录 1. Spring, Spring MVC, SpringBoot是什么关系&#xff1f;2. 谈一谈对Spring IoC的理解3. Component 和 Bean 的区别&#xff1f;4. Autowired 和 Resource 的区别&#xff1f;5. 注入Bean的方法有哪些&#xff1f;6. 为什么Spring 官方推荐构造函数注入&#xff1f;…...

C++——类和对象(1)

文章目录 一、前言二、类和对象上2.1 类的定义2.1.1 定义格式一2.1.2 定义格式二2.1.3 注意点 2.2 访问限定符2.2.1 访问限定符的用法 2.3 类域2.4 类的实例化2.4.1 实例化的概念2.4.2 实例化具体举例2.4.3类的实例化对象大小 2.5 this指针2.5.1 this指针的概念2.5.6 this指针的…...

【行为型之观察者模式】游戏开发实战——Unity事件驱动架构的核心实现策略

文章目录 &#x1f3af; 观察者模式&#xff08;Observer Pattern&#xff09;深度解析一、模式本质与核心价值二、经典UML结构三、Unity实战代码&#xff08;玩家血量监控系统&#xff09;1. 定义观察者接口与主题基类2. 实现具体主题&#xff08;玩家血量&#xff09;3. 实现…...

Java基础语法之数组

数组 一、认识数组 1.什么是数组 数组就是一个容器&#xff0c;用来存一批同种类型的数据。 举例 20, 10, 80, 60, 90 int[] arr {20, 10, 80, 60, 90};张三, 李四, 王五 String[] names {"张三", "李四", "王五"};2.为什么要使用数组 假设…...

Vue3学习(组合式API——计算属性computed详解)

目录 一、计算属性computed。 Vue官方提供的案例。(普通写法与计算属性写法) 使用计算属性computed重构——>简化描述响应式状态的复杂逻辑。 &#xff08;1&#xff09;计算属性computed小案例。 <1>需求说明。&#xff08;筛选原数组——>得新数组&#xff09; &…...

高海拔和远距离的人员识别:面部、体型和步态的融合

大家读完就觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 摘要 我们解决了在无约束环境中进行全身人体识别的问题。这个问题出现在诸如IARPA高空和远距离生物识别与身份识别&#xff08;BRIAR&#xff09;计划等监视场景中&#xff0c;其中生物识别数据是在长…...

《P2345 [USACO04OPEN] MooFest G》

题目背景 P5094 [USACO04OPEN] MooFest G 加强版 题目描述 约翰的 n 头奶牛每年都会参加“哞哞大会”。 哞哞大会是奶牛界的盛事。集会上的活动很多&#xff0c;比如堆干草&#xff0c;跨栅栏&#xff0c;摸牛仔的屁股等等。 它们参加活动时会聚在一起&#xff0c;第 i 头…...

浅浅学:DoIP工作流程及基于DoIP的诊断/刷写工具

注&#xff1a;阅读本文需要对UDS及BootLoader有一定了解&#xff0c;基础内容不做赘述。 在汽车"新四化"浪潮的推动下&#xff0c;智能座舱、自动驾驶、车路协同等创新技术正加速重构行业格局。随着车载ECU数量突破百个量级&#xff0c;软件代码量呈指数级增长——…...

首个专业AI设计Agent发布-Lovart

Lovart是什么 Lovart 是为设计师打造的世界上首个专业设计 Agent。Lovart 能像专业设计师一样思考和执行设计任务&#xff0c;提供高水平的设计方案。基于自然语言交互&#xff0c;用户能快速调整布局、颜色和构图。Lovart 支持从创意拆解到专业交付的全链路设计&#xff0c;单…...

二叉树(中序遍历)

嘿&#xff0c;欢迎来到小巫blog&#xff01;小巫又来啦&#xff01;看到你对二叉树中序遍历这道题有点困惑&#xff0c;别担心&#xff0c;我会一步步带你搞定它&#xff01;这道题是树的基础题目&#xff0c;掌握了它&#xff0c;你对树的遍历就会有很深的理解。我相信&#…...

Ubuntu 系统默认已安装 python,此处只需添加一个超链接即可

步骤 1&#xff1a;确认 Python 3 的安装路径 查看当前 Python 3 的路径&#xff1a; which python3 输出类似&#xff1a; /usr/bin/python3 步骤 2&#xff1a;创建符号链接 使用 ln -s 创建符号链接&#xff0c;将 python 指向 python3&#xff1a; sudo ln -s /usr/b…...

AcroForm JavaScript Promise 对象应用示例: 异步加载PDF文件

这段代码演示了在Adobe Acrobat DC Pro 的 JavaScript 环境中如何使用 Promise 对象处理异步操作。具体功能是&#xff1a; 定义了一个loadFile函数&#xff0c;模拟异步加载PDF文件的操作使用Promise对象封装异步操作&#xff0c;提供成功(resolve)和失败(reject)两种状态通过…...

LeetCode 热题 100 114. 二叉树展开为链表

LeetCode 热题 100 | 114. 二叉树展开为链表 大家好&#xff0c;今天我们来解决一道经典的二叉树问题——二叉树展开为链表。这道题在 LeetCode 上被标记为中等难度&#xff0c;要求将二叉树展开为一个单链表&#xff0c;展开后的单链表应该与二叉树的先序遍历顺序相同。 问题…...

DML和DQL

1. 设置MySQL的储存引擎 上一章的附录里已经将ini设置好了&#xff0c;不用再次设置 2. DML语句 插入单数据记录 插入多数据记录 将查询结果插入新表 更新数据 删除数据 注意&#xff1a;delete删除只会删除数据&#xff0c;不会重置表的现有逻辑&#xff0c;truncate会重置表逻…...

多线程与线程互斥

我们初步学习完线程之后&#xff0c;就要来试着写一写多线程了。在写之前&#xff0c;我们需要继续来学习一个线程接口——叫做线程分离。 默认情况下&#xff0c;新创建的线程是joinable的&#xff0c;线程退出后&#xff0c;需要对其进行pthread_join操作&#xff0c;否则无法…...

BMS工具箱用来执行贝叶斯模型平均(BMA)计算模块

贝叶斯模型平均&#xff08;Bayesian Model Averaging&#xff0c;BMA&#xff09;是一种用于处理模型不确定性的统计方法&#xff0c;通过结合多个模型的预测结果来提高预测的准确性和鲁棒性。在 MATLAB 中&#xff0c;可以使用专门的工具箱&#xff08;如 BMS 工具箱&#xf…...

Java死锁排查:线上救火实战指南

想象一下&#xff0c;你正在值班&#xff0c;突然监控告警红成一片&#xff0c;用户反馈雪花般飘来&#xff1a;“系统卡死了&#xff01;用不了了&#xff01;” —— 这很可能就是Java应用遭遇了“死锁”这个大魔王。这时候&#xff0c;你就是救火队长&#xff0c;首要任务不…...

第十九次博客打卡

今天学习的内容是Java中的常见循环。 在 Java 中&#xff0c;常见的循环结构主要有以下几种&#xff1a;for 循环、while 循环、do-while 循环以及增强型 for 循环&#xff08;也称为 for-each 循环&#xff09;。 1. for 循环 for 循环是一种非常灵活的循环结构&#xff0c…...

智能体制作学习笔记1——智能体

01 智能体_哔哩哔哩_bilibili 大语言模型可以理解成一个很厉害的人。 但是要完成一些特定的工作&#xff0c;除了大语言模型&#xff0c;还需要一些工具和业务流程&#xff0c;这样才能自动化帮我们完成特定的工作&#xff0c;这个就叫做智能体。 突然发现放视频的时候出现了…...

Python常见问题

文章目录 1.python有哪些数据类型2.python中的元组和列表的区别是什么&#xff1f;3.python中的break、continue、pass代表什么意思&#xff1f;4.如何在python中生成一个随机数&#xff1f;5.Python有哪些常见的内置函数&#xff1f;6.请用自己最擅长的编程语言&#xff0c;将…...

小程序 存存上下滑动的页面

推荐阅读文档&#xff1a; Vue3组合式API之getCurrentInstance详解 - 且行且思 - 博客园Vue2中&#xff0c;可以通过this来获取当前组件实例&#xff1b; Vue3中&#xff0c;在setup中无法通过this获取组件实例&#xff0c;console.log(this)打印出来的值是undefined。 在Vue3…...