欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS組件Bootstrap Table表格行拖拽效果實(shí)現(xiàn)代碼

 更新時(shí)間:2020年08月27日 09:07:02   作者:懶得安分  
這篇文章分享了JS組件Bootstrap Table表格行拖拽效果實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

一、業(yè)務(wù)需求及實(shí)現(xiàn)效果

項(xiàng)目涉及到訂單模塊,那天突然接到一個(gè)需求,說(shuō)是兩種不同狀態(tài)的訂單之間要實(shí)現(xiàn)插單的效果,頁(yè)面上呈現(xiàn)方式是:左右兩個(gè)Table,左邊Table里面是狀態(tài)為1的訂單,右邊Table里面是狀態(tài)為2訂單,左邊Table里面的行數(shù)據(jù)拖動(dòng)到右邊Table里面指定行的位置,拖動(dòng)完成后,左邊表格減少一行,右邊表格增加一行。除此之外,還需要撤銷(xiāo)操作(相當(dāng)于Ctrl + Z操作),能夠返回到上一步的狀態(tài)??赡苊枋鰰?huì)讓大家模擬兩可,反正已經(jīng)實(shí)現(xiàn)了,先來(lái)看看效果圖吧。

1、先看看拖動(dòng)之前的效果

2、這是拖動(dòng)左邊表格行數(shù)據(jù)的效果

3、拖動(dòng)一行完成之后表格數(shù)據(jù)的效果

4、第二次、第三次拖動(dòng)完成后效果

5、右邊表格上面撤銷(xiāo)操作點(diǎn)擊效果

6、多次點(diǎn)擊撤銷(xiāo),表格回到初始狀態(tài)

二、代碼示例
接到需求的第一感覺(jué)是應(yīng)該上Bootstrap table api里面找一下,畢竟開(kāi)源的力量是強(qiáng)大的,或許有相關(guān)的示例呢。經(jīng)過(guò)一番查找,很可惜,Bootstrap Table沒(méi)有這種兩張表格之間的操作。想想其實(shí)也可以理解,Bootstrap Table是針對(duì)某個(gè)動(dòng)態(tài)表格數(shù)據(jù)綁定的,它的側(cè)重點(diǎn)是表格內(nèi)部的功能,比如表格內(nèi)部行的拖拽排序(Reorder Rows)有很好的解決方案,對(duì)于像博主這樣的特殊需求,似乎也應(yīng)該自己去實(shí)現(xiàn)。
1、需求分析
既然決定自己去寫(xiě),開(kāi)始分析需求,似乎這個(gè)操作里面比較困難的是拖拽效果,說(shuō)到拖拽效果,原來(lái)使用JsPlumb的時(shí)候那使用太多了,于是就想到了我們神奇的JQuery UI里面的draggable.js 和droppable.js。拖拽的問(wèn)題解決了,那么還有一個(gè)難點(diǎn),就是撤銷(xiāo)操作怎么辦?我們知道Ctrl+z的意思是還原,什么叫還原?就是返回到上一步的操作,那么前提是要能夠保存上一步的狀態(tài),說(shuō)到保存某一步的狀態(tài),博主就知道怎么做了,需要一個(gè)全局變量Json,里面要有三個(gè)鍵值對(duì),分別是當(dāng)前步驟的索引、左邊表格的數(shù)據(jù)、右邊表格的數(shù)據(jù)。似乎也不太難嘛,就此著手,開(kāi)干。
2、代碼示例
2.1 cshtml頁(yè)面代碼

<html>
<head>
 <meta name="viewport" content="width=device-width" />
 <title>@ViewBag.Title</title>
 @Styles.Render("~/Content/css")
 @Styles.Render("~/Content/table-css")
 @Scripts.Render("~/bundles/jquery")
 @Scripts.Render("~/bundles/knockout")
 @Scripts.Render("~/bundles/bootstrap")
 @Scripts.Render("~/bundles/bootstrap-table")
 @RenderSection("Scripts", false)
</head>
<body>
 @RenderBody()
</body>
</html>
 
@{
 ViewBag.Title = "訂單插單";
 Layout = "~/Views/Shared/_Layout.cshtml";
}

@Scripts.Render("~/bundles/Order/InsertOrder")
@Styles.Render("~/bundles/Order/css")
@Scripts.Render("~/Content/bootstrap/datepicker/js")
@Styles.Render("~/Content/bootstrap/datepicker/css")

<script src="~/Content/jquery-ui-1.11.4.custom/jquery-ui.min.js"></script>

<div class="panel-body" style="padding-bottom:0px;">
 
 <div class="panel panel-default" style="margin-bottom:0px;">
 <div class="panel-heading">查詢(xún)條件</div>
 <div class="panel-body container-fluid">
 <div class="row">
 <div class="col-md-3">
 <label for="txt_search_ordernumber" class="col-sm-4 control-label" style="margin-top:6px;">訂單號(hào)</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_ordernumber">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_bodynumber" class="col-sm-3 control-label" style="margin-top:6px;">車(chē)身號(hào)</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_bodynumber">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_vinnumber" class="col-sm-4 control-label" style="margin-top:6px;">VIN碼</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_vinnumber">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_engin_code" class="col-sm-4 control-label" style="margin-top:6px;">發(fā)動(dòng)機(jī)號(hào)</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_engin_code">
 </span>
 </div>
 </div>
 <div class="collapse" id="div_more_search">
 <div class="row" style="margin-top:15px;">
 <div class="col-md-3">
 <label for="txt_search_import_startdate" class="col-sm-4 control-label" style="margin-top:6px;">導(dǎo)入時(shí)間</label>
 <span class="col-sm-8">
 <input type="text" class="form-control datetimepicker" readonly id="txt_search_import_startdate">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_import_enddate" class="col-sm-3 control-label" style="margin-top:6px;">至</label>
 <span class="col-sm-8">
 <input type="text" class="form-control datetimepicker" readonly id="txt_search_import_enddate">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_send_startdate" class="col-sm-4 control-label" style="margin-top:6px;">下發(fā)時(shí)間</label>
 <span class="col-sm-8">
 <input type="text" class="form-control datetimepicker" readonly id="txt_search_send_startdate">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_send_enddate" class="col-sm-4 control-label" style="margin-top:6px;">至</label>
 <span class="col-sm-8">
 <input type="text" class="form-control datetimepicker" readonly id="txt_search_send_enddate">
 </span>
 </div>
 </div>

 <div class="row" style="margin-top:15px;">
 <div class="col-md-3">
 <label for="txt_search_carcode" class="col-sm-4 control-label" style="margin-top:6px;">整車(chē)編碼</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_carcode">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_vms" class="col-sm-3 control-label" style="margin-top:6px;">VMS號(hào)</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_vms">
 </span>
 </div>
 <div class="col-md-3">
 <label for="txt_search_trans_code" class="col-sm-4 control-label" style="margin-top:6px;">變速箱號(hào)</label>
 <span class="col-sm-8">
 <input type="text" class="form-control" id="txt_search_trans_code">
 </span>
 </div>
 </div>
 </div>

 <div class="row" style="float:right;margin-right:50px;margin-top:13px;">
 <div>
 <button type="button" id="btn_query" class="btn btn-primary" style="margin-right:20px;width:100px;">查詢(xún)</button>
 <button type="submit" id="btn_reset" class="btn btn-default" style="margin-right:20px;width:100px;">重置</button>
 </div>

 </div>
 </div>
 </div>

 <div class="collapse_div_outside">
 <div class="collapse_div_inside"></div>
 <span id="span_collapse" href="#div_more_search" class="collapse_div_inside_ele">展開(kāi)<label class="glyphicon glyphicon-menu-down"></label></span>
 </div>
</div>

@*<div id="toolbar_left" class="btn-group">
</div>*@
<div id="toolbar_right" class="btn-group">
 <button id="btn_cancel" type="button" class="btn btn-default">
 <span class="glyphicon glyphicon-backward aria-hidden="true"></span>撤銷(xiāo)
 </button>
 <button id="btn_insertorder" type="button" class="btn btn-default">
 <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>插單
 </button>
