js 实现数组元素交换位置
2017-05-03 15:32
323 查看
/**
* 数组元素交换位置
* @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('已经处于置底');
}
}
* 数组元素交换位置
* @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('已经处于置底');
}
}
相关文章推荐
- JS+CSS实现几个DIV层上下移动交换位置的效果
- 原生js实现照片墙的效果(拖拽图片与另一张图片交换位置)
- js实现两个div交换位置
- js金额数字格式化实现代码(三位加逗号处理保留两位置小数)
- JS实现iframe编辑器光标位置插入内容的方法(兼容IE和Firefox)
- js实现获取鼠标当前的位置
- 用JS实现页面滚动位置保持的方法
- 链表的基本操作(创建,查找指定位置元素,删除指定元素,插入,倒置,去重,求集合的差,分别交换结点与交换结点值实现的冒泡排序,将两个有序链表合并成一个有序链表)c语言实现
- js从数组中删除指定值(不是指定位置)的元素实现代码
- 通过js实现2个select控件的交换数据
- 点击导航,滑动到网页中的指定位置(JS实现滑动锚点定位)
- JS实现页面进入、返回定位到具体位置
- JS能力测评-查找数组元素位置
- textbox 在光标位置插入字符功能的js实现(兼容ie,firefox)
- (***)有两个10个元素的数组,分别为A和B,编程实现相同位置的元素, 如果 B 的元素小于 A 的元素进行数值交换:(使用回调函数实现)
- js 交换两个元素的位置,动画效果
- RecycleView实现拖拽交换item位置
- js几行代码实现数组元素删除,无占位,改长度
- js实现滚动条滚动到某个位置便自动定位某个tr
- frames的对象兼容性获取以及跨域实现数据交换(js文件的加载判断)