位置: 编程技术 - 正文
推荐整理分享JavaScript模拟数组合并concat(js模拟用户输入),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:js模拟用户操作,js模拟数组方法map的实现,js模拟接口,js模拟用户输入,javascript模拟器,js模拟接口,js模拟接口,js模拟数组方法map的实现,内容如对您有帮助,希望把文章链接给更多的朋友!
定义和用法
concat() 方法用于连接两个或多个数组。
该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。
语法
参数 描述 arrayX 必需。该参数可以是具体的值,也可以是数组对象。可以是任意多个。 返回值
返回一个新的数组。该数组是通过把所有 arrayX 参数添加到 arrayObject 中生成的。如果要进行 concat() 操作的参数是数组,那么添加的是数组中的元素,而不是数组。
我们有两个这样的数组
任务:合并成这样,请至少提供两种思路。
思路一:我们可以把第二个数组里面的值挨个添加到第一个数组的末尾。
1:数组怎么添加内容 ?[] || push || shift
2:怎么向数组最后一个索引添加值? push || [数组.length]
3:怎么挨个向数组一添加内容? for
4: for循环多少次? 你要添加多少就循环多少次,也就是arr2的长度
5: 要添加什么内容?arr2里面的值,怎么获取,arr[]
代码实现:
问题来了,原生js提供的concat方法不会修改原数组(arr1)的内容,而是返回一个新数组。
分析:既然是要返回值,那我们可以定义一个函数,然后再定义一个变量,这个变量来接收我们添加好的值,但是我们会一个问题,那就是不能在arr1上面push内容了,不然还是会修改原数组的内容。于是我觉得要把原数组复制一份,但是又有一个问题,就是对象是引用类型,简单来说虽然我们可以把数组1复制到一个变量中,但是如果我用push或者[]的形式修改里面的值,或者添加,那么我们的原数组也会被修改,(如果你不知道什么是引用类型,可以去看我博客的第一页或者在第二页)这不是我们想要的结果,但是我们必须复制一份arr1。此时你有什么解决方法?
解决数组引用问题:
我的思路是把数组1的值挨个的添加到arr3这个数组中,此时的arr3是这样的
任务:在这个新的数组arr3中添加arr2的所以值,方法和第一步一样,如果忘记了回头看看。
代码实现:
问题:虽然这个已经实现了数组的合并,但是我每次合并都要重新写一份,那样太麻烦,于是我们得想个办法把它封装成一个函数,下次我们要用的时候调用它就行。
思路二:
分析:把arr1和arr2都转换成字符串,然后将这两段字符串相加得到一个组合,然后再把这个字符串转成数组。
代码实现:
出了点小问题,这个这个数组里面的值是字符串了。
["1", "2", "3", "4", "5", "6", "7", "8", "9"]
解决思路:遍历这个数组,挨个把他们转换成数字。
课外扩展:继承版
以上所述是小编给大家介绍的JavaScript模拟数组合并concat的相关知识,希望对大家有所帮助!
JavaScript实现图片滑动切换的代码示例分享 假设我们这里有1到5五张bmp图片,那么控制图片切换显示的核心代码可以为:scriptvari=1;varimg=newArray();img[0]="1.bmp";img[1]="2.bmp";img[2]="3.bmp";img[3]="4.bmp";img[4]="
使用JavaScript脚本判断页面是否在微信中被打开 1、根据User-Agent判断//Js获取User-Agentwindow.navigator.userAgentif(window.navigator.userAgent.match(/MicroMessenger/i)=="micromessenger")//Php获取User-Agentecho$_SERVER['HTTP_USER_AGENT'];if
javascript实现label标签跳出循环操作 出场:首先我们来说说为什么需要label标签,虽然我们已经知道有break,continue跳出循环,但如果是多重循环那么它们就显的无能为力了,所以就出现了la
标签: js模拟用户输入
本文链接地址:https://www.jiuchutong.com/biancheng/378957.html 转载请保留说明!友情链接: 武汉网站建设