</div>
<div class="panel-body" style="padding-top:0px;">
 <div id="div_tableleft" class="col-md-6">
 <table id="tb_order_left"></table>
 </div>
 <div id="div_tableright" class="col-md-6">
 <table id="tb_order_right"></table>
 </div>
</div>

2.2 js代碼

var i_statuindex = 0;
//此數(shù)組用于保存撤銷(xiāo)操作每一步的數(shù)據(jù)
var arrdata = [];

var m_oTable = null;

$(function () {
 //1.初始化表格
 m_oTable = new TableInit();
 m_oTable.Init();

 //2.初始化按鈕事件
 var oButtonInit = new ButtonInit();
 oButtonInit.Init();

 //3.日期控件的初始化
 $(".datetimepicker").datetimepicker({
 format: 'yyyy-mm-dd hh:ii',
 autoclose: true,
 todayBtn: true,
 });

});

//表格相關(guān)事件和方法
var TableInit = function () {
 var oTableInit = new Object();

 oTableInit.Init = function () {
     //初始化左邊表格
 $('#tb_order_left').bootstrapTable({
 url: '/api/OrderApi/get',
 method: 'get',
 striped: true,
 cache: false,
 striped: true,
 pagination: true,
 height: 600,
 uniqueId:"TO_ORDER_ID",
 queryParams: oTableInit.queryParams,
 queryParamsType: "limit",
 sidePagination: "server",
 pageSize: 10,
 pageList: [10, 25, 50, 100],
 search: true,
 strictSearch: true,
 showColumns: true,
 showRefresh: true,
 minimumCountColumns: 2,
 clickToSelect: true,
 columns: [{
 checkbox: true
 },
 {
 field: 'ORDER_NO',
 title: '訂單號(hào)'
 },
 {
 field: 'BODY_NO',
 title: '車(chē)身號(hào)'
 }, {
 field: 'VIN',
 title: 'VIN碼'
 }, {
 field: 'TM_MODEL_MATERIAL_ID',
 title: '整車(chē)編碼'
 },
 {
 field: 'ORDER_TYPE',
 title: '訂單類(lèi)型'
 },
 {
 field: 'ORDER_STATUS',
 title: '訂單狀態(tài)'
 },
 {
 field: 'CREATE_DATE',
 title: '訂單導(dǎo)入時(shí)間'
 },
 {
 field: 'PLAN_DATE',
 title: '訂單計(jì)劃上線日期'
 },
 {
 field: 'VMS_NO',
 title: 'VMS號(hào)'
 },
 {
 field: 'ENGIN_CODE',
 title: '發(fā)動(dòng)機(jī)號(hào)'
 },
 {
 field: 'TRANS_CODE',
 title: '變速箱號(hào)'
 },
 {
 field: 'OFFLINE_DATE_ACT',
 title: '實(shí)際下線日期'
 },
 {
 field: 'HOLD_RES',
 title: 'hold理由'
 },
 {
 field: 'SPC_FLAG',
 title: '特殊標(biāo)記'
 },
 ],
 onLoadSuccess: function (data) {
 //表格加載完成之后初始化拖拽
          oTableInit.InitDrag();
 }
 });
     //初始化右邊表格
 $('#tb_order_right').bootstrapTable({
 url: '/api/OrderApi/get',
 method: 'get',
 toolbar: '#toolbar_right',
 striped: true,
 cache: false,
 striped: true,
 pagination: true,
 height: 600,
 queryParams: oTableInit.queryParamsRight,
 queryParamsType: "limit",
 //ajaxOptions: { departmentname: "", statu: "" },
 sidePagination: "server",
 pageSize: 10,
 pageList: [10, 25, 50, 100],
 search: true,
 strictSearch: true,
 showRefresh: true,
 minimumCountColumns: 2,
 columns: [
 {
 field: 'ORDER_NO',
 title: '訂單號(hào)'
 },
 {
 field: 'BODY_NO',
 title: '車(chē)身號(hào)'
 }, {
 field: 'VIN',
 title: 'VIN碼'
 }, {
 field: 'TM_MODEL_MATERIAL_ID',
 title: '整車(chē)編碼'
 },
 {
 field: 'ORDER_TYPE',
 title: '訂單類(lèi)型'
 },
 {
 field: 'ORDER_STATUS',
 title: '訂單狀態(tài)'
 },
 {
 field: 'CREATE_DATE',
 title: '訂單導(dǎo)入時(shí)間'
 },
 {
 field: 'PLAN_DATE',
 title: '訂單計(jì)劃上線日期'
 },
 {
 field: 'VMS_NO',
 title: 'VMS號(hào)'
 },
 {
 field: 'ENGIN_CODE',
 title: '發(fā)動(dòng)機(jī)號(hào)'
 },
 {
 field: 'TRANS_CODE',
 title: '變速箱號(hào)'
 },
 {
 field: 'OFFLINE_DATE_ACT',
 title: '實(shí)際下線日期'
 },
 {
 field: 'HOLD_RES',
 title: 'hold理由'
 },
 {
 field: 'SPC_FLAG',
 title: '特殊標(biāo)記'
 },
 ],
 onLoadSuccess: function (data) {
 oTableInit.InitDrop();
 }
 });
 };
 //注冊(cè)表格行的draggable事件
 oTableInit.InitDrag = function () {
 $('#tb_order_left tr').draggable({
 helper: "clone",
 start: function (event, ui) {
 var old_left_data = JSON.stringify($('#tb_order_left').bootstrapTable("getData"));
 var old_right_data = JSON.stringify($('#tb_order_right').bootstrapTable("getData"));
 var odata = { index: ++i_statuindex, left_data: old_left_data, right_data: old_right_data };
 arrdata.push(odata);
 },
 stop: function (event, ui) {
 
 }
 });
 };
 //注冊(cè)右邊表格的droppable事件
 oTableInit.InitDrop = function () {
 $("#tb_order_right").droppable({
 drop: function (event, ui) {
 var arrtd = $(ui.helper[0]).find("td");
 var rowdata = {
 ORDER_NO: $(arrtd[1]).text(),
 BODY_NO: $(arrtd[2]).text(),
 VIN: $(arrtd[3]).text(),
 TM_MODEL_MATERIAL_ID: $(arrtd[4]).text(),
 ORDER_TYPE: $(arrtd[5]).text(),
 ORDER_STATUS: $(arrtd[6]).text(),
 CREATE_DATE: $(arrtd[7]).text() == "-" ? null : $(arrtd[7]).text(),
 PLAN_DATE: $(arrtd[8]).text() == "-" ? null : $(arrtd[8]).text(),
 VMS_NO: $(arrtd[9]).text(),
 ENGIN_CODE: $(arrtd[10]).text(),
 TRANS_CODE: $(arrtd[11]).text(),
 OFFLINE_DATE_ACT: $(arrtd[12]).text() == "-" ? null : $(arrtd[12]).text(),
 HOLD_RES: $(arrtd[13]).text(),
 SPC_FLAG: $(arrtd[14]).text(),
 TO_ORDER_ID: $(ui.helper[0]).attr("data-uniqueid")

 };
 var oTop = ui.helper[0].offsetTop;
 var iRowHeadHeight = 40;
 var iRowHeight = 37;
 var rowIndex = 0;
 if (oTop <= iRowHeadHeight + iRowHeight / 2) {
 rowIndex = 0;
 }
 else {
 rowIndex = Math.ceil((oTop - iRowHeadHeight) / iRowHeight);
 }
          //插入右邊表格指定位置行數(shù)據(jù)
 $("#tb_order_right").bootstrapTable("insertRow", { index: rowIndex, row: rowdata });
 $('#tb_order_left').bootstrapTable("removeByUniqueId", $(ui.helper[0]).attr("data-uniqueid"));
 oTableInit.InitDrag();
 }
 });
 };

 oTableInit.queryParams = function (params) { //配置參數(shù)
 var temp = { //這里的鍵的名字和控制器的變量名必須一直,這邊改動(dòng),控制器也需要改成一樣的
 limit: params.limit, //頁(yè)面大小
 offset: params.offset, //頁(yè)碼
 strBodyno: $("#txt_search_bodynumber").val(),
 strVin: $("#txt_search_vinnumber").val(),
 strOrderno: $("#txt_search_ordernumber").val(),
 strEngincode: $("#txt_search_engin_code").val(),
 strOrderstatus: 0,
 strTranscode: $("#txt_search_trans_code").val(),
 strVms: $("#txt_search_vms").val(),
 strCarcode: $("#txt_search_carcode").val(),
 strImportStartdate: $("#txt_search_import_startdate").val(),
 strImportEnddate: $("#txt_search_import_enddate").val(),
 strSendStartdate: $("#txt_search_send_startdate").val(),
 strSendEnddate: $("#txt_search_send_enddate").val(),

 };
 return temp;
 };

 oTableInit.queryParamsRight = function (params) { //配置參數(shù)
 var temp = { //這里的鍵的名字和控制器的變量名必須一直,這邊改動(dòng),控制器也需要改成一樣的
 limit: params.limit, //頁(yè)面大小
 offset: params.offset, //頁(yè)碼
 strBodyno: "",
 strVin: "",
 strOrderno: "",
 strEngincode: "",
 strOrderstatus: 5,
 strTranscode: "",
 strVms: "",
 strCarcode: "",
 strImportStartdate: "",
 strImportEnddate: "",
 strSendStartdate: "",
 strSendEnddate: "",

 };
 return temp;
 };

 return oTableInit;
};

