zoukankan      html  css  js  c++  java
  • js 实现数组元素交换位置

    /**
    * 数组元素交换位置
    * @param {array} arr 数组
    * @param {number} index1 添加项目的位置
    * @param {number} index2 删除项目的位置
    * index1和index2分别是两个数组的索引值,即是两个要交换元素位置的索引值,如1,5就是数组中下标为1和5的两个元素交换位置
    */
    function swapArray(arr, index1, index2) {
       arr[index1] = arr.splice(index2, 1, arr[index1])[0];
        return arr;
    }
    
    //上移 将当前数组index索引与后面一个元素互换位置,向数组后面移动一位
    
    function zIndexUp(arr,index,length){
       if(index+1 != length){
           swapArray(arr, index, index+1);
       }else{
          alert(‘已经处于置顶,无法上移‘);
      }
    }
    
    //下移 将当前数组index索引与前面一个元素互换位置,向数组前面移动一位
    
    function zIndexDown(arr,index,length){
       if(index!= 0){
           swapArray(arr, index, index-1);
       }else{
          alert(‘已经处于置底,无法下移‘);
      }
    }
    
    //置顶,即将当前元素移到数组的最后一位
    
    function zIndexTop(arr,index,length){
       if(index+1 != length){
    
         //首先判断当前元素需要上移几个位置,置底移动到数组的第一位
          var moveNum = length - 1 - index;
    
          //循环出需要一个一个上移的次数
           for (var i = 0; i<moveNum; i++) {
    
             swapArray(arr, index, index + 1);
    
              index++;
    
         }
       }else{
          alert(‘已经处于置顶‘);
      }
    }
    
    //置底,即将当前元素移到数组的第一位
    
    function zIndexBottom(arr,index,length){
       if(index!=0){
    
          //首先判断当前元素需要上移几个位置,置底移动到数组的第一位
          var moveNum = index - 0;
    
          //循环出需要一个一个上移的次数
           for (var i = 0; i<moveNum; i++) {
    
             swapArray(arr, index, index - 1);
    
              index--;
    
         }
       }else{
          alert(‘已经处于置底‘);
      }
    }
  • 相关阅读:
    反汇编测试20191325
    20191325mystat
    20191325学习笔记8
    20191325学习笔记7
    2.3.1测试 20191325
    20191214-改进ls
    团队作业4
    20191214-反汇编测试
    stat命令的实现-mysate(必做)
    图片
  • 原文地址:https://www.cnblogs.com/plBlog/p/13906288.html
Copyright © 2011-2022 走看看