成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? jQuery拖動元素并對元素進行重新排序
全站頭部文字 我要出現在這里
jQuery拖動元素并對元素進行重新排序 641 2024-03-15   

本文實例講述了jQuery拖動元素并對元素進行重新排序的實現方法,分享給大家供大家參考,具體實現內容如下

效果圖:

查看圖片

具體內容如下:

從上圖可以看出我們今天要實現的功能。當用戶拖動一個圖片時,就能改變圖片的已有排序并更新表中的排列順序。比如用戶可以隨意拖動我們網站中的布局,如谷歌iGoogle就已經實現了。這樣便很好的提高了用戶體驗。

下邊,我們一步一步來實現這個功能。

<span id="show">
<div>
  <input id="check" type="checkbox" />
</div>
<div>
  <input type="hidden" id="orderlist" />
  <ul id="list">
    <asp:Repeater ID="rptOrder" runat="server">
    <ItemTemplate>
      <li id="<%#Eval("ID") %>" title="<%#Eval("OrderID") %>">
        <img alt="img" src="http://www.gimoo.net/t/1904/<%"Link") %>" />
      </li>
    </ItemTemplate>
    </asp:Repeater>   
  </ul>
</div>

有一個單選框,當用戶選中后,拖動圖片時對數據庫中數據排序進行更改。隱藏域保存原來的圖片排列順序。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")); 
  } 
});

最后,執行排列操作。后臺部分就是對現在ID對應原來排列順序的更新,相信大家并不陌生。

可以看出如果不進行數據庫操作,該插件只需要調用sorttable便可完成對元素的拖動。

以上就是jQuery拖動元素并對元素進行重新排序的實現方法,希望對大家的學習有所幫助。



主站蜘蛛池模板: 山西卫视直播高清在线直播| cctv16节目表今天内容| 日本电视剧《阿信》| 黑暗之心电影完整在线观看| 云上的宝石| 极品美女在线| 抖音电脑直播| 无内秘书| 四 电影| 成人免费视频在线播放| 所求皆所愿| 人民日报评墨茶| 胃疼呕吐视频实拍| 单敬尧| 诗歌繁星| 白鲸 电影| 奔向所有时空的你电视剧在线观看| 游泳池电影| 在线播放网站| 同根生| 巨神战击队| 美女洗澡直播| 尹馨演过的三部电影| 红电视剧演员表| 永恒族 电影| 2024年援疆职称评审最新政策| 那些女人演员表全部名单| 美国电影《黑吃黑》在线观看| 谈判专家 电影| 母线槽规格型号及价格| after之后| 尤克里里指弹谱| 安渡| 首映式| 圆的认识评课| 可能歌词完整版| 投名状演员表| 草刈正雄| 杨晓宁| 神探狄仁杰1电视剧| 女生的宿舍2|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103