//頁(yè)面按鈕初始化事件
var ButtonInit = function () {
 var oInit = new Object();
 var postdata = {};

 oInit.Init = function () {

 //查詢(xún)點(diǎn)擊事件
 $("#btn_query").click(function () {
 $("#tb_order_left").bootstrapTable('refresh');
 });

 //重置點(diǎn)擊事件
 $("#btn_reset").click(function () {
 $(".container-fluid").find(".form-control").val("");
 $("#tb_order_left").bootstrapTable('refresh');
 });
 //撤銷(xiāo)操作點(diǎn)擊事件
 $("#btn_cancel").click(function () {
 if (i_statuindex <= 0) {
 return;
 }
 for (var i = 0; i < arrdata.length; i++) {
 if (arrdata[i].index != i_statuindex) {
 continue;
 }
 var arr_left_data = eval(arrdata[i].left_data);
 var arr_right_data = eval(arrdata[i].right_data);

 $('#tb_order_left').bootstrapTable('removeAll');
 $('#tb_order_right').bootstrapTable('removeAll');
 $('#tb_order_left').bootstrapTable('append', arr_left_data);
 for (var x = 0; x < arr_right_data.length; x++) {
 $("#tb_order_right").bootstrapTable("insertRow", { index: x, row: arr_right_data[x] });
 }
 
 //$('#tb_order_right').bootstrapTable('append', arr_right_data);//append之后不能drop
 break;
 }
 i_statuindex--;

 //重新注冊(cè)可拖拽
 m_oTable.InitDrag();
 //m_oTable.InitDrop();
 });

 //搜索欄展開(kāi)收起點(diǎn)擊事件
 $("#span_collapse").click(function () {
 if ($(this).text() == "收起") {
 $(this).html('展開(kāi)<label class="glyphicon glyphicon-menu-down"></label>');
 $("#div_more_search").collapse('hide');
 }
 else {
 $(this).html('收起<label class="glyphicon glyphicon-menu-up"></label>');
 $("#div_more_search").collapse('show')
 }
 });
 };

 return oInit;
};

