[JavaScript] JQuery를 이용한 Drag Drop 리스트 순서변경


dd8b9164e328f2c1e534e53b6016b8cd.png
위 리스트 형태를 드래그 드랍을 이용하여 순서를 변경할 수 있다.


ul 과 li 태그는 그대로 사용하는 것이 무방하다. ^.^


//Drag Drop 순서 바꾸기를 위한 태그

$irDataHtml .= '<div style="display:none;"><input class="disp-order" data-id="'.$irData['no'].'" data-order="'.$irDispIdx.'" data-reorder="'.$irDispIdx.'" value="'.$irData['no'].'-'.$irDispIdx.'"></div>';


실제 DB에 order를 저장하고 다음에는 Query시 Order ASC 형태로 쿼리하면 된다.

<script>
// Drag Drop 순서 바꾸기
$(function (){
$('#ir-data-list').sortable({
stop: function (event, ui) {
reorder();
}
});
$('#ir-data-list').disableSelection();
});

function reorder() {
$("#ir-data-list .ir-data-wrapper").each(function(i, box) {
var li_target = $(box).find(".disp-order");
var li_order = li_target.data('id') + '=' + (i+1);
li_target.data('reorder',(i+1));
li_target.val(li_order);
$('[data-action="reorderUpdate"]').css('display','block');
});
}

$('[data-action="reorderUpdate"]').on('click', function (e) {

var orderUpdateInfo = '';
var li_target ,li_order;
$("#ir-data-list .disp-order").each(function() {
li_target = $(this);
li_order = li_target.data('order');
if (li_order != li_target.data('reorder')) {
orderUpdateInfo += (li_target.val() + ',');
}
});

alert(orderUpdateInfo);

var sO = new Object();
sO.cmd = 'ir.list.order.update';

sO.orderUpdateInfo = orderUpdateInfo;
console.log(sO);
var url = "<?php echo site_url('IpsAjax/apiCall'); ?>";
___ajax(url,sO,0,null);
});
</script>
0
0
이 글을 페이스북으로 퍼가기 이 글을 트위터로 퍼가기 이 글을 카카오스토리로 퍼가기 이 글을 밴드로 퍼가기
captcha
자동등록방지 숫자입력

웹개발

번호 제목 글쓴이 날짜 조회수
122 [Dart] Dart 문법 정리 최고관리자 09-09 24,845
121 [Flutter] absorbpointer-and-ignorepointer 최고관리자 09-08 24,166
120 [PHP] 타입선언 최고관리자 08-22 23,995
119 [PHP] error_level 셋팅과 실제 출력 최고관리자 08-21 24,100
118 [MySql] 타입지정시 괄호안의 숫자 최고관리자 08-18 24,131
117 [MySql] MySQL 최적의 데이터 타입 선택 방법 최고관리자 08-18 23,808
116 [MySql] 인덱스 조회시 주의 사항 최고관리자 08-18 23,813
115 [MySql] NOT NULL과 DEFAULT 를 동시에 쓸 필요가 있는가? 최고관리자 08-18 23,833
114 [Flutter] Row and Column 최고관리자 08-16 23,691
113 [Flutter] Linting 설정으로, 흔하게 실수할 수 있는 것을 build 전 방지하기. 최고관리자 08-16 23,856
112 [PHP] PHP 7.x PHP 8.x에서의 조건문 최고관리자 07-26 23,829
111 [JS] Webpack을 쓰는 이유 최고관리자 07-24 23,885
110 [Vue] Vue Router 최고관리자 07-22 23,763
109 [Vue] Vue.js 기본 원리 최고관리자 07-22 24,250
108 [MySql] 쿼리 결과를 합치는 union vs union all의 차이 최고관리자 07-10 23,777
107 [Vue] 일반적인 프로젝트의 구조에 대해 알아보자. 최고관리자 06-18 23,844
106 [JSP] vue등의 스크립트 분석을 위해 %태그 정도는 알자. 최고관리자 06-18 23,971
105 [MySql] 페이징(paging) 쿼리시 전체개수를 한번에 처리하는 방법 최고관리자 06-14 24,609
104 [MySql] Join vs Sub Query 비교 최고관리자 06-05 24,021
103 [SQL] SQL Join에 대한 이해 최고관리자 06-05 23,872