js 实现一个数组对应位置插入另一个数组

js 实现一个数组对应位置插入另一个数组


文章目录

  • js 实现一个数组对应位置插入另一个数组
  • 前言
  • 一、网上的教程
  • 二、实现思路
    • 1.将两个数组分成三个数组
    • 2.将需要再指定位置插入另一个数组的数据进行拆分
      • 2-1.拆解的另一份数组数据
      • 2-2.拼接数组 - concat


前言

网上看了很多改写splice的方法,可能我自己是ts环境会有一些提示错误,所以就自己重新换了个思路实现这个


提示:以下是本篇文章正文内容,下面案例可供参考

一、网上的教程

var arr1 = ['a', 'b', 'c']; 
var arr2 = ['1', '2', '3']; 
var index = 2; 
arr2.unshif(index, 0);
Array.prototype.splice.apply(arr1, arr2); 
console.log(arr1); 

网上一大堆类似这种的,但是我用这个unshif会有ts报错,所以我就只能重新自己写一个方法了。

二、实现思路

1.将两个数组分成三个数组

这样的话就可以避免循环使用splice进行填数据了

2.将需要再指定位置插入另一个数组的数据进行拆分

这里我们使用到slice
slice的具体用法我就不过多解释了,大家不懂的可以百度一下。slice它会返回一个根据开始,可选的结束索引返回一个新数组。

const arr1 = ['a', 'b', 'c']; 
const index = 1 
// 这里加1是因为slice结束索引不包含
const sliceArr = arr1.slice(0, index + 1)
console.log(sliceArr) // ['a', 'b']
// 如果不加1
const sliceArr1 = arr1.slice(0, index)
console.log(sliceArr) // ['a']

2-1.拆解的另一份数组数据

const arr1 = ['a', 'b', 'c']; 
const index = 1 
const sliceArr2 = arr1.slice(index + 1)
console.log(sliceArr) // ['c']

2-2.拼接数组 - concat

const arr1 = ['a', 'b', 'c']; 
const arr2 = [1, 2, 3]
const index = 1 const newData = arr1.slice(0, index + 1).concat(arr2, arr1.slice(index + 1))
console.log(newData) // ['a', 'b', 1, 2, 3, 'c']

这样我们就得到了拼接后的数据

如果小伙伴的环境还是js的,还是能用开头改写splice的方法,我将两个数组拆分为三个,就是想着兼容ts语法报错问题。循环使用splice也是一样能实现的,希望能给小伙伴们一些思路。

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

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

相关文章

FPGA解析串口指令控制spi flash完成连续写、读、擦除数据

前言 最近在收拾抽屉时找到一个某宝的spi flash模块,如下图所示,我就想用能不能串口来读写flash,大致过程就是,串口向fpga发送一条指令,fpga解析出指令控制flah,这个指令协议目前就是: 55 AA …

剑指offer(C++)-JZ64:求1+2+3+...+n(算法-位运算)

作者:翟天保Steven 版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处 题目描述: 求123...n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句&…

QT使用QXlsx实现对Excel的创建与文字的存取 QT基础入门【Excel的操作】

准备:搭建环境引用头文件QT中使用QtXlsx库的三种方法 QT基础入门【Excel的操作】_吻等离子的博客-CSDN博客 #include "xlsxdocument.h"const QString ExcelName="./test.xlsx"; QTXLSX_USE_NAMESPACE // 添加Xlsx命名空间 1、初始化excel表格 注意!两…

行业首家·合规典范|昂首资本携手菲律宾警察局,树立经纪商合规经营典范

Anzo Capital 昂首资本携手菲律宾达沃市警察局长阿尔贝托P卢帕兹受邀参加由 AFP-PNP Southern Mindanao Press Corps( 菲律宾武装部队(AFP)和菲律宾国家警察(PNP)南部棉兰老岛记者团)举办的新闻发布会。 本次新闻发布会在菲律宾达沃市皇家曼达亚酒店举行,Anzo Cap…

前端、后端、运维、产品等开发技术在面试之前,如何做好一份完美的自我介绍

1. 文章引言 我们都知道,不论是前端开发、后端开发、产品设计、运维开发等,在面试之前,都要做自我介绍。 虽然我们都有简历,但对方仍要求做自我介绍。 那么,你怎么做一份完美的自我介绍,给面试官一个良好的印象呢? 接下来,我便详细介绍,如何做一份完美的自我介绍。…

React创建组件的三种方式及其区别是什么?

在React中,创建组件的三种主要方式是函数式组件、类组件和使用React Hooks的函数式组件。以下是对每种方式的详细解释以及它们之间的区别: 1、函数式组件: 函数式组件是使用纯粹的JavaScript函数来定义的。它接收一个props对象作为参数&…

Leetcode每日一题:2337. 移动片段得到字符串(2023.8.21 C++)

目录 2337. 移动片段得到字符串 题目描述: 实现代码与解析: 双指针 原理思路: 2337. 移动片段得到字符串 题目描述: 给你两个字符串 start 和 target ,长度均为 n 。每个字符串 仅 由字符 L、R 和 _ 组成&#x…

网络渗透day1-Windows Server相关

-建议收藏至手机,每天顺道几分钟学一下。掌握别人掌握不了的知识,赢在起跑线。 1.Windows Server操作系统是以下哪个公司开发的? A.Microsoft B.Apple C.Google D.IBM 正确答案:A 答案解析:Windows Server操作系…

【LeetCode-中等题】189. 轮转数组

题目 题解一&#xff1a;开辟数组 取模运算寻找位置(ik)mod n 新位置 思路&#xff1a;通过&#xff0c;开辟数组 取模运算寻找新位置------位置(ik)mod n 新位置 int[] newNums new int[nums.length];for(int i 0;i<nums.length;i){newNums[(ik)%nums.length] nums[i…

微信小程序|步骤条

![在这里插入图片描述]() 步骤条是现代用户界面设计中常见的元素之一,它能够引导用户按照预定顺序完成一系列任务或步骤。在小程序中,实现步骤条可以为用户提供更好的导航和引导,使用户体验更加流畅和直观。本文将介绍如何在小程序中实现步骤条,并逐步展示实现的过程和关键…

时序预测 | Matlab实现SO-CNN-BiGRU蛇群算法优化卷积双向门控循环单元时间序列预测

时序预测 | Matlab实现SO-CNN-BiGRU蛇群算法优化卷积双向门控循环单元时间序列预测 目录 时序预测 | Matlab实现SO-CNN-BiGRU蛇群算法优化卷积双向门控循环单元时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 时序预测 | Matlab实现SO-CNN-BiGRU蛇群算法优化…

Docker容器与虚拟化技术:Docker consul 实现服务注册与发现

目录 一、理论 1.Docker consul 二、实验 1.consul部署 2. consul-template部署 三、总结 一、理论 1.Docker consul &#xff08;1&#xff09;服务注册与发现 服务注册与发现是微服务架构中不可或缺的重要组件。起初服务都是单节点的&#xff0c;不保障高可用性&…

在Ubuntu 22.04上配置静态IP地址

在Ubuntu 22.04上配置静态IP地址需要进行以下步骤&#xff1a; 打开终端&#xff1a;在桌面上&#xff0c;按下Ctrl Alt T 组合键&#xff0c;或者在应用程序搜索栏中键入“终端”。 编辑网络配置文件&#xff1a;使用文本编辑器&#xff08;例如nano或vim&#xff09;打开网…

微信小程序,封装身高体重选择器组件

wxml代码&#xff1a; // 微信小程序的插值语法不支持直接使用Math <wxs src"./ruler.wxs" module"math"></wxs> <view class"ruler-container"><scroll-view scroll-left"{{scrollLeft}}" enhanced"{{tru…

梳理系统学习R语言1-R语言实战-使用ggplot进行高阶绘图

以下为书中代码&#xff0c;会添加一些理解 library("ggplot2") ggplot(datamtcars,aes(xwt,ympg))geom_point()geom_point(pch17,color"blue",size2)geom_smooth(method"lm",color"red",linetype2)labs(title"Automobile Data&…

【SpringBoot】SpringBoot完整实现电子商务系统

一个完整的电子商务系统需要涉及到前台展示、后台管理、商品管理、订单管理、用户管理等各方面。这里提供一个简单的实现示例&#xff0c;供参考。 前端代码 前端使用Vue框架&#xff0c;以下是部分代码示例&#xff1a; 商品列表页&#xff1a; <template><div>…

vue中利用Echarts实现飞线(飞机)地图样式

实现效果 思想&#xff1a;主要是三个要素&#xff1a;1 地图样式 2散点图 3飞线 组合配置后就形成以下效果。 第一步&#xff1a;vue中引入Echarts npm install vue-echarts echarts第二步&#xff1a;导入代码 代码已经写好&#xff0c;直接引入运行就好了&#xff0c;关键…

信息安全面试题合集

0x00 前言 本篇会记录一些可能会遇到的面试题&#xff0c;持续更新 0x01 Web SQL注入 sql注入常见的闭合方式有哪些&#xff1f;Mysql5.0上下sql注入有什么区别&#xff1f;SQL注入空格被过滤&#xff0c;有什么绕过方式&#xff1f;过滤了逗号&#xff0c;有什么绕过方式&…

字节跳动 Git 的正确使用姿势与最佳实践

版本控制Git 黑马&尚硅谷 Git的前世今生 方向介绍 为什么要学习Git 1.0 Git是什么 1.1 版本控制 1.1.1 本地版本控制 1.1.2 集中版本控制 1.1.3 分布式版本控制 我们已经把三个不同的版本控制系统介绍完了&#xff0c;Git 作为分布式版本控制工具&#xff0c; 虽然目前来讲…

Django(4)-Django 管理页面

创建一个管理员账号 python manage.py createsuperuser运行项目&#xff0c;访问http://127.0.0.1:8080/admin&#xff0c;可以看到管理员界面 管理页面加上投票应用 polls/admin.py from django.contrib import admin# Register your models here. from .models import …