我們重點(diǎn)來(lái)看幾個(gè)地方的代碼:
2.2.1  左邊表格加載成功之后執(zhí)行表格行的可拖拽。

$('#tb_order_left tr').draggable({
 helper: "clone",
 start: function (event, ui) {
 var old_left_data = JSON.stringify($('#tb_order_left').bootstrapTable("getData"));
 var old_right_data = JSON.stringify($('#tb_order_right').bootstrapTable("getData"));
 var odata = { index: ++i_statuindex, left_data: old_left_data, right_data: old_right_data };
 arrdata.push(odata);
 },
 stop: function (event, ui) {
 }
 });

在draggable的start事件中,我們將拖拽之前的左右表格中的數(shù)據(jù)全部保存到arrdata變量中,i_statuindex這個(gè)全局變量用于記錄當(dāng)前這一步的索引,用于撤銷(xiāo)操作。
2.2.2 右邊表格在加載成功之后注冊(cè)表格的droppable事件    

$("#tb_order_right").droppable({
 drop: function (event, ui) {
 var arrtd = $(ui.helper[0]).find("td");
 var rowdata = {
 ORDER_NO: $(arrtd[1]).text(),
 BODY_NO: $(arrtd[2]).text(),
 VIN: $(arrtd[3]).text(),
 TM_MODEL_MATERIAL_ID: $(arrtd[4]).text(),
 ORDER_TYPE: $(arrtd[5]).text(),
 ORDER_STATUS: $(arrtd[6]).text(),
 CREATE_DATE: $(arrtd[7]).text() == "-" ? null : $(arrtd[7]).text(),
 PLAN_DATE: $(arrtd[8]).text() == "-" ? null : $(arrtd[8]).text(),
 VMS_NO: $(arrtd[9]).text(),
 ENGIN_CODE: $(arrtd[10]).text(),
 TRANS_CODE: $(arrtd[11]).text(),
 OFFLINE_DATE_ACT: $(arrtd[12]).text() == "-" ? null : $(arrtd[12]).text(),
 HOLD_RES: $(arrtd[13]).text(),
 SPC_FLAG: $(arrtd[14]).text(),
 TO_ORDER_ID: $(ui.helper[0]).attr("data-uniqueid")

 };
 var oTop = ui.helper[0].offsetTop;
 var iRowHeadHeight = 40;
 var iRowHeight = 37;
 var rowIndex = 0;
 if (oTop <= iRowHeadHeight + iRowHeight / 2) {
 rowIndex = 0;
 }
 else {
 rowIndex = Math.ceil((oTop - iRowHeadHeight) / iRowHeight);
 }
 $("#tb_order_right").bootstrapTable("insertRow", { index: rowIndex, row: rowdata });
 $('#tb_order_left').bootstrapTable("removeByUniqueId", $(ui.helper[0]).attr("data-uniqueid"));
 oTableInit.InitDrag();
 }
 });

