http://1632004.blog.163.com/blog/static/29991497201172254724797/
JavaScriptSerializer jss = new JavaScriptSerializer(); if (result.ProductJson!=null && result.ProductJson.Any()) { ViewBag.ProductJson = jss.Deserialize<List<ProductJson>>(result.ProductJson); }
<td>设置推荐商品:</td> <td> <div id="tbbox"> <label style="width: 200px; line-height: 30px; text-align: center">商品id</label> <label style="width: 200px; line-height: 30px; text-align: center">排序</label> <p style="width: 550px"> <input type="text" style="width: 200px; text-align: center" id="ProductId" /><input type="text" style="width: 200px; text-align: center" id="SordId"/> <input type="button" value="添加" class="operatetxt" style="width: 50px;" onclick=" addtr($.trim($('#ProductId').val()), $.trim($('#SordId').val())) " /> @* <input type="button" value="添加" class="operatetxt" style="width: 50px;" onclick=" add() " />*@ <input type="hidden" value="@Model.ProductJson" id="productjson"/> </p> <table id="activetab"> <tbody> @if (result != null && ViewBag.ProductJson != null && ViewBag.ProductJson.Count > 0) { foreach (var item in ViewBag.ProductJson) { var trId = "tr_" + item.sortindex; <tr id="@trId"> <td style='width: 500px; border: none'> <input type='text' style='width: 200px; text-align: center' value='@item.productid' name='productId'/> <input type='text' style='width: 200px; text-align: center' value='@item.sortindex' name='sordId'/> <a class='operatetxt' style='width: 40px;' onclick=' deltr(this); '>删除</a></td> </tr> } } </tbody> </table> </div> </td>
<td>状态:</td> <td> @{ var selectTrue = "checked='checked'"; var selectFalse = ""; if (Model.Enable != null) { if (Model.Enable == true) { selectTrue = "checked='checked'"; selectFalse = ""; } else { selectTrue = ""; selectFalse = "checked='checked'"; } } } <input @selectTrue type="radio" name="IsEnable" value="true" style="width: 20px;cursor:pointer" id="rd1"/><label for="rd1" style="width: 100px; text-align: left; margin-left: 0;cursor:pointer">启用</label> <input @selectFalse type="radio" name="IsEnable" value="false" style="width: 20px;cursor:pointer" id="rd2"/><label for="rd2" style="width: 100px; text-align: left; margin-left: 0;cursor:pointer">禁用</label> </td>
<script type="text/javascript"> $(function () { $("#KeyWordType").val(@Model.KeyWordType); //控制下拉框选项的值被选中 }); var productJsonListstr = $.trim($("#productjson").val()); //获取productjson字符串 var productJsonList = productJsonListstr.length > 0 ? JSON.parse(productJsonListstr) : new Array(); //由JSON字符串转换为JSON对象 //格式化开始时间与结束时间,开始时间小于结束时间 function dateFmt(obj, type) { if (type == 1) { if (obj.value == "") { WdatePicker({ dateFmt: 'yyyy-MM-dd 00:00:00', maxDate: '#F{$dp.$D(\'txtEndTime\',{d:-1})}'}); } else { WdatePicker({ dateFmt: 'yyyy-MM-dd HH:mm:ss', maxDate: '#F{$dp.$D(\'txtEndTime\',{d:-1})}'}); } } else { if (obj.value == "") { WdatePicker({ dateFmt: 'yyyy-MM-dd 23:59:59', minDate: '#F{$dp.$D(\'txtStartTime\',{d:0})}' }); } else { WdatePicker({ dateFmt: 'yyyy-MM-dd HH:mm:ss', minDate: '#F{$dp.$D(\'txtStartTime\',{d:0})}' }); } } } //用英文逗号替换英文分号、中英文逗号或者回车 function ReplaceSeperator(mobiles) { var i; var result = ""; var c; for (i = 0; i < mobiles.length; i++) { c = mobiles.substr(i, 1); if (c == ";" || c == "," || c == "," || c == "\n") result = result + ","; else if (c != "\r") result = result + c; } return result; } //json对象数组按对象属性排序 function JsonSort(obj, field, sortby) { this.obj = obj; this.field = field; this.sortby = sortby; } JsonSort.prototype.sort = function () { var $this = this; var ascend = function (a, b) { return a[$this.field] > b[$this.field] ? 1 : -1; }; var descend = function (a, b) { return a[$this.field] > b[$this.field] ? -1 : 1; }; if (this.sortby == "ascend") { this.obj.sort(ascend); } else { this.obj.sort(descend); } }; //移除当前的排序商品 function deltr(clickTd) { var tr = $(clickTd).parent(); var productId = tr.find('input[name=productId]').val(); var sordId = tr.find('input[name=sordId]').val(); //alert($.trim(JSON.stringify(productJsonList))); for (var i = 0; i < productJsonList.length; i++) { if (productJsonList[i].productid == productId) { productJsonList.splice(i, 1); //移除json数组中的该对象 } } //alert($.trim(JSON.stringify(productJsonList))); tr.remove(); } function distincttip() { var productId = $.trim($('#ProductId').val()); var sordId = $.trim($('#SordId').val()); for (var i = 0; i < productJsonList.length; i++) { if ((productId == productJsonList[i].productid)) { alert("该商品id已设置"); return false; } if (sordId == productJsonList[i].sortindex) { alert("该排序id已存在"); return false; } } return true; } function showProductList() { $('#activetab').html(""); //清空 var str = ""; for (var i = 0; i < productJsonList.length; i++) { var trId = "tr_" + productJsonList[i].sortindex; str += "<tr id = '" + trId + "'><td style='width:500px;border:none'><input type='text' style='width: 200px; text-align: center' value='" + productJsonList[i].productid + "' name='productId'/><input type='text' style='width: 200px; text-align: center' value='" + productJsonList[i].sortindex + "' name='sordId'/><a class='operatetxt' style='width: 40px;' onclick=' deltr(this);'>删除</a></td></tr>"; } $("#activetab").append(str); //alert($('#activetab').html()); } //添加新的排序商品 function addtr(productId, sordId) { if (productId == '' || productId == undefined) { alert("请填写产品id"); return false; } if (sordId == '' || sordId == undefined) { alert("请填写排序id"); return false; } if (sordId > 10 || sordId < 1) { alert("请输入在1到10之间的正整数"); return false; } if (distincttip()) { productJsonList.push({ "productid": productId, "sortindex": sordId }); $('#ProductId').val(""); //清空输入框的值 $('#SordId').val(""); var jsonSort = new JsonSort(productJsonList, 'sortindex', 'ascend'); jsonSort.sort(); //alert($.trim(JSON.stringify(productJsonList))); showProductList(); } } function necessaryinput() { var presavejA = $.trim(JSON.stringify(productJsonList)); if ($("#KeyWord").val() == '' || $("#KeyWord").val() == undefined) { alert("请填写匹配的数据"); return false; } if ($("#txtStartTime").val() == '' || $("#txtStartTime").val() == undefined) { alert("请选择有效期开始时间"); return false; } if ($("#txtEndTime").val() == '' || $("#txtEndTime").val() == undefined) { alert("请选择有效期结束时间"); return false; } if (presavejA == "[]") { alert("请设置推荐商品"); return false; } return true; } if ($("#hdId").val() > 0) { //更新时不让更改关键字类型与关键字 $("#KeyWordType").attr("disabled", "disabled"); $("#KeyWord").attr("disabled", "disabled"); } var model = {}; $("#btnSave").click(function () { model.Id = $.trim($("#hdId").val()); model.KeyWordType = $("#KeyWordType").val(); model.KeyWord = ReplaceSeperator($.trim($("#KeyWord").val())); model.StartTime = $.trim($("#txtStartTime").val()); model.EndTime = $.trim($("#txtEndTime").val()); model.Enable = $("input[name='IsEnable']:checked").val(); model.ProductJson = $.trim(JSON.stringify(productJsonList)); if (confirm("你确定保存吗?")) { if (necessaryinput()) { $.ajax({ url: '@Url.Action("EditSortProdutDetail", "SortProduct")', type: 'post', dataType: 'json', contentType: 'application/json', data: JSON.stringify(model), success: function (result) { if (result.DoFlag) { alert(result.DoResult); window.location.href = '@Url.Action("Index", "SortProduct", new { id = @Model.Id })'; } else { alert(result.DoResult); } } }); } } }); $("#btnSaveReset").click(function () { model.Id = $.trim($("#hdId").val()); model.KeyWordType = $("#KeyWordType").val(); model.KeyWord = ReplaceSeperator($.trim($("#KeyWord").val())); model.StartTime = $.trim($("#txtStartTime").val()); model.EndTime = $.trim($("#txtEndTime").val()); model.Enable = $("input[name='IsEnable']:checked").val(); model.ProductJson = $.trim(JSON.stringify(productJsonList)); if (confirm("你确定保存吗?")) { if (necessaryinput()) { $.ajax({ url: '@Url.Action("EditSortProdutDetail", "SortProduct")', type: 'post', dataType: 'json', contentType: 'application/json', data: JSON.stringify(model), success: function (result) { if (result.DoFlag) { alert(result.DoResult); window.location.href = '@Url.Action("EditDetail", "SortProduct")'; } else { alert(result.DoResult); } } }); } } }); </script>