代码如下:
(function ($)
{
//全局系统对象
window['LG'] = {};
LG.cookies = (function ()
{
var fn = function ()
{
};
fn.prototype.get = function (name)
{
var cookieValue = "";
var search = name + "=";
if (document.cookie.length > 0)
{
offset = document.cookie.indexOf(search);
if (offset != -1)
{
offset += search.length;
end = document.cookie.indexOf(";", offset);
if (end == -1) end = document.cookie.length;
cookieValue = decodeURIComponent(document.cookie.substring(offset, end))
}
}
return cookieValue;
};
fn.prototype.set = function (cookieName, cookieValue, DayValue)
{
var expire = "";
var day_value = 1;
if (DayValue != null)
{
day_value = DayValue;
}
expire = new Date((new Date()).getTime() + day_value * 86400000);
expire = "; expires=" + expire.toGMTString();
document.cookie = cookieName + "=" + encodeURIComponent(cookieValue) + ";path=/" + expire;
}
fn.prototype.remvoe = function (cookieName)
{
var expire = "";
expire = new Date((new Date()).getTime() - 1);
expire = "; expires=" + expire.toGMTString();
document.cookie = cookieName + "=" + escape("") + ";path=/" + expire;
/*path=/*/
};
return new fn();
})();
//右下角的提示框
LG.tip = function (message) {
if (LG.wintip) {
LG.wintip.set('content', message);
LG.wintip.show();
} else {
LG.wintip = $.ligerDialog.tip({ content: message });
}
setTimeout(function () {
LG.wintip.hide()
}, 5000);
};
//预加载图片
LG.prevLoadImage = function (rootpath, paths) {
for (var i in paths) {
$('').attr('src', rootpath + paths[i]);
}
};
//显示loading
LG.showLoading = function (message) {
message = message || "正在加载中...";
$('body').append("
" + message + "
");
$.ligerui.win.mask();
};
//隐藏loading
LG.hideLoading = function (message) {
$('body > div.jloading').remove();
$.ligerui.win.unmask({ id: new Date().getTime() });
};
LG.showLoading2 = function(message){
message = message || "正在加载中...";
$('body').append("
" + message + "
");
$.ligerui.win.mask();
}
LG.hideLoading2 = function(){
$('body > div.l-grid-loading').remove();
$.ligerui.win.unmask({ id: new Date().getTime() });
}
//显示成功提示窗口
LG.showSuccess = function (message, callback) {
if (typeof (message) == "function" || arguments.length == 0) {
callback = message;
message = "操作成功!";
}
$.ligerDialog.success(message, '提示', callback);
};
//显示成功提示窗口
LG.warn = function (message,title, callback) {
if (typeof (message) == "function" || arguments.length == 0) {
callback = message;
message = "操作成功!";
}
$.ligerDialog.warn(message, '提示', callback);
};
//显示失败提示窗口
LG.showError = function (message, callback)
{
if (typeof (message) == "function" || arguments.length == 0)
{
callback = message;
message = "操作失败!";
}
$.ligerDialog.error(message, '提示', callback);
};
//预加载dialog的图片
LG.prevDialogImage = function (rootPath) {
rootPath = rootPath || base;
LG.prevLoadImage(rootPath + '/core_res/thirdparty/ligerUI/skins/Aqua/images/win/', ['dialog-icons.gif']);
LG.prevLoadImage(rootPath + '/core_res/thirdparty/ligerUI/skins/Gray/images/win/', ['dialogicon.gif']);
};
//提交服务器请求
//返回json格式
//1,提交给类 options.type 方法 options.method 处理
//2,并返回 AjaxResult(这也是一个类)类型的的序列化好的字符串
LG.ajax = function (options) {
var p = options || {};
$.ajax({
cache: false,
async: p.async == undefined ? true : p.async,
url: p.url,
data: p.data,
dataType: 'json', type: 'post',
beforeSend: function () {
LG.loading = true;
if (p.beforeSend)
p.beforeSend();
else
LG.showLoading(p.loading);
},
contentType : "application/x-www-form-urlencoded;charset=utf-8",
complete: function (xhr, textStatus) {
if(xhr.status == 911){
if (top.location == location) {
window.opener=null;
alert("登陆超时,请重新登录!");
top.location = base +"/login/home.htm";
} else {
top.location = location;
}
}
LG.loading = false;
LG.hideLoading();
},
success: p.success,
error: function (result, b) {
//LG.tip('发现系统错误
错误码:' + result.status);
}
});
};
//获取当前页面的MenuNo
//优先级1:如果页面存在MenuNo的表单元素,那么加载它的值
//优先级2:加载QueryString,名字为MenuNo的值
LG.getPageMenuNo = function () {
var menuno = $("#MenuNo").val();
if (!menuno) {
menuno = getQueryStringByName("MenuNo");
}
return menuno;
};
//创建按钮
LG.createButton = function (options) {
var p = $.extend({
appendTo: $('body')
}, options || {});
var btn = $('
');
if (p.icon)
{
btn.removeClass("buttonnoicon");
btn.append('
');
}
//绿色皮肤
if (p.green)
{
btn.removeClass("button2");
}
if (p.width)
{
btn.width(p.width);
}
if (p.click)
{
btn.click(p.click);
}
if (p.text)
{
$("span", btn).html(p.text);
}
if (typeof (p.appendTo) == "string") p.appendTo = $(p.appendTo);
btn.appendTo(p.appendTo);
};
//创建过滤规则(查询表单)
LG.bulidFilterGroup = function (form) {
if (!form) return null;
var group = { op: "and", rules: [] };
$(":input", form).not(":submit, :reset, :image,:button, [disabled]")
.each(function () {
if (!this.name) return;
if (!$(this).hasClass("field")) return;
if ($(this).val() == null || $(this).val() == "") return;
var ltype = $(this).attr("ltype");
var optionsJSON = $(this).attr("ligerui"), options;
if (optionsJSON) {
options = JSON2.parse(optionsJSON);
}
var op = $(this).attr("op") || "like";
//get the value type(number or date)
var type = $(this).attr("vt") || "string";
var value = $(this).val();
var name = this.name;
//如果是下拉框,那么读取下拉框关联的隐藏控件的值(ID值,常用与外表关联)
if (ltype == "select" && options && options.valueFieldID) {
value = $("#" + options.valueFieldID).val();
name = options.valueFieldID;
}
group.rules.push({
op: op,
field: name,
value: value,
type: type
});
});
return group;
};
//附加表单搜索按钮:搜索、高级搜索
LG.appendSearchButtons = function (form, grid) {
if (!form) return;
form = $(form);
//搜索按钮 附加到第一个li 高级搜索按钮附加到 第二个li
var container = $('
').appendTo(form);
LG.addSearchButtons(form, grid, container.find("li:eq(0)"), container.find("li:eq(1)"));
};
//创建表单搜索按钮:搜索、高级搜索
LG.addSearchButtons = function (form, grid, btn1Container, btn2Container) {
if (!form) return;
if (btn1Container) {
LG.createButton({
appendTo: btn1Container,
text: '搜索',
click: function () {
var rule = LG.bulidFilterGroup(form);
if (rule.rules.length)
{
grid.set('parms', { where: JSON2.stringify(rule) });
} else
{
grid.set('parms', {});
}
grid.loadData();
}
});
}
if (btn2Container) {
LG.createButton({
appendTo: btn2Container,
width: 80,
text: '高级搜索',
click: function ()
{
grid.showFilter();
}
});
}
};
//快速设置表单底部默认的按钮:保存、取消
LG.setFormDefaultBtn = function (cancleCallback, savedCallback) {
//表单底部按钮
var buttons = [];
if (cancleCallback)
{
buttons.push({ text: '取消', onclick: cancleCallback });
}
if (savedCallback)
{
buttons.push({ text: '保存', onclick: savedCallback });
}
LG.addFormButtons(buttons);
};
//增加表单底部按钮,比如:保存、取消
LG.addFormButtons = function (buttons)
{
if (!buttons) return;
var formbar = $("body > div.form-bar");
if (formbar.length == 0)
formbar = $('
').appendTo('body');
if (!(buttons instanceof Array))
{
buttons = [buttons];
}
$(buttons).each(function (i, o)
{
var btn = $('
');
$("div.l-dialog-btn-inner:first", btn).html(o.text || "BUTTON");
if (o.onclick)
{
btn.bind('click', function ()
{
o.onclick(o);
});
}
if (o.width)
{
btn.width(o.width);
}
$("> div:first", formbar).append(btn);
});
};
//填充表单数据
LG.loadForm = function (mainform, options, callback)
{
options = options || {};
if (!mainform)
mainform = $("form:first");
var p = $.extend({
beforeSend: function ()
{
LG.showLoading('正在加载表单数据中...');
},
complete: function ()
{
LG.hideLoading();
},
success: function (data)
{
var preID = options.preID || "";
//根据返回的属性名,找到相应ID的表单元素,并赋值
for (var p in data)
{
var ele = $("[name=" + (preID + p) + "]", mainform);
//针对复选框和单选框 处理
if (ele.is(":checkbox,:radio"))
{
ele[0].checked = data[p] ? true : false;
}
else
{
ele.val(data[p]);
}
}
//下面是更新表单的样式
var managers = $.ligerui.find($.ligerui.controls.Input);
for (var i = 0, l = managers.length; i < l; i++)
{
//改变了表单的值,需要调用这个方法来更新ligerui样式
var o = managers[i];
o.updateStyle();
if (managers[i] instanceof $.ligerui.controls.TextBox)
o.checkValue();
}
if (callback)
callback(data);
},
error: function (message)
{
LG.showError('数据加载失败!
错误信息:' + message);
}
}, options);
LG.ajax(p);
};
//带验证、带loading的提交
LG.submitForm = function (mainform, success, error, data) {
if (!mainform)
mainform = $("form:first");
if (mainform.valid()) {
mainform.ajaxSubmit({
dataType: 'json',
success: success,
data: data,
beforeSubmit: function (formData, jqForm, options){
//针对复选框和单选框 处理
$(":checkbox,:radio", jqForm).each(function (){
if (!existInFormData(formData, this.name)){
formData.push({ name: this.name, type: this.type, value: this.checked });
}
});
for (var i = 0, l = formData.length; i < l; i++){
var o = formData[i];
if (o.type == "checkbox" || o.type == "radio"){
o.value = $("[name=" + o.name + "]", jqForm)[0].checked ? "true" : "false";
}
}
},
beforeSend: function (a, b, c){
LG.showLoading('正在保存数据中...');
},
complete: function (result){
LG.hideLoading();
},
error: function (result){
LG.tip('发现系统错误
错误码:' + result.status);
}
});
}
else{
LG.showInvalid();
}
function existInFormData(formData, name){
for (var i = 0, l = formData.length; i < l; i++){
var o = formData[i];
if (o.name == name) return true;
}
return false;
}
};
//提示 验证错误信息
LG.showInvalid = function (validator) {
validator = validator || LG.validator;
if (!validator) return;
var message = '
存在' + validator.errorList.length + '个字段验证不通过,请检查!
';
//top.LG.tip(message);
$.ligerDialog.error(message);
};
//表单验证
LG.validate = function (form, options) {
if (typeof (form) == "string")
form = $(form);
else if (typeof (form) == "object" && form.NodeType == 1)
form = $(form);
options = $.extend({
errorPlacement: function (lable, element)
{
if (!element.attr("id"))
element.attr("id", new Date().getTime());
if (element.hasClass("l-textarea"))
{
element.addClass("l-textarea-invalid");
}
else if (element.hasClass("l-text-field"))
{
element.parent().addClass("l-text-invalid");
}
$(element).removeAttr("title").ligerHideTip();
$(element).attr("title", lable.html()).ligerTip({
distanceX: 5,
distanceY: -3,
auto: true
});
},
success: function (lable) {
if (!lable.attr("for")) return;
var element = $("#" + lable.attr("for"));
if (element.hasClass("l-textarea")) {
element.removeClass("l-textarea-invalid");
} else if (element.hasClass("l-text-field")) {
element.parent().removeClass("l-text-invalid");
}
$(element).removeAttr("title").ligerHideTip();
}
}, options || {});
LG.validator = form.validate(options);
return LG.validator;
};
LG.loadToolbar = function (grid, toolbarBtnItemClick) {
LG.ajax({
loading: '正在加载工具条中...',
type: 'AjaxSystem',
url: base + '/rbac/operate!toolBarButton.ajax',
data: { HttpContext: true, url: location.pathname },
success: function (data) {
if (!grid.toolbarManager) return;
if (!data || !data.length) return;
var items = [];
for (var i = 0, l = data.length; i < l; i++){
var o = data[i];
items[items.length] = {
click: toolbarBtnItemClick || LG.toolbarBtnItemClick,
text: o.name,
html: o.html,
img: base + "/" + o.btnIcon,
id: o.id,
url: o.url
};
items[items.length] = { line: true };
}
grid.toolbarManager.set('items', items);
}
});
};
LG.toolbarBtnItemClick = function(item) {
eval(item.html);
};
//关闭Tab项,如果tabid不指定,那么关闭当前显示的
LG.closeCurrentTab = function (tabid) {
if (!tabid) {
tabid = $("#framecenter > .l-tab-content > .l-tab-content-item:visible").attr("tabid");
}
if (tab) {
tab.removeTabItem(tabid);
}
};
//关闭Tab项并且刷新父窗口
LG.closeAndReloadParent = function (tabid, parentMenuNo) {
LG.closeCurrentTab(tabid);
var menuitem = $("#mainmenu ul.menulist li[menuno=" + parentMenuNo + "]");
var parentTabid = menuitem.attr("tabid");
var iframe = window.frames[parentTabid];
if (tab) {
tab.selectTabItem(parentTabid);
}
if (iframe && iframe.f_reload) {
iframe.f_reload();
} else if (tab) {
tab.reload(parentTabid);
}
};
//覆盖页面grid的loading效果
LG.overrideGridLoading = function () {
$.extend($.ligerDefaults.Grid, {
onloading: function () {
LG.showLoading('正在加载表格数据中...');
}, onloaded: function () {
LG.hideLoading();
}
});
};
//根据字段权限调整 页面配置
LG.adujestConfig = function (config, forbidFields) {
if (config.Form && config.Form.fields) {
for (var i = config.Form.fields.length - 1; i >= 0; i--) {
var field = config.Form.fields[i];
if ($.inArray(field.name, forbidFields) != -1)
config.Form.fields.splice(i, 1);
}
}
if (config.Grid && config.Grid.columns) {
for (var i = config.Grid.columns.length - 1; i >= 0; i--) {
var column = config.Grid.columns[i];
if ($.inArray(column.name, forbidFields) != -1)
config.Grid.columns.splice(i, 1);
}
}
if (config.Search && config.Search.fields)
{
for (var i = config.Search.fields.length - 1; i >= 0; i--)
{
var field = config.Search.fields[i];
if ($.inArray(field.name, forbidFields) != -1)
config.Search.fields.splice(i, 1);
}
}
};
//查找是否存在某一个按钮
LG.findToolbarItem = function (grid, itemID)
{
if (!grid.toolbarManager) return null;
if (!grid.toolbarManager.options.items) return null;
var items = grid.toolbarManager.options.items;
for (var i = 0, l = items.length; i < l; i++)
{
if (items[i].id == itemID) return items[i];
}
return null;
};
//设置grid的双击事件(带权限控制)
LG.setGridDoubleClick = function (grid, btnID, btnItemClick) {
// btnItemClick = btnItemClick || toolbarBtnItemClick;
// if (!btnItemClick) return;
grid.bind('dblClickRow', function (rowdata) {
var item = LG.findToolbarItem(grid, btnID);
if (!item) return;
grid.select(rowdata);
eval(item.html);
//btnItemClick(item);
});
};
//将选中的记录转换成ID数组
LG.getIds = function (selected){
var ids = new Array();
for (var i = 0; i< selected.length; i++){
ids.push(selected[i].id);
};
return ids;
};
LG.ajaxByJSON = function ajaxByJSON(_url,_data,_async, callBack, errorCallBack){
jQuery.ajax({
url: _url,
cache: false,
async: _async,
type: 'POST',
data: _data,
dataType: 'json',
error: function(){
if(errorCallBack){
errorCallBack();
}
alert("jQuery.ajax 执行失败!");
},
success: function(json){
if(callBack) callBack(json);
}
});
}
LG.search = function(grid, p){
p = $.extend({
beforeSearch: null, //搜索之前调用的函数
afterSearch: null //搜索之后调用的函数
}, p || {});
$("#search").click(function(){
var self = this;
this.p = p;
if ($.isFunction(self.p.beforeSearch)) {
self.p.beforeSearch();
}
var searchData = getWarpPara("functions");
delete searchData[""];
var flag = false;
for (var key in searchData) {
if (searchData[key].trim() != "") {
flag = true;
break;
}
}
if (flag) {
$("#search_btn_reset").css("display", "inline");
grid.options.parms = searchData;
grid.loadData(true);
if ($.isFunction(self.p.afterSearch)) {
self.p.afterSearch();
}
}
});
$("#search_btn_reset").click(function(){
clearSearchWeiget("functions");
grid.options.parms = null;
grid.loadData(true);
$(this).css("display", "none");
});
};
})(jQuery);
//根据id清空搜索框
function clearSearchWeiget(id){
var inputs = $("#"+id).find("input[type!='button'], select");
for (var i = 0; i < inputs.size(); i++) {
var input = $(inputs[i]);
//如果是checkbox
if(input.attr("type") == "checkbox" && input.val() != ''){
input.attr("checked", false);
continue;
} else if(input.attr("type") == "radio"){
if (input.attr("checked")) {
input.attr("checked", false);
}
continue;
} else if (input.val() != '') {
input.val("");
continue;
}
}
};