前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js数组的几个练习题

js数组的几个练习题

作者头像
用户2145235
发布2020-11-27 15:01:23
1K0
发布2020-11-27 15:01:23
举报
文章被收录于专栏:前端吧啦吧啦前端吧啦吧啦

  第一次在博客园写文章,之前一直自己做记录。现在前端工作两年了,对前端整体技术有较清晰的了解。项目用了vue,react之类的写,如今打算从基础开始,慢慢深入了解原生的JS.这几天清明节,玩的嗨皮,最后一次开始赶作业(我规定自己每天至少一个Js题,在网上随机找的。*~*)

  今天主要是重写了数组的remove(),concat()方法以及查找数组中对应元素。下面做一个简单分享:

  1.重写remove()方法,返回新数组

      function remove(arr, item) {         var arry=[]         for(var i=0;i<arr.length;i++){           if(arr[i]!=item){             arry.push(arr[i])           }         }         return arry       }

  2.移除数组 arr 中的所有值与 item 相等的元素,直接在给定的 arr 数组上进行操作,并将结果返回    

      function removeWithoutCopy(arr, item) {         for(var i=0;i<arr.length;i++){           if(arr[i]==item){             arr.splice(i,1);             i--;             arr.length--;           }         }         return arr       }

  注:这里要i--;arr.length--;是因为在给定的数组中操作的。splice每次移除都会改变arr的长度。

  3.在数组 arr 末尾添加元素 item。不要直接修改数组 arr,结果返回新的数组  

    function append(arr, item) {       Array.prototype.clone=function(){         return this.slice(0)       }       var arry=arr.clone();       arry.push(item);       return arry     }

  注:这里我特意给数组的原型加了一个克隆方法是方法初学者理解。因为直接给数组赋值如:var arry=arr;是赋值引用,

  当我改变arry时,arr源会跟着改变,所以我选择克隆一个新数组。

  4.数组的合并,不能在原有数组上修改。 

    function concat(arr1,arr2) {       var arry=arr1.slice(0);       for(var i=0;i<arr2.length;i++){         arry.push(arr2[i]);       }       return arry;     }

  注:这里我也用到了第3题的克隆(截取)方式

下面我再用一组图简单介绍一下操作数组用烂了的几个函数:push(),pop(),unshift(),shift()

  好啦,今天就写到这,欢迎多多指教!

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-04-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档