Rumah  >  Artikel  >  hujung hadapan web  >  jquery实现元素拖动排序(附代码)

jquery实现元素拖动排序(附代码)

php中世界最好的语言
php中世界最好的语言asal
2018-04-26 09:28:222077semak imbas

这次给大家带来jquery实现元素拖动排序(附代码),jquery实现元素拖动排序的注意事项有哪些,下面就是实战案例,一起来看一下。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 
<title>jquery学习-jquery对元素拖动排序</title> 
<style type="text/css"> 
#show 
{ 
color: Red; 
} 
#list 
{ 
cursor: move; 
width: 300px; 
} 
#list li 
{ 
border: solid 1px yellow; 
float: left; 
list-style-type
: none; 
margin-top: 10px;


下边,我们一步一步来实现这个功能。

7c928e1d211f36ec7310729fd46a47c1
e388a4556c0f65e1904146cc1a846bee
  54153603597a11c0ecaca8d50659c6a5
94b3e26ee717c64999d7867364b1b4a3
e388a4556c0f65e1904146cc1a846bee
  42f9d5e1cca7403849efb03461e9dc4d
  fffa25a7818d82750bcdb1d93f1448b2
    d1c056396ead6d6604ab822b507e6f06
    0fc5c90f257c8bbe709da427d559475b
      bf6105e4f5d8de1e7369b22baf553752" title="73c2b177074e40726d0145cd07cfd221">
        9566dce7235c757661f3387e59eb332f" />
      bed06894275b65c1ab86501b08a632eb
    247b94fc9b32a7a895c80acdf798d00f
    eae969b2b8f4f46816c415c43cee3362   
  929d1f5ca49e04fdcb27f9465b944689
94b3e26ee717c64999d7867364b1b4a3

有一个单选框,当用户选中后,拖动图片时对数据库中数据排序进行更改。隐藏域保存原来的图片排列顺序。ul显示图片列表。

为了能看得过去,稍微加了点样式:

var show = jQuery("#show"); //输出提示 
var orderlist = jQuery("#orderlist"); //原顺序 
var check = jQuery("#check"); //是否更新到数据库

首先将常用的选择器保存下来,这样后边调用就变得比较简洁。这一部大家肯定没有问题。^_^

//保存原来的排列顺序 
var order = []; 
list.children("li").each(function() { 
  order.push(this.title); //原排列顺序保存在title,得到后更改title 
  jQuery(this).attr("title", "你可以拖动进行排序"); 
}); 
orderlist.val(order.join(','));

保存原来的排列顺序到隐藏域。这里用到了数组的push()方法,就是将ul每个li中的title(原来的排列顺序)添加到数组中。最后用join()方法,得到了原排列顺序,返回一个字符串。现在排列顺序格式为1,2,3 。

//ajax更新 
var Update = function(itemid, itemorder) { 
  jQuery.ajax({ 
    type: "post", 
    url: "update.aspx", 
    //id:新的排列对应的ID,order:原排列顺序
    data: { id: itemid, order: orderlist.val() },  
    beforeSend: function() { 
      show.html("正在更新"); 
    }, 
    success: function() { 
      show.html("更新成功"); 
    } 
  }); 
};

接下来,将ajax更新块单独分出来。这样程序变得比较整洁,这块没有新东西。

//调用ajax更新方法 
var Submit = function(update) { 
  var order = []; 
  list.children("li").each(function() { 
    order.push(this.id); 
  }); 
  var itemid = order.join(','); 
  //如果单选框选中,则更新表中排列顺序 
  if (update) { 
    Update(itemid); 
  } 
  else { 
    show.html(""); 
  } 
};

和得到排列顺序类似,将ID组成一个字符串传递给了Update()方法。函数中的参数update为checkbox是否选中。

//执行排列操作 
list.sortable({ 
  opacity: 0.7, 
  update: function() { 
    Submit(check.attr("checked")); 
  } 
});
} 
531ac245ce3e4fe3d50054a55f265927 
8bd863e91d98a06233d67cb070a5a0352cacc6d41bbb37262a98f745aa00fbf0 
fa50566c1ba3ab9c330d111a9753321f2cacc6d41bbb37262a98f745aa00fbf0 
8019067d09615e43c7904885b5246f0a 
$(document).ready(function () { 
//保存常用选择器 
var list = $("#list"); //ul 
var show = $("#show"); //输出提示 
var orderlist = $("#orderlist"); //原顺序 
var check = $("#check"); //是否更新到数据库 
//保存原来的排列顺序 
var order = []; 
list.children("li").each(function () { 
order.push(this.title); //原排列顺序保存在title,得到后更改title 
$(this).attr("title", "你可以拖动进行排序"); 
}); 
orderlist.val(order.join()); 
//执行排列操作 
list.sortable({ 
axis: 'y',//只能横向拖动 
opacity: 0.7,// 移动时的透明度 
update: function () {//当排序动作结束时且元素坐标已经发生改变时触发此事件。 
Submit(check.attr("checked")); 
} 
}); 
//ajax更新 
var Update = function (itemid, itemorder) { 
$.ajax({ 
type: "post", 
url: "update.aspx", 
data: { id: itemid, order: orderlist.val() }, //id:新的排列对应的ID,order:原排列顺序 
beforeSend: function () { 
show.html("正在更新"); 
}, 
success: function (req) { 
if (req == "100") { 
show.html("更新成功"); 
} 
else if (req == "001") { 
show.html("失败,请稍后再试"); 
} 
else { 
show.html("参数不全"); 
} 
} 
}); 
}; 
//调用ajax更新方法 
var Submit = function (update) { 
var order = []; 
list.children("li").each(function () { 
order.push(this.id); 
}); 
var itemid = order.join(','); 
//如果单选框选中,则更新表中排列顺序 
if (update) { 
Update(itemid); 
} 
else { 
show.html(""); 
} 
}; 
}); 
2cacc6d41bbb37262a98f745aa00fbf0 
9c3bca370b5104690d9ef395f2c5f8d1 
6c04bd5ca3fcae76e30b72ad730ca86d 
0f28a2e542498a06984532c26ec903d7 
4d8013dd52b59b7f5010ca6f4d407322 
abb3ee51e3edf4023a53117b7f59c8d7 
94b3e26ee717c64999d7867364b1b4a3 
7c928e1d211f36ec7310729fd46a47c154bdf357c58b8a65c66d7c19c8e4d114 
4a249f0d628e2318394fd9b75b4636b1jQuery对元素拖动排序473f0a7621bec819994bb5020d29372a 
e388a4556c0f65e1904146cc1a846bee拖动时同时更新数据库数据:3946ef108da436c11ba9837ecc9a60e094b3e26ee717c64999d7867364b1b4a3 
e388a4556c0f65e1904146cc1a846bee 
42f9d5e1cca7403849efb03461e9dc4d 
fffa25a7818d82750bcdb1d93f1448b2 
a147adb5559a34aa31a726348d34ab3c 
09cd0892fd3fa82f3cd76967db807afcbed06894275b65c1ab86501b08a632eb 
acba92fa4ca9d3de20e0fe1b3a8a92b9 
272c3bad1ce688d7eb3565c47a7aae64bed06894275b65c1ab86501b08a632eb 
d6446f532190dc211a3be932a20b4760 
604eb8bc7ff6e6c7ceccd55b37633193bed06894275b65c1ab86501b08a632eb 
929d1f5ca49e04fdcb27f9465b944689 
94b3e26ee717c64999d7867364b1b4a3 
f5a47148e367a6035fd7a2faa965022e 
36cc49f0c466276486e50c850b7e4956 
73a6ac4ed44ffec12cee46588e518a5e

最后,执行排列操作。后台部分就是对现在ID对应原来排列顺序的更新,相信大家并不陌生。

可以看出如果不进行数据库操作,该插件只需要调用sorttable便可完成对元素的拖动。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

sortElements实现table排序步骤详解

jquery实现表格排序+实时搜索功能

Atas ialah kandungan terperinci jquery实现元素拖动排序(附代码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn