基于jquery實現(xiàn)左右上下移動效果
更新時間:2018年05月02日 11:20:06 作者:田埂上的夢想
這篇文章主要為大家詳細介紹了基于jquery實現(xiàn)左右上下移動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
最近再做報表時候,直接把全部字段都導出了,但這不太靈活。回憶老師講過的項目做報表如下左右上下移功能靈活控制,所以就嘗試下咯。

js代碼
function selected(thiz)
{
var name = thiz.name;
if(name=="right")
$("select[name='left']").val("");
else
$("select[name='right']").val("");
}
function Shift(thiz)
{
var right = $("select[name='right']");
var left = $("select[name='left']");
if(thiz=="left" && right.val() != ""){
lrShift(right,left);
}else if(thiz=="right" && left.val() != ""){
lrShift(left,right);
}
//獲取選中的值
}
//從dest移動到target
function lrShift(dest,target)
{
var childrens = dest.children();
var args = "";
//alert(dest.val());
var dests = dest.val()
for(var x = 0; x < dests.length; x++)
{
var vaTemp = dests[x];
target.append("<option value='"+vaTemp+"'>"+vaTemp+"</option>");//追加
target.find("option[value='"+vaTemp+"']").attr("selected",true);//給追加獲取焦點
for(var y = 0; y <childrens.length;y++ )//刪除選中的元素
{
if(childrens.get(y).value==vaTemp)
$(childrens.get(y)).remove();
}
}
dest.val("");
}
function ShiftValue(address)
{
var right = $("select[name='right']");
var left = $("select[name='left']");
if(right.val()!=null)
shift(right,address);
else if(left.val()!=null)
shift(left,address);
}
function shift(obj,address){
//獲取選中的值
var objData = obj.val();
var childrens = obj.children();
var strs = "";
for(var x = 0; x < objData.length; x++)
{
strs+="@"+objData[x];
}
//獲取要添加位置對象
var temp = null;
if(address=="top"){
var number = findSelect(childrens,objData[0]);
if((--number) < 0)
return;
temp = childrens.get(number);
}
else{
var number = findSelect(childrens,objData[objData.length-1]);
if((++number) > childrens.length-1)
return;
temp = childrens.get(number);
}
//刪除選中的值
var n = 0;
var buffer = new Array(childrens.length-objData.length);
for(var x = 0; x < childrens.length;x++)
{
var value = childrens.get(x).value;
if(strs.indexOf(value)==-1)
buffer[n++] = value;
}
//添加新排序的值
obj.empty();
if(address=="top")
{
for(var y = 0; y < buffer.length;y++)
{
if(buffer[y]==temp.value)
{
for(var x = 0; x < objData.length ; x++)
{
obj.append("<option>"+objData[x]+"</option>");
}
}
obj.append("<option>"+buffer[y]+"</option>");
}
}else{
for(var y = 0; y < buffer.length;y++)
{
obj.append("<option>"+buffer[y]+"</option>");
if(buffer[y]==temp.value)
{
for(var x = 0; x < objData.length; x++)
{
obj.append("<option>"+objData[x]+"</option>");
}
}
}
}
//選中值
obj.val(objData);
}
function findSelect(selects,objValue)
{
var number = -1;
for(var x = 0; x < selects.length; x++)
{
if(objValue==selects.get(x).value)
number = x;
}
return number;
}
頁面調用
<div>
<div>
<b>未導出字段</b>
</div>
<div style="float:left;">
<select name="left" multiple="multiple" onchange="selected(this)" style="height:350px;width:200px;">
<option value="姓名">姓名</option>
<option value="快件號">快件號</option>
<option value="快遞公司">快遞公司</option>
<option value="首重">首重</option>
<option value="續(xù)重">續(xù)重</option>
</select>
</div>
</div>
<div style="float:left;">
<div style="margin:30px;margin-top:110px;">
<input type="button" value="<<" onclick="Shift('left')"/>
</div>
<div style="margin:30px;margin-top:30px;">
<input type="button" value=">>" onclick="Shift('right')"/>
</div>
</div>
<div style="margin-top:-20px;">
<div style="margin-left:22%;">
<b>需導出字段</b>
</div>
<div style="float:left;">
<select name="right" multiple="multiple" onchange="selected(this)" style="height:350px;width:200px;">
<option value="首價">首價</option>
<option value="續(xù)價">續(xù)價</option>
<option value="大大">大大</option>
<option value="小小">小小</option>
</select>
</div>
</div>
<div style="float:left;">
<div style="margin:30px;margin-top:110px;">
<input type="button" value="向上" onclick="ShiftValue('top')" />
</div>
<div style="margin:30px;margin-top:30px;">
<input type="button" value="向下" onclick="ShiftValue('bottom')" />
</div>
</div>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
jQuery JSON實現(xiàn)無刷新三級聯(lián)動實例探討
無刷新三級聯(lián)動的實現(xiàn)方法有很多,今天將與大家討論下jQuery JSON如何實現(xiàn),感興趣的朋友們可以參考下哈2013-05-05
基于jQuery實現(xiàn)帶動畫效果超炫酷的彈出對話框(附源碼下載)
這是一款基于jQuery的彈出對話框插件,這個jQuery對話框插件的最大特點是彈出和關閉都帶有非常炫酷的動畫特效,需要的朋友參考下吧2016-02-02
快速掌握jquery分頁插件jqPaginator的使用方法
這篇文章主要幫助大家快速掌握jquery分頁插件jqPaginator的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08
jsonp跨域請求數(shù)據(jù)實現(xiàn)手機號碼查詢實例分析
這篇文章主要介紹了jsonp跨域請求數(shù)據(jù)實現(xiàn)手機號碼查詢的方法,結合實例形式較為詳細的分析了jsonp跨域請求數(shù)據(jù)的原理與查詢號碼的應用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-12-12
jQuery+jsp實現(xiàn)省市縣三級聯(lián)動效果(附源碼)
這篇文章主要介紹了jQuery+jsp實現(xiàn)省市縣三級聯(lián)動效果,以完整實例形式分析了jQuery結合jsp讀取MySQL數(shù)據(jù)庫操作實現(xiàn)省市縣三級聯(lián)動效果的相關技巧,并附帶完整實例源碼供讀者下載參考,需要的朋友可以參考下2015-12-12

