jquery easy ui datagrid中遇到的坑爹的問題。。。

      不說廢話,直接上代碼吧。。。
      //定義一個全局變量防止重複提交(百度了一下彷佛不少人也遇到類似的問題)
1
    var i = 0; 2 //修改 3 function Update() { 4 //獲取選中行 5 var selected = $("#dg1").datagrid('getSelected');
         //判斷是否有選中行
6 if (selected != null) { 7 //顯示添加窗體 8 $('.theme-popover-mask').fadeIn(100); 9 $('.theme-popover').slideDown(200); 10 //初始化窗體內容 11 $("#title").text("修改信息"); 12 $("#btnAdd").hide(); 13 $("#btnUpdate").show(); 14 $("#id").val(selected.ID);
           //問題就出在這裡 開始沒有用將選中行的ID賦值給hidden 開始一直以為是緩存的問題
           而是直接寫的 model.push({ ID:selected.ID, Grade: grade, State: state, UserName: username, PassWord: password, RegisterDate: registerdate.format("yyyy-MM-dd hh:mm:ss") });
           這樣的話取的ID就是第一次選中行的ID 因此後臺始終更新的就是第一次選中行的數據
15 $("#username").val(selected.UserName); 16 $("#username").attr("disabled", "disabled"); 17 $("#username").attr("background-color", "#E0CACA"); 18 $("#password").val(selected.PassWord); 19 $("input[name='grade'][value=" + selected.Grade + "]").attr("checked", "checked"); 20 $("input[name='state'][value=" + selected.State + "]").attr("checked", "checked"); 21 if (i == 0) { 22 $("#btnUpdate").click(function () { 23 i++; //點擊按鈕i++ i=0時才能提交 防止重複提交 24 var model = []; 25 var id = $("#id").val();
               //再將hidden的值取出來賦值給id 這樣就沒有上面的問題了 我也是很鬱悶其實本質上沒區別的。。。 可就是取的值不一樣
                model.push({ ID: id, Grade: grade, State: state, UserName: username, PassWord: password, RegisterDate: registerdate.format("yyyy-MM-dd hh:mm:ss") });
26 var username = $("#username").val(); 27 var password = $("#password").val(); 28 var grade = $("input[name='grade']:checked").val(); 29 var state = $("input[name='state']:checked").val(); 30 var registerdate = new Date(); 31 model.push({ ID: id, Grade: grade, State: state, UserName: username, PassWord: password, RegisterDate: registerdate.format("yyyy-MM-dd hh:mm:ss") }); 32 //ajax異步提交 33 $.ajax({ 34 type: "post", 35 cache: false,  //禁用緩存                 
37 url: "/Admin/Update?time" + (new Date()).getTime(), //也是防止緩存問題 38 data: { "data": JSON.stringify(model)}, //序列化json格式提交到後臺 39 success: function (data) { 40 $('.theme-popover-mask').fadeOut(100); 41 $('.theme-popover').slideUp(200); 42 if (data == 1) { 43 ds.dialog({ 44 title: '溫馨提示', 45 content: '恭喜你,修改爲功!', 46 icon: '../../images/dsdialog/success.png' 47 }); 48 } 49 else { 50 ds.dialog({ 51 title: '溫馨提示', 52 content: '修改失敗!', 53 icon: '../../images/dsdialog/info.png' 54 }); 55 } 56 //從新加載datagrid 57 $("#dg1").datagrid('reload'); 58 } 59 });
                //end ajax 60 //$.post("/Admin/Update?time" + (new Date()).getTime(), {"data": JSON.stringify(model) }, function (data) { 61 //$('.theme-popover-mask').fadeOut(100); 62 //$('.theme-popover').slideUp(200); 63 //if (data == 1) { 64 // ds.dialog({ 65 // title: '溫馨提示', 66 // content: '恭喜你,修改爲功!', 67 // icon: '../../images/dsdialog/success.png' 68 // }); 69 // } 70 //else{ 71 // ds.dialog({ 72 // title: '溫馨提示', 73 // content: '修改失敗!', 74 // icon: '../../images/dsdialog/info.png' 75 // }); 76 //} 77 //$("#dg1").datagrid('reload'); 78 //}); 79 }); //end click 80 } 81 } 82 else { 83 ds.dialog({ 84 title: '溫馨提示', 85 content: '請選擇要修改的行!', 86 icon: '../../images/dsdialog/info.png' 87 }); 88 } 89 }
 1      //刪除
 2         function Delete() {
 3             var selected = $("#dg1").datagrid('getSelected');
 4             if (selected != null) {
 5                 ds.dialog({
 6                     title: '溫馨提示',
 7                     content: '你確定要刪除該用戶嗎?',
 8                     icon: '../../images/dsdialog/question.png',
 9                     yesText: '確定',
10                     onyes: function () {
                //但是刪除的時候 這樣是沒問題的 因為刪除了上一次選中的行就沒有了 因此不會出現Update時的問題 當然添加的時候也不會出現這種問題的 但是我先作的就是刪除方法 因此沒想到這些 哈哈 是否是很蛋疼了。。。
11 $.post("/Admin/Delete", { "Id": selected.ID }, function (data) { 12 if (data == 1) { 13 ds.dialog({ 14 title: '溫馨提示', 15 content: '恭喜你,刪除成功!', 16 icon: '../../images/dsdialog/success.png' 17 }); 18 } 19 else { 20 ds.dialog({ 21 title: '溫馨提示', 22 content: '刪除失敗!', 23 icon: '../../images/dsdialog/info.png' 24 }); 25 } 26 $("#dg1").datagrid('reload'); 27 }); 28 }, 29 noTest: '取消', 30 onno: function () { 31 this.close(); 32 } 33 }); 34 } 35 else { 36 ds.dialog({ 37 title: '溫馨提示', 38 content: '請選擇要刪除的行!', 39 icon: '../../images/dsdialog/info.png' 40 }); 41 } 42 }
 1 //格式化日期
 2         Date.prototype.format = function (format) {
 3             var o = {
 4                 "M+": this.getMonth() + 1, //month
 5                 "d+": this.getDate(),    //day
 6                 "h+": this.getHours(),   //hour
 7                 "m+": this.getMinutes(), //minute
 8                 "s+": this.getSeconds(), //second
 9                 "q+": Math.floor((this.getMonth() + 3) / 3),  //quarter
10                 "S": this.getMilliseconds() //millisecond
11             }
12             if (/(y+)/.test(format)) format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
13             for (var k in o) if (new RegExp("(" + k + ")").test(format))
14                 format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
15             return format;
16         }

    生命不息,代碼不止...ajax

相關文章
相關標籤/搜索