广告案例的网站/百度权重

广告案例的网站,百度权重,电子商务网站开发与设计,游戏平台管理系统文章目录 ✨ 掌握 findIndex、push 和 splice:打造微信小程序的灵活图片上传功能 🌟示例场景:小程序图片上传🌼 认识 findIndex定义语法在代码中的应用示例当前行为 🚀 认识 push定义语法在代码中的应用示例特点 ✂️ …

文章目录

  • ✨ 掌握 `findIndex`、`push` 和 `splice`:打造微信小程序的灵活图片上传功能 🌟
    • 示例场景:小程序图片上传
    • 🌼 认识 `findIndex`
      • 定义
      • 语法
      • 在代码中的应用
        • 示例
        • 当前行为
    • 🚀 认识 `push`
      • 定义
      • 语法
      • 在代码中的应用
        • 示例
        • 特点
    • ✂️ 认识 `splice`
      • 定义
      • 语法
      • 在代码中的应用
        • 示例
        • 特点
    • 🌈 三者的协作:动态管理
      • 操作流程
      • 长度变化
    • 🔧 优化:固定 4 张
      • 问题
      • 优化代码
      • 效果
      • 长度变化
    • 🌟 三者的最佳实践
        • 建议
    • 🎉 总结

✨ 掌握 findIndexpushsplice:打造微信小程序的灵活图片上传功能 🌟

在 JavaScript 中,数组操作是前端开发的核心技能。findIndexpushsplice 是三个功能强大且常用的方法,分别用于查找、追加和修改数组元素。在微信小程序开发中,这三个方法可以帮助我们实现动态的图片上传管理。今天,我们将以一个小程序的图片上传场景为例,探索它们如何协作,确保数据与 UI 无缝匹配,并提供优化方案以满足固定槽位的需求。

本文从实践出发,带你深入理解三者的应用与优化。


示例场景:小程序图片上传

我们开发一个微信小程序,用户可以上传产品照片到 productImages 数组,UI 展示最多 4 张。以下是初始代码:

Page({data: {productImages: [], // 产品照片数组},chooseImage: async function() {try {const res = await wx.chooseMedia({count: 1,mediaType: ['image'],sourceType: ['album', 'camera']});if (!res.tempFiles || res.tempFiles.length === 0) {throw new Error('未选择任何图片');}const imagePath = await uploadImage(res.tempFiles[0].tempFilePath, 'fake-strategy', 1);const imageUrl = `${path.IMAGE_BASE_URL}${imagePath}`;const productImages = [...this.data.productImages];const emptyIndex = productImages.findIndex(img => !img);if (emptyIndex !== -1) {productImages[emptyIndex] = imageUrl;} else {productImages.push(imageUrl);}this.setData({ productImages });} catch (error) {wx.showToast({ title: error.message || '上传失败', icon: 'none' });}},deleteImage: function(e) {const index = e.currentTarget.dataset.index;const productImages = this.data.productImages;productImages.splice(index, 1);this.setData({ productImages });},
});
<!-- WXML -->
<view class="image-upload-grid"><block wx:for="{{[0,1,2,3]}}" wx:key="index"><view wx:if="{{productImages[index]}}" class="image-item"><image src="{{productImages[index]}}" bindtap="previewImage" data-url="{{productImages[index]}}"/><view class="delete-btn" bindtap="deleteImage" data-index="{{index}}">×</view></view><view wx:else class="upload-btn" bindtap="chooseImage">+</view></block>
</view>

我们将以此为基础,分析 findIndexpushsplice 的作用,并探讨如何优化为固定 4 张的逻辑。


🌼 认识 findIndex

定义

findIndex 查找数组中第一个满足条件的元素的索引,若无匹配,返回 -1

语法

array.findIndex(callback(element[, index[, array]])[, thisArg])

在代码中的应用

const emptyIndex = productImages.findIndex(img => !img);
  • 检查元素是否为“空值”(如 null)。
  • 作用:定位可替换的空位。
示例
const arr = ['url1', null, 'url3'];
const index = arr.findIndex(img => !img); // 1
当前行为
  • 初始 [],上传后为有效 URL(如 ['url1']),无 nullemptyIndex 总是 -1

🚀 认识 push

定义

push 将元素追加到数组末尾,返回新长度。

语法

array.push(element1[, ...[, elementN]])

在代码中的应用

productImages.push(imageUrl);
  • 当无空位时,追加图片。
示例
const arr = ['url1'];
arr.push('url2'); // ['url1', 'url2']
特点
  • 无长度限制。

✂️ 认识 splice

定义

splice 修改数组,可删除或替换元素。

语法

array.splice(start[, deleteCount[, item1[, item2[, ...]]]])

在代码中的应用

productImages.splice(index, 1);
  • 删除图片,缩短数组。
示例
const arr = ['url1', 'url2', 'url3'];
arr.splice(1, 1); // ['url1', 'url3']
特点
  • 减少长度,不留空位。

🌈 三者的协作:动态管理

操作流程

  1. 初始[] -> 4 个“+”。
  2. 上传 4 张
    • [] -> ['url1'] -> ['url1', 'url2'] -> ['url1', 'url2', 'url3'] -> ['url1', 'url2', 'url3', 'url4']
    • 长度 4,UI 显示 4 图。
  3. 删除索引 1
    • splice(1, 1)['url1', 'url2', 'url3', 'url4'] -> ['url1', 'url3', 'url4']
    • 长度 3,UI 显示 3 图 + 1 个“+”。
  4. 上传第 5 张
    • push('url5')['url1', 'url3', 'url4', 'url5']
    • 长度 4,UI 显示 4 图。

长度变化

  • 上传增加长度,删除减少长度,最终反映净结果。

🔧 优化:固定 4 张

问题

  • 无限制:当前 push 可超 4,UI 只显示前 4 个。
  • findIndex 未生效:无 null,总是追加。

优化代码

Page({data: {productImages: [null, null, null, null], // 固定 4 个槽位},chooseImage: async function() {// ... 上传逻辑 ...const productImages = [...this.data.productImages];const emptyIndex = productImages.findIndex(img => !img);if (emptyIndex !== -1) {productImages[emptyIndex] = imageUrl;} else {wx.showToast({ title: '最多 4 张图片', icon: 'none' });return;}this.setData({ productImages });},deleteImage: function(e) {const index = e.currentTarget.dataset.index;const productImages = [...this.data.productImages];productImages[index] = null;this.setData({ productImages });},
});

效果

  1. 初始[null, null, null, null] -> 4 个“+”。
  2. 上传 4 张['url1', 'url2', 'url3', 'url4'] -> 4 图。
  3. 删除索引 1['url1', null, 'url3', 'url4'] -> 3 图 + 1 个“+”。
  4. 上传第 5 张['url1', 'url5', 'url3', 'url4'] -> 4 图。

长度变化

  • 始终为 4,删除后空位用 null 占位,上传替换空位。

🌟 三者的最佳实践

  • findIndex:定位空位,需有 null
  • push:追加元素,需限制。
  • splice:删除时可选缩短或保留空位。
建议
  • 固定槽位:用 findIndexnull
  • 动态扩展:用 pushsplice

🎉 总结

findIndexpushsplice 是数组管理的核心工具。通过优化,你可以实现固定或动态的图片上传逻辑,确保数据与 UI 一致。试试调整后的代码,看看效果吧!


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/71026.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微服务即时通信系统---(七)文件管理子服务

目录 功能设计 模块划分 业务接口/功能示意图 服务实现流程 服务代码实现 封装文件操作模块(utils.hpp) 获取唯一标识ID 文件读操作 文件写操作 编写proto文件 文件元信息 文件管理proto 单文件上传 多文件上传 单文件下载 多文件下载 RPC调用 服务端创建子…

ES的简单讲解

功能 &#xff1a; 文档存储 与 文档搜索 特点&#xff1a;比如有一个文档名 “你好” 可以用‘你‘&#xff0c;好&#xff0c;你好都可以搜索到这个文档 ES核心概念 类似于数据库中表的概念&#xff0c;在表的概念下又对数据集合进行了细分 ​ ES_Client查询接口 cpr::R…

宝塔安装向量数据库-Milvus

注&#xff1a;宝塔需要安装好docker容器组件&#xff01; 1、纯血宝塔安装 1.1 在线上镜像中&#xff0c;拉取milvus镜像&#xff0c;创建milvus容器 1.2 安装milvus管理工具ATTU&#xff1b;同样方式拉取线上镜像创建attu容器 2、自定义安装 2.1修改配置 {"registry-…

【K8S】Kubernetes 基本架构、节点类型及运行流程详解(附架构图及流程图)

Kubernetes 架构 k8s 集群 多个 master node 多个 work nodeMaster 节点&#xff08;主节点&#xff09;&#xff1a;负责集群的管理任务&#xff0c;包括调度容器、维护集群状态、监控集群、管理服务发现等。Worker 节点&#xff08;工作节点&#xff09;&#xff1a;实际运…

数据库MySQL,在终端输入后,提示不是内部命令等

【解决问题】mysql提示不是内部或外部命令&#xff0c;也不是可运行的程序 一般这种问题是因为没有在系统变量里面添加MySQL的可执行路径 以下是添加可执行路径的方法&#xff1a; 第一步&#xff1a;winR输入services.msc 然后找到MySQL&#xff0c;右击属性并复制MySQL的可执…

PhotoShop学习01

了解Photoshop 这里省略了Photoshop的软件安装&#xff0c;请自行查找资源下载。 1.打开图片 下图为启动photoshop后出现的界面&#xff0c;我们可以通过创建新文件或打开已有文件来启用photoshop的工作界面。 可以通过左边的按钮进行新文件的创建或打开已有文件。 也可以点…

GitCode 助力 python-office:开启 Python 自动化办公新生态

项目仓库&#xff1a;https://gitcode.com/CoderWanFeng1/python-office 源于需求洞察&#xff0c;打造 Python 办公神器 项目作者程序员晚枫在运营拥有 14w 粉丝的 B 站账号 “Python 自动化办公社区” 时&#xff0c;敏锐察觉到非程序员群体对 Python 学习的强烈需求。在数字…

javaweb + AI day03

一、web基础 二、分层解耦 注意&#xff1a;bean的名字默认是类名的首字母小写&#xff01;&#xff01;&#xff01; 三、Mysql count不参与null值统计 四、JDBC 五、MyBatis 数据库连接池

运行程序时出现加载配置文件时出错,对路径****的访问被拒绝

问题&#xff1a;最近给客户用c#语言编写进销存项目&#xff0c;在用vs2022自带的打包工具Microsoft visual studio installer projects 打包生成了安装文件&#xff0c;顺利安装后&#xff0c;点击桌面快捷方式后出现如下错误 经过查询相关资料发现是桌面快捷方式的权限问题&a…

基于C#的CANoe CLR Adapter开发指南

一、引言 CANoe 是一款广泛应用于汽车电子开发和测试的工具&#xff0c;它支持多种编程接口&#xff0c;方便开发者进行自定义扩展。CANoe CLR Adapter 允许我们使用 C# 语言与 CANoe 进行交互&#xff0c;充分利用 C# 的强大功能和丰富的类库。本文将详细介绍如何基于 C# 进行…

【三维分割】LangSplat: 3D Language Gaussian Splatting(CVPR 2024 highlight)

论文&#xff1a;https://arxiv.org/pdf/2312.16084 代码&#xff1a;https://github.com/minghanqin/LangSplat 文章目录 一、3D language field二、回顾 Language Fields的挑战三、使用SAM学习层次结构语义四、Language Fields 的 3DGS五、开放词汇查询&#xff08;Open-voca…

haclon固定相机位标定

什么是标定&#xff1f; 工业应用中相机拍到一个mark点的坐标为C1&#xff08;Cx,Cy&#xff09;&#xff0c;C1点对应的龙门架/机械手等执行端对应的坐标是多少&#xff1f; 标定就是解决这个问题&#xff0c;如相机拍到一个点坐标C1&#xff08;Cx,Cy&#xff09;&#xff0c…

【通俗讲解电子电路】——从零开始理解生活中的电路(二)

电路分析&#xff1a;看懂简单的“电路图” ——从“路线图”到“工具箱”&#xff0c;掌握电路的底层逻辑 1. 欧姆定律&#xff1a;电的“交通规则” 公式解析&#xff1a;V I R 电压&#xff08;V&#xff09;&#xff1a;推动电流的动力&#xff08;如电池电压&#xff…

Linux 第三次脚本作业

源码编译安装httpd 2.4&#xff0c;提供系统服务管理脚本并测试&#xff08;建议两种方法实现&#xff09; 一、第一种方法 1、把 httpd-2.4.63.tar.gz 这个安装包上传到你的试验机上 2、 安装编译工具 (俺之前已经装好了&#xff09; 3、解压httpd包 4、解压后的httpd包的文…

视频推拉流EasyDSS点播平台云端录像播放异常问题的排查与解决

EasyDSS视频直播点播平台是一个功能全面的系统&#xff0c;提供视频转码、点播、直播、视频推拉流以及H.265视频播放等一站式服务。该平台与RTMP高清摄像头配合使用&#xff0c;能够接收无人机设备的实时视频流&#xff0c;实现无人机视频推流直播和巡检等多种应用。 最近&…

SpringBoot新闻推荐系统设计与实现

随着信息时代的快速发展&#xff0c;新闻推荐系统成为用户获取个性化内容的重要工具。本文将介绍一个幽络源的基于SpringBoot开发的新闻推荐系统&#xff0c;该系统功能全面&#xff0c;操作简便&#xff0c;能够满足管理员和用户的多种需求。 管理员模块 管理员模块为系统管…

一次现网问题定位-线程池设置不当,导致流量上去后接口变慢

背景 公司大促活动流量上升&#xff0c;突然一线用户反馈发消息特别慢&#xff0c;运维已经初步通过监控发现B服务接口大量超时&#xff0c;调用链如下图。 发消息接口以前只经过A服务&#xff0c;后面为了防止客服骂人&#xff08;我们是客服系统&#xff09;&#xff0c;接…

【JavaWeb13】了解ES6的核心特性,对于提高JavaScript编程效率有哪些潜在影响?

文章目录 &#x1f30d;一. ES6 新特性❄️1. ES6 基本介绍❄️2. 基本使用2.1 let 声明变量2.2 const 声明常量/只读变量2.3 解构赋值2.4 模板字符串2.5 对象拓展运算符2.6 箭头函数 &#x1f30d;二. Promise❄️1. 基本使用❄️2. 如何解决回调地狱问题2.1回调地狱问题2.2 使…

《几何原本》命题I.2

《几何原本》命题I.2 从一个给定的点可以引一条线段等于已知的线段。 设 A A A 为给定点&#xff0c; B C BC BC 为给定线段 连接 A B AB AB&#xff0c;作等边 △ A B D \triangle ABD △ABD 以 B B B 为圆心&#xff0c; B C BC BC 为半径作小圆 延长 D B DB DB 交小圆…

java数据结构_Map和Set_9.1

1. 搜索树 1.1 概念 二叉搜索树又称二叉排序树&#xff0c;它或者是一棵空树&#xff0c;或者是具有以下性质的二叉树&#xff1a; 若它的左子树不为空&#xff0c;则左子树上所有的结点都小于根结点的值若它的右子树不为空&#xff0c;则右子树上所有的结点都大于根结点的值…