$(function () { $("#jqGrid").jqGrid({ url: '../sys/printer/list', datatype: "json", colModel: [ {label: 'id', name: 'id', index: 'id', key: true, hidden: true}, {label: '打印机名称', name: 'name', index: 'name', width: 80}, {label: '打印机编号', name: 'sn', index: 'sn', width: 80}, {label: '所属门店', name: 'storeName', index: 'store_name', width: 80}], viewrecords: true, height: 385, rowNum: 10, rowList: [10, 30, 50], rownumbers: true, rownumWidth: 25, autowidth: true, multiselect: true, pager: "#jqGridPager", jsonReader: { root: "page.list", page: "page.currPage", total: "page.totalPage", records: "page.totalCount" }, prmNames: { page: "page", rows: "limit", order: "order" }, gridComplete: function () { $("#jqGrid").closest(".ui-jqgrid-bdiv").css({"overflow-x": "hidden"}); } }); }); let vm = new Vue({ el: '#rrapp', data: { showList: true, title: null, sysPrinter: {}, ruleValidate: { name: [ {required: true, message: '打印机名称不能为空', trigger: 'blur'} ], sn: [ {required: true, message: '打印机编号不能为空', trigger: 'blur'} ], storeId: [ {required: true, message: '所属门店不能为空', trigger: 'blur'} ] }, q: { name: '' }, storeList: [] }, methods: { getStoreList: function() { $.get("../store/queryAll", function (r) { vm.storeList = r.list; }); }, query: function () { vm.reload(); }, add: function () { vm.showList = false; vm.title = "新增"; vm.sysPrinter = {}; vm.storeList = []; vm.getStoreList(); }, update: function (event) { let id = getSelectedRow(); if (id == null) { return; } vm.showList = false; vm.title = "修改"; vm.getInfo(id) }, saveOrUpdate: function (event) { let url = vm.sysPrinter.id == null ? "../sys/printer/save" : "../sys/printer/update"; $.ajax({ type: "POST", url: url, contentType: "application/json", data: JSON.stringify(vm.sysPrinter), success: function (r) { if (r.code === 0) { alert('操作成功', function (index) { vm.reload(); }); } else { alert(r.msg); } } }); }, del: function (event) { let ids = getSelectedRows(); if (ids == null) { return; } confirm('确定要删除选中的记录?', function () { $.ajax({ type: "POST", url: "../sys/printer/delete", contentType: "application/json", data: JSON.stringify(ids), success: function (r) { if (r.code == 0) { alert('操作成功', function (index) { $("#jqGrid").trigger("reloadGrid"); }); } else { alert(r.msg); } } }); }); }, getInfo: function (id) { $.get("../sys/printer/info/" + id, function (r) { vm.sysPrinter = r.sysPrinter; }); }, reloadSearch: function () { vm.q = { name: '' } vm.reload(); }, reload: function (event) { vm.showList = true; let page = $("#jqGrid").jqGrid('getGridParam', 'page'); $("#jqGrid").jqGrid('setGridParam', { postData: {'name': vm.q.name}, page: page }).trigger("reloadGrid"); vm.handleReset('formValidate'); }, handleSubmit: function (name) { handleSubmitValidate(this, name, function () { vm.saveOrUpdate() }); }, handleReset: function (name) { handleResetForm(this, name); } } });