在drop事件時(shí),取到當(dāng)前拖過(guò)來(lái)的行數(shù)據(jù),計(jì)算當(dāng)前鼠標(biāo)所在的位置,在右邊表格指定位置插入拖過(guò)來(lái)的行數(shù)據(jù)。然后刪除左邊表格拖過(guò)來(lái)的行數(shù)據(jù)。
2.2.3 撤銷(xiāo)操作代碼   

//撤銷(xiāo)操作點(diǎn)擊事件
 $("#btn_cancel").click(function () {
 if (i_statuindex <= 0) {
 return;
 }
 for (var i = 0; i < arrdata.length; i++) {
 if (arrdata[i].index != i_statuindex) {
 continue;
 }
 var arr_left_data = eval(arrdata[i].left_data);
 var arr_right_data = eval(arrdata[i].right_data);

 $('#tb_order_left').bootstrapTable('removeAll');
 $('#tb_order_right').bootstrapTable('removeAll');
 $('#tb_order_left').bootstrapTable('append', arr_left_data);
 for (var x = 0; x < arr_right_data.length; x++) {
 $("#tb_order_right").bootstrapTable("insertRow", { index: x, row: arr_right_data[x] });
 }
 //$('#tb_order_right').bootstrapTable('append', arr_right_data);//append之后不能drop
 break;
 }
 i_statuindex--;

 //重寫(xiě)注冊(cè)可拖拽
 m_oTable.InitDrag();
 });

撤銷(xiāo)操作主要是通過(guò)全局變量arrdata里面的索引判斷撤銷(xiāo)到哪一步,然后根據(jù)索引取出當(dāng)前步驟的左右表格數(shù)據(jù),依次向兩表格插入數(shù)據(jù),然后i_statuindex依次遞減,直至等于零,由于左邊表格行數(shù)據(jù)全部重寫(xiě)加載過(guò),所以需要重新注冊(cè)可拖拽事件。就是這么簡(jiǎn)單的三步就能實(shí)現(xiàn)想要的效果,是不是很簡(jiǎn)單~~

如果大家還想深入學(xué)習(xí),可以點(diǎn)擊這里進(jìn)行學(xué)習(xí),再為大家附兩個(gè)精彩的專(zhuān)題:Bootstrap學(xué)習(xí)教程 Bootstrap實(shí)戰(zhàn)教程

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • 深入解析JavaScript中函數(shù)的Currying柯里化

    深入解析JavaScript中函數(shù)的Currying柯里化

    這篇文章主要介紹了JavaScript中函數(shù)的Currying柯里化,Currying 的重要意義在于可以把函數(shù)完全變成"接受一個(gè)參數(shù)、返回一個(gè)值"的固定形式,需要的朋友可以參考下
    2016-03-03
  • 一文帶你深入理解JavaScript模板引擎

    一文帶你深入理解JavaScript模板引擎

    在Web前端開(kāi)發(fā)中,需要將數(shù)據(jù)動(dòng)態(tài)渲染到頁(yè)面上,隨著應(yīng)用程序的復(fù)雜度增加,數(shù)據(jù)渲染的邏輯也變得越來(lái)越復(fù)雜,這時(shí)候就需要使用模板引擎來(lái)幫助我們動(dòng)態(tài)生成HTML標(biāo)記,本文將深入介紹 JavaScript 模板引擎,幫助讀者更好地理解和應(yīng)用模板引擎
    2023-06-06
  • uniapp 封裝組件的方法實(shí)例分析

    uniapp 封裝組件的方法實(shí)例分析

    這篇文章主要介紹了uniapp 封裝組件的方法,結(jié)合實(shí)例形式分析了uniapp父級(jí)頁(yè)與子頁(yè)面組件封裝與傳參交互相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2023-06-06
  • JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)留言板功能

    JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)留言板功能

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)留言板功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • 詳解如何使用webpack打包JS

    詳解如何使用webpack打包JS

    這篇文章主要介紹了詳解如何使用webpack打包JS,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • javaScript深拷貝和淺拷貝的簡(jiǎn)單介紹

    javaScript深拷貝和淺拷貝的簡(jiǎn)單介紹

    深淺拷貝知識(shí)在我們的日常開(kāi)發(fā)中還算是用的比較多,下面這篇文章主要給大家介紹了關(guān)于javaScript深拷貝和淺拷貝的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • JS的拖拽屬性draggable詳解

    JS的拖拽屬性draggable詳解

    這篇文章主要介紹了JS的拖拽屬性draggable詳解,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • JS點(diǎn)擊動(dòng)態(tài)添加標(biāo)簽、刪除指定標(biāo)簽的代碼

    JS點(diǎn)擊動(dòng)態(tài)添加標(biāo)簽、刪除指定標(biāo)簽的代碼

    這篇文章主要介紹了JS點(diǎn)擊動(dòng)態(tài)添加標(biāo)簽、刪除指定標(biāo)簽的代碼,在文中給大家補(bǔ)充介紹了js 更加輪播圖圖片張數(shù)動(dòng)態(tài)生成小圓點(diǎn)的方法,需要的朋友參考下實(shí)現(xiàn)代碼
    2018-04-04
  • 一行JavaScript代碼如何實(shí)現(xiàn)瀑布流布局

    一行JavaScript代碼如何實(shí)現(xiàn)瀑布流布局

    這篇文章主要給大家介紹了如何通過(guò)一行JavaScript代碼實(shí)現(xiàn)瀑布流布局的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 利用 JavaScript 實(shí)現(xiàn)并發(fā)控制的示例代碼

    利用 JavaScript 實(shí)現(xiàn)并發(fā)控制的示例代碼

    這篇文章主要介紹了利用 JavaScript 實(shí)現(xiàn)并發(fā)控制的示例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常想詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12

最新評(píng)論