<script>
/*
方法目录;
【IE7 8 不支持trim()方法的弥补】
【 终止冒泡】
【数字千分位】
【js运算的替代方法(js3.3/1.1不等于3浮点计算有bug)】
【日期加减天数,两日期相减】
【页面如果想使用终止冒泡,则在页面调用此方法;类ArtJS_stopMaopao点击会终止冒泡;类ArtJs_removeAfterDomClick dom点击会remove或者hide】
【元素下方呈现带有三角形的div】
【table实现类似excel搜索】
【table排序】
【弥补layer.msg只能同一时间使用一个,第二个会覆盖第一个的效果】
*/

; (function (a, $) {
//【IE7 8 不支持trim()方法】
String.prototype.trim = function () {
return this.replace(/^\s\s*/, '').replace(/\s\s*$/, '');
}
var ArtJS = {};
/*
【 终止冒泡】
对于 动态元素的事件绑定(比如 live ),stopMaopao无效果,需要在方法内使用return false;即可。
使用冒泡,则使用冒泡的元素内部的同样的事件,只能冒泡到当前元素上就会终止冒泡。所以内部元素的live不会冒泡到document起作用(直接在元素上onclick能起作用)。不过可以使用, on(delegate) 的方式,使事件监听不冒泡到document对象而是冒泡到使用冒泡的元素身上即可。{live是把动态元素事件的监听放到document上;delegate是把动态元素事件的监听放到指定的对象上,高版本的jquery推荐使用on}

使用时候的注意点:event参数需要来自于要使用终止冒泡的方法绑定时候的参数中;
情况1-> <input type='button' value='按钮' onclick='btnClick(event,其他参数)'/>
情况2-> <input type='button' value='按钮' id='testbtn'/> $('#testbtn').click(funtion(event,其他参数){})
情况3-> $('#testbtn').live('click',function(其他参数){ 逻辑代码; return false;})

return false 就可以终止冒泡。
*/
ArtJS.stopMaopao = function (event) {
var evt = event || window.event;
if (evt.stopPropagation) { //W3C阻止冒泡方法
evt.stopPropagation();
} else {
evt.cancelBubble = true; //IE阻止冒泡方法
}
}
/*
【数字千分位】
数字千位分,只负责把数字类型的数据转换成千位分的字符串。如需要小数和四舍五入等则在千位分之前进行处理。
*/
ArtJS.toThousandSplit = function (num) {
//1.先去除空格,判断是否空值和非数
num = num + "";
num = num.replace(/[^\d.]/g, "");
num = num.replace(/^\./g, ""); //第一个不能是.
num = num.replace(".", "f").replace(/\./g, "").replace("f", "."); //仅保留第一个小数点
if (num == "") {
return "";
}

//2.针对是否有小数点,分情况处理
var index = num.indexOf(".");
if (index == -1) {//无小数点
var reg = /(-?\d+)(\d{3})/;
while (reg.test(num)) {
num = num.replace(reg, "$1,$2");
}
} else {
var intPart = num.substring(0, index);
var pointPart = num.substring(index + 1, num.length);
var reg = /(-?\d+)(\d{3})/;
while (reg.test(intPart)) {
intPart = intPart.replace(reg, "$1,$2");
}
num = intPart + "." + pointPart;
}
return num;
}
ArtJS.deThousandSplit = function (numStr) {
numStr = numStr.replace(/[ ]/g, ""); //去除空格
numStr = numStr.replace(/,/gi, '');
return numStr;
}
ArtJS.autoThousandSplit = function (val) {
val = val.toString();
if (val.indexOf(",") > -1) {
return nameSpace.duyupu.deThousandSplit(val);
} else {
return nameSpace.duyupu.toThousandSplit(val);
}
}
//【js运算的替代方法(js3.3/1.1不等于3浮点计算有bug)】
ArtJS.A = function (arg1, arg2) {
var r1, r2, m;
try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }
try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
m = Math.pow(10, Math.max(r1, r2))
return (T(arg1, m) + T(arg2, m)) / m
}
//减
ArtJS.M = function (arg1, arg2) {
var r1, r2, m, n;
try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }
try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
m = Math.pow(10, Math.max(r1, r2));
//动态控制精度长度
n = (r1 >= r2) ? r1 : r2;
return ((T(arg1, m) - T(arg2, m)) / m).toFixed(n);
}
//乘
ArtJS.T = function (arg1, arg2) {
var m = 0, s1 = arg1.toString(), s2 = arg2.toString();
try { m += s1.split(".")[1].length } catch (e) { }
try { m += s2.split(".")[1].length } catch (e) { }
return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m)
}
//除
ArtJS.D = function (arg1, arg2) {
var t1 = 0, t2 = 0, r1, r2;
try { t1 = arg1.toString().split(".")[1].length } catch (e) { }
try { t2 = arg2.toString().split(".")[1].length } catch (e) { }
with (Math) {
r1 = Number(arg1.toString().replace(".", ""))
r2 = Number(arg2.toString().replace(".", ""))
return (r1 / r2) * pow(10, t2 - t1);
}
}

//【日期加减天数,两日期相减】
//日期加天数
ArtJS.dateAddDays = function (primaryDay, addDays) {
var primaryDay = primaryDay.split("-");
if (primaryDay[1].indexOf("0") == 0) {
primaryDay[1] = parseInt(primaryDay[1].replace("0", ""));
}
primaryDay[1] = primaryDay[1] - 1;
var nDate = new Date(primaryDay[0], primaryDay[1], primaryDay[2]); // new Date(年,月,日) 出来的日期,月份加1
var millSeconds = Math.abs(nDate) + (addDays * 24 * 60 * 60 * 1000);
var rDate = new Date(millSeconds);
var year = rDate.getFullYear();
var month = rDate.getMonth() + 1;
if (month < 10) month = "0" + month;
var date = rDate.getDate();
if (date < 10) date = "0" + date;
return (year + "-" + month + "-" + date);
}
//日期减天数
ArtJS.dateRemoveDays = function (primaryDay, addDays) {
var primaryDay = primaryDay.split("-");
if (primaryDay[1].indexOf("0") == 0) {
primaryDay[1] = parseInt(primaryDay[1].replace("0", ""));
}

primaryDay[1] = primaryDay[1] - 1;
var nDate = new Date(primaryDay[0], primaryDay[1], primaryDay[2]);
var millSeconds = Math.abs(nDate) - (addDays * 24 * 60 * 60 * 1000);
var rDate = new Date(millSeconds);
var year = rDate.getFullYear();
var month = rDate.getMonth() + 1;
if (month < 10) month = "0" + month;
var date = rDate.getDate();
if (date < 10) date = "0" + date;
return (year + "-" + month + "-" + date);
}
//两日期相减
ArtJS.twoDateMinus = function (date1, date2) {
var d1 = date1.split("-");
if (d1[1].indexOf("0") == 0) {
d1[1] = parseInt(d1[1].replace("0", ""));
}
d1[1] = d1[1] - 1;
var rd1 = new Date(d1[0], d1[1], d1[2]);

var d2 = date2.split("-");
if (d2[1].indexOf("0") == 0) {
d2[1] = parseInt(d2[1].replace("0", "") - 1);
}
d2[1] = d2[1] - 1;
var rd2 = new Date(d2[0], d2[1], d2[2]);

var millSeconds = Math.abs(Math.abs(rd1) - Math.abs(rd2));

return Math.abs(millSeconds / (24 * 60 * 60 * 1000));
}
/*
Example:

var now = new Date();
var y = now.getFullYear();//获取时间中的年份
var m = now.getMonth()+1;//获取时间中的月份 月份 0-11 所以,需要加1
var d = now.getDate();//获取时间中的几号
//转换成可以用来加减,处理的格式 年-月-日
var formatNow = y + "-" + m + "-" + d;
var result = ArtJS.dateAddDays(formatNow, 11);
alert(result);
ArtJS.twoDateMinus('2016-09-30','2016-10-1')
*/

//【页面如果想使用终止冒泡,则在页面调用此方法;ArtJS_stopMaopao点击会终止冒泡;ArtJs_removeAfterDomClick dom点击会remove】添加类 ArtJS_stopMaopao 就会终止冒泡到 document
ArtJS.setStopMaopaoAfterDomClickRemove = function () {
setStopMaopaoAfterDomClick("ArtJS_stopMaopao", "ArtJs_removeAfterDomClick", "remove");
}
//内部方法,
function setStopMaopaoAfterDomClick(stopMaopaoClass, documentClickHideClass, removeOrHide) {
if ($.fn.on == null) {
$("." + stopMaopaoClass).live('click', function (event) {
ArtJS.stopMaopao(event);
});
}
else {
$(document).on('click', "." + stopMaopaoClass, function (event) {
ArtJS.stopMaopao(event);
});
}
$(document).click(function () {
if (documentClickHideClass != null) {
var dom = $("." + documentClickHideClass);
if (dom.length > 0) {
if (removeOrHide == "remove") {
dom.remove();
}
else {
dom.hide();
}
}
}

});
}
ArtJS.setStopMaopaoAfterDomClickHide = function () {
setStopMaopaoAfterDomClick("ArtJS_stopMaopao", "ArtJs_removeAfterDomClick", 'hide');
}
//【下方呈现带有三角形的div】
ArtJS.showWithTriDiv = function (single, cont) {
var those = $(single);
if ($("#triangleDiv_add").length > 0) {
$("#triangleDiv_add").remove();
}
var left = $(single).offset().left;
var top = $(single).offset().top + $(single).outerHeight() + 10;
$("body").append("<div id='triangleDiv_add' class='ArtJS_stopMaopao ArtJs_removeAfterDomClick' style=' position: absolute;border-radius: 4px;border: 1px solid #545050;box-shadow: 1px 1px 5px #d1d1d1; -webkit-box-shadow: 1px 1px 5px gray;left:" + left + "px;top:" + top + "px;'><em style='position: absolute; left: 10px;margin-top: -11px;width: 0; height: 0; border-right: 10px solid transparent; border-left: 10px solid transparent;border-bottom: 10px solid #1e242b; z-index: 5;'></em><i style='position: absolute;left: 10px; margin-top: -10px;width: 0; height: 0;border-right: 10px solid transparent; border-left: 10px solid transparent;border-bottom: 10px solid white;z-index: 5;'></i><div style=' padding: 20px;overflow: auto; max-height: 300px; word-wrap: break-word; word-break: break-all;white-space: normal;'>" + cont + "</div></div>");
}

//【弥补layer.msg只能同一时间使用一个,第二个会覆盖第一个的效果】
ArtJS.msg = function (cont, time, cssParam) {
if ($("#addedMsg").length>0) {
clearTimeout($("#addedMsg").attr("addedMsgAttr1"));
$("#addedMsg").remove();
}

$('body').append("<div id='addedMsg' style='display:table;'>" + cont + "</div>");
var defaultParam = { "z-index": 5000, "color": "white", "border-radius": "4px", "background-color": "#AD8585", "padding": "10px", "position": "fixed", "left": "50%", "top": "50%" };
var css = $.extend({}, defaultParam, cssParam);
var $msg = $("#addedMsg");

if (cssParam != null && cssParam.right != null) {
}
else {
css["margin-top"] = (0 - $msg.width() / 2) + "px";
}
if (cssParam != null && cssParam.right != null) {
}
else {
css["margin-left"] = (0 - $msg.width() / 2) + "px";
}

var index = setTimeout(function () {
$("#addedMsg").remove();
}, time);
$("#addedMsg").attr("addedMsgAttr1", index);
$msg.css(css);
}

a.ArtJS = ArtJS;

//===============================
// 【excel搜索】 依赖 json2.js jquery.js my97datepickeer
$.fn.useExcelFilter = function (submitOrAjaxSearch, cssObj) {
var those = this;
var defaultMainCss = { "width": "220px", "height": "350px", "position": "absolute", "z-index": "888", "border": "1px solid gray", "background-color": "white", "border-radius": "4px", "display": "none" };
$(".useExcelFilter_Main_div").remove(); //如果有先删除
var realMainCss = {}; $.extend(realMainCss, defaultMainCss, cssObj);
$("body").append("<div class='useExcelFilter_Main_div'><div class='useExcelFilter_Main_div_cont' style='margin-left:20px; margin-right:20px;'></div><div class='useExcelFilter_Main_div_bottom' style='position:absolute;bottom:15px;margin:0px auto;width:100%;text-align:center'><span style='color:white;padding-top:3px;padding-bottom:3px;padding-left:5px;padding-right:5px;border-radius:4px;cursor:pointer;color: #fff; background-color: #337ab7;border-color: #2e6da4;' id='excel_sure'>确定</span>&nbsp; &nbsp; <span style='background-color:red;color:white;padding-top:3px;padding-bottom:3px;padding-left:5px;padding-right:5px;border-radius:4px;cursor:pointer; color: #333; background-color:#E0C3C3; border-color: #ccc;' id='excel_sure_not' >取消</span></div></div>");
$('body').append("<style>.excel_li:hover,.useExcelFilter_Main_div_sortul li:hover{cursor:pointer;} .useExcelFilter_Main_div_ul{color:black;}.Excel_unsearched{display:none;} .useExcelFilter_Main_div_ul li{word-break: keep-all;white-space:nowrap;}</style>");
$(".useExcelFilter_Main_div").css(realMainCss);
$(".useExcelFilter_Main_div").click(function (event) {
var evt = event || window.event;
if (evt.stopPropagation) { //W3C阻止冒泡方法
evt.stopPropagation();
} else {
evt.cancelBubble = true; //IE阻止冒泡方法
}
});
$(this).click(function (event) {
var that = this;
if ($(that).hasClass("excelclicked")) {
$(".useExcelFilter_Main_div").hide();
return;
}
$(those).removeClass("excelclicked");
$(that).addClass("excelclicked");
var jsonDataMark = $(that).attr("jsonDataMark");
var jsonDataType = $(that).attr("jsonDataType");
var excelJsonStr = $("#excelJsonStr").val();

var excelJson = $.parseJSON(excelJsonStr);
var thisObjJson = null;
if (excelJson != null) {
thisObjJson = excelJson[jsonDataMark];
}

// var uls = "<ul class='useExcelFilter_Main_div_sortul' style='border-bottom:1px solid gray;'><li>升序&nbsp;↑</li><li>降序&nbsp;↓</li></ul>";
var uls = "";
//字符串
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "1") {
uls = uls + "<input type='text' style='box-shadow:none; height:30px;margin-top:20px; padding:5px 2px;width:100%;' placeholder='搜索' id='excel_search_text'/><div style='overflow-y:auto;height:" + (parseFloat(realMainCss.height.replace('px', '')) - 110) + "px;margin-top:10px;'><ul class='useExcelFilter_Main_div_ul'><li onclick='$(this).find(\":checkbox\").click()' class='excel_li fisrtli'><input type='checkbox' class='excel_cb_all excel_cb'/>&nbsp;<span>全选</span></li>";

$.each(thisObjJson, function (a, b) {
if (b.isChecked) {
uls = uls + "<li class='excel_li' onclick='$(this).find(\":checkbox\").click()'><input type='checkbox' class='excel_cb' value='" + b.dbVal + "' checked='checked'/>&nbsp;&nbsp;<span>" + b.showVal + "</span></li>";
}
else {
uls = uls + "<li class='excel_li' onclick='$(this).find(\":checkbox\").click()'><input type='checkbox' class='excel_cb' value='" + b.dbVal + "' />&nbsp;&nbsp;<span>" + b.showVal + "</span></li>";
}
});
uls = uls + "</ul></div>";
}
//金钱类型
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "2") {
uls = uls + "<div style='margin-top:20px;color:black;' class='execle_money_div'>金额范围&nbsp;<span style='color:white;padding-left:5px;padding-right:5px;border-radius:4px;cursor:pointer; color: #333; background-color:#E0C3C3; border-color: #ccc;' id='excel_typeclear'>清空</span><br/><input type='text' style='width:100%;height:30px;box-shadow:none;' placeholder='¥' class='inputmoney' value='" + thisObjJson[0].moneyMin + "'/> <br/> ↓<input type='text' style='width:100%;height:30px;box-shadow:none;' placeholder='¥' class='inputmoney' value='" + thisObjJson[0].moneyMax + "'/></div>";
}
//时间类型
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "3") {
uls = uls + "<div style='margin-top:20px;color:black;' class='execle_date_div'>日期范围&nbsp;<span style='color:white;padding-left:5px;padding-right:5px;border-radius:4px;cursor:pointer; color: #333; background-color:#E0C3C3; border-color: #ccc;' id='excel_typeclear'>清空</span><br/><input type='text' style='width:100%;height:30px;box-shadow:none;' class='Wdate'onFocus='WdatePicker()' value='" + thisObjJson[0].timeMin + "'/> <br/> ↓<input type='text' style='width:100%;height:30px;box-shadow:none;' class='Wdate' onFocus='WdatePicker()' value='" + thisObjJson[0].timeMax + "' /></div>";
}

//添加前移除已经存在的
$(".useExcelFilter_Main_div_cont").find("div,input,ul").remove().end().append(uls);

//字符串
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "1") {
if ($(".excel_cb:not('.excel_cb_all')").length == $(".excel_cb:not('.excel_cb_all'):checked").length) {
$(".excel_cb_all").attr("checked", "checked");
}
else {
$(".excel_cb_all").removeAttr("checked");
}
//全选按钮
$(".excel_cb").click(function (event) {
if ($(this).hasClass("excel_cb_all")) {
if ($(this).is(":checked")) {
$(".excel_cb").attr("checked", "checked");
}
else {
$(".excel_cb").removeAttr("checked");
}
}
var evt = event || window.event;
if (evt.stopPropagation) { //W3C阻止冒泡方法
evt.stopPropagation();
} else {
evt.cancelBubble = true; //IE阻止冒泡方法
}
});
//搜索框keyup
$("#excel_search_text").keyup(function () {
var xcont = $(this).val();
if (xcont == "") {
$(".useExcelFilter_Main_div_ul li").removeClass("Excel_unsearched");
return;
}
var lis = $(".excel_li").not(".fisrtli");
$.each(lis, function (c, d) {
if ($(d).find("span").text().indexOf(xcont) >= 0) {
$(d).removeClass("Excel_unsearched");
}
else {
$(d).addClass("Excel_unsearched");
}
});
});

}
//金钱类型
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "2") {
$(".inputmoney").keyup(function () {

var num = $(this).val();
//1.先去除空格,判断是否空值和非数
num = num + "";
num = num.replace(/[^\d.]/g, ""); //非数字和.的替换掉
num = num.replace(/^\./g, ""); //第一个不能是.
num = num.replace(".", "f").replace(/\./g, "").replace("f", "."); //仅保留第一个小数点
if (num == "") {
return;
}

//2.针对是否有小数点,分情况处理
var index = num.indexOf(".");
if (index == -1) {//无小数点
var reg = /(-?\d+)(\d{3})/;
while (reg.test(num)) {
num = num.replace(reg, "$1,$2");
}
} else {
var intPart = num.substring(0, index);
var pointPart = num.substring(index + 1, num.length);
var reg = /(-?\d+)(\d{3})/;
while (reg.test(intPart)) {
intPart = intPart.replace(reg, "$1,$2");
}
num = intPart + "." + pointPart;
}
$(this).val(num);

});
$(".inputmoney").focusout(function () {
var num = $(this).val();
//1.先去除空格,判断是否空值和非数
num = num + "";
num = num.replace(/[^\d.]/g, ""); //非数字和.的替换掉
num = num.replace(/^\./g, ""); //第一个不能是.
num = num.replace(".", "f").replace(/\./g, "").replace("f", "."); //仅保留第一个小数点
if (num == "") {
return;
}

//2.针对是否有小数点,分情况处理
var index = num.indexOf(".");
if (index == -1) {//无小数点
var reg = /(-?\d+)(\d{3})/;
while (reg.test(num)) {
num = num.replace(reg, "$1,$2");
}
} else {
var intPart = num.substring(0, index);
var pointPart = num.substring(index + 1, num.length);
var reg = /(-?\d+)(\d{3})/;
while (reg.test(intPart)) {
intPart = intPart.replace(reg, "$1,$2");
}
num = intPart + "." + pointPart;
}
$(this).val(num);
});
$("#excel_typeclear").click(function () {
$(".useExcelFilter_Main_div").find(":text").val("");
});
}
//时间类型
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "3") {
$("#excel_typeclear").click(function () {
$(".useExcelFilter_Main_div").find(":text").val("");
});
}

$(".useExcelFilter_Main_div").css({ "left": $(that).offset().left, "top": ($(that).offset().top + $(that).outerHeight()) });
$(".useExcelFilter_Main_div").show();

$("#excel_sure_not").unbind('click').click(function () {
$(document).click();
});
//
$("#excel_sure").unbind('click').click(function () {

//字符串
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "1") {

var checkedCBs = $(".excel_cb:not('.excel_cb_all'):visible:checked");

var str = ',';
$.each(checkedCBs, function (m, n) {
str = str + $(n).val() + ",";
});
$.each(thisObjJson, function (h, m) {
if (str.indexOf("," + m.dbVal + ",") >= 0) {
m.isChecked = true;
}
else {
m.isChecked = false;
}
});
$("#excelJsonStr").val(JSON.stringify(excelJson));
submitOrAjaxSearch();
}

//金钱
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "2") {
var inputMoney = $(".execle_money_div").find(".inputmoney");
thisObjJson[0].moneyMin = $(inputMoney[0]).val();
thisObjJson[0].moneyMax = $(inputMoney[1]).val();
debugger;
$("#excelJsonStr").val(JSON.stringify(excelJson));
submitOrAjaxSearch();
}
//时间
if (thisObjJson != null && thisObjJson.length > 0 && jsonDataType == "3") {
var inputDate = $(".execle_date_div").find(":text");
thisObjJson[0].timeMin = $(inputDate[0]).val();
thisObjJson[0].timeMax = $(inputDate[1]).val();
$("#excelJsonStr").val(JSON.stringify(excelJson));
submitOrAjaxSearch();
}

$(document).click();
});
//终止冒泡
var evt = event || window.event;
if (evt.stopPropagation) { //W3C阻止冒泡方法
evt.stopPropagation();
} else {
evt.cancelBubble = true; //IE阻止冒泡方法
}
});
$(document).click(function (event) {
$(".useExcelFilter_Main_div").hide();
$(those).removeClass("excelclicked");
});
}
/*
html

<input type="hidden" name="excelJsonStr" value='@后台excelJsonStr>' id='excelJsonStr' />

<td>
<div align="center" style='width: 80px;' >
销售人员
&nbsp;<img src="../images/excel.png" paixu="order_type" style=" cursor:pointer" class='useWidthSort' jsonDataMark ='xiaoShou' jsonDataType="1"/>
</div>
</td>
<td>
<div align="center" style='width: 150px;' >
发票申请人
&nbsp;<img src="../images/excel.png" paixu="order_type" style=" cursor:pointer" class='useWidthSort' jsonDataMark ='shenQingRen' jsonDataType="1"/>
</div>
</td>
<td >
<div align="center" style='width: 120px;' >
申请日期
&nbsp;<img src="../images/excel.png" paixu="order_type" style=" cursor:pointer" class='useWidthSort' jsonDataMark ='shenDate' jsonDataType="3"/>
</div>
</td>
<td>
<div align="center" style='width: 110px;' >
认款金额&nbsp;<img src="../images/excel.png" paixu="order_type" style=" cursor:pointer" class='useWidthSort' jsonDataMark ='renKuanMoney' jsonDataType="2"/></div>
</td>
后台


//后台接受从前台传递过来的excle数据值
string excelJsonStr = Request["excelJsonStr"];
System.Web.Script.Serialization.JavaScriptSerializer js = new System.Web.Script.Serialization.JavaScriptSerializer();
jsonModel4 jm = null;
if (!string.IsNullOrEmpty(excelJsonStr))
{
jm = js.Deserialize<jsonModel4>(excelJsonStr);
//销售
var xiaoShous = jm.xiaoShou.Where(t => t.isChecked == true);
//申请人
var shenWingRens = jm.shenQingRen.Where(t => t.isChecked == true);
//认款金额
List<basicExcelModel4> renMoney = jm.renKuanMoney.Where(t => t.moneyMin != "" || t.moneyMax != "").ToList();
//申请日期
List<basicExcelModel4> shenDate = jm.shenDate.Where(t => t.timeMin != "" || t.timeMax != "").ToList();
StringBuilder sbb = new StringBuilder();
#region 销售
foreach (var item in xiaoShous)
{
sbb.Append(item.dbVal + ",");
}
if (sbb.ToString() != "")
{
sb.Append(" and fpxsid in (" + sbb.ToString().Trim(',') + ")");
}
else//什么也没选 空
{
sb.Append(" and fpxsid in (-1)");
}
#endregion

sbb = new StringBuilder();
#region 申请人
foreach (var item in shenWingRens)
{
sbb.Append(item.dbVal + ",");
}
if (sbb.ToString() != "")
{
sb.Append(" and fpxzid in (" + sbb.ToString().Trim(',') + ")");
}
else//什么也没选 空
{
sb.Append(" and fpxzid in (-1)");
}
#endregion

sbb = new StringBuilder();
#region 认款金额
if (renMoney.Count>0)
{
string moneyMin = renMoney[0].moneyMin;
string moneyMax = renMoney[0].moneyMax;
if (moneyMin != "")
{
sb.Append(" and fapUsedMoney >=" + moneyMin.Replace(",", ""));
}
if (moneyMax != "")
{
sb.Append(" and fapUsedMoney <=" + moneyMin.Replace(",", ""));
}
}

#endregion

sbb = new StringBuilder();
#region 申请日期
if (shenDate.Count>0)
{
string dateMin = shenDate[0].timeMin;
string dateMax = shenDate[0].timeMax;
if (dateMin!="")
{
sb.Append(" and fpcreateddate >= '" + dateMin+"'");
}
if (dateMax != "")
{
sb.Append(" and fpcreateddate <= '" + dateMax + "'");
}
}
#endregion

}
else
{
MakeJsonStr();
}



void MakeJsonStr()
{
//要被序列化的对象
jsonModel4 jm = new jsonModel4();

//excel 销售
List<basicExcelModel4> xiaosohu = new List<basicExcelModel4>();
//excel 申请人
List<basicExcelModel4> xz = new List<basicExcelModel4>();

//获取excle数据源
DataSet ds = FapiaoManageRule.GetExcel();

if (ds != null && ds.Tables.Count > 0)
{
var rows = ds.Tables[0].Rows;
foreach (DataRow item in rows)
{
xiaosohu.Add(new basicExcelModel4()
{
dbVal = item["fpxsid"].ToString(),
isChecked = true,
showVal = item["xsname"].ToString()
});
}


var rows2 = ds.Tables[1].Rows;
foreach (DataRow item in rows2)
{
xz.Add(new basicExcelModel4() { dbVal = item["fpxzid"].ToString(), isChecked = true, showVal = item["xzname"].ToString() });
}
}
jm = new jsonModel4();
jm.xiaoShou = xiaosohu;
jm.shenQingRen = xz;
jm.renKuanMoney = new List<basicExcelModel4>() { new basicExcelModel4() { } };
jm.shenDate = new List<basicExcelModel4>() { new basicExcelModel4() { } };
System.Web.Script.Serialization.JavaScriptSerializer js = new System.Web.Script.Serialization.JavaScriptSerializer();
excelJsonStr = js.Serialize(jm);

}




class jsonModel4
{
public List<basicExcelModel4> xiaoShou { get; set; }
public List<basicExcelModel4> shenQingRen { get; set; }
public List<basicExcelModel4> renKuanMoney { set; get; }
public List<basicExcelModel4> shenDate { set; get; }
}
class basicExcelModel4
{

//1 字符串
public string dbVal = "";
public string showVal = "";
public bool isChecked = false;

//2 金钱
public string moneyMin = "";
public string moneyMax = "";

// 3 时间
public string timeMin = "";
public string timeMax = "";
}


*/
//【排序】
//【排序】
$.fn.useSort = function (afterDeal) {

var those = this;
//点击排序
$(this).click(function () {
var that = this;
var sort = $(that).attr("sort"); //排序标记
var sortStr = "";
debugger;
//如果是 升序排序
if (sort.indexOf("asc") >= 0) {
sortStr = sort.replace("asc", "desc");
$(that).attr("sort", sortStr);
}
//倒叙,或者 还没有排序
else {
sortStr = sort.replace("desc", "") + " asc ";
$(that).attr("sort", sortStr);
}
var focusedSorts = $(".focusedSort").not(that);
if (focusedSorts.length > 0) {
$.each(focusedSorts, function (x, y) {
$(y).attr("sort", $(y).attr("sort").replace("desc", "").replace("asc", ""));
});
}
focusedSorts.removeClass("focusedSort");
$(that).addClass("focusedSort");
$("#hiddenSortStr").val(sortStr);
afterDeal(that);
});
}
/*
<input type="hidden" name="hiddenSortStr" value="" id='hiddenSortStr'/>


$(".sortIcon").useSort(afterDealsort);

function afterDealsort(a) {
var sort = $(a).attr("sort");

$.each($(".sortIcon"), function () {
$(this).attr("src", "../images/details_open.png");
});

if (sort.indexOf("asc")>=0) {
$(a).attr("src", "../images/details_close.png");
}
else {
$(a).attr("src", "../images/details_open.png");
}

ajaxGetData();
}



后台

private string GetSort()
{
string sort = " order by a.statu asc, sort asc, a.autoid desc";
string hiddenSortStr = Request["hiddenSortStr"];
if (!string.IsNullOrEmpty(hiddenSortStr))
{
string sortField = hiddenSortStr.Replace("asc", "").Replace("desc", "").Trim();
string sortType = hiddenSortStr.IndexOf("asc")>=0 ?"asc":"desc";
switch (sortField)
{
case "zhuangtai":
if (sortType == "desc")
{
sort = " order by t.astatu desc, sort asc, aid desc";
}
else
{
sort = " order by t.astatu asc, sort asc, aid desc";
}
break;

case "liushui":
sort = " order by a.waternumber " + sortType;
break;
case "daoqi":
sort = " order by b.endDate " + sortType;
break;

case "kaishouju":
sort = " order by a.ksjdate " + sortType;
break;
case "shouju":
sort = " order by a.sydsjh " + sortType;
break;



}







}
return sort;
}

*/

})(window, jQuery);
/*
把window作为参数传入,据说好处 1 提高性能; 2 可以把window定义成a; 压缩js文件减少代码;
*/

</script>

ArtJS(原创)的更多相关文章

  1. 【原创分享·支付宝支付】HBuilder打包APP调用支付宝客户端支付

    前言 最近有点空余时间,所以,就研究了一下APP支付.前面很早就搞完APP的微信支付了,但是由于时间上和应用上的情况,支付宝一直没空去研究.然后等我空了的时候,发现支付宝居然升级了支付逻辑,虽然目前还 ...

  2. 【原创分享·微信支付】C# MVC 微信支付教程系列之现金红包

            微信支付教程系列之现金红包           最近最弄这个微信支付的功能,然后扫码.公众号支付,这些都做了,闲着无聊,就看了看微信支付的其他功能,发现还有一个叫“现金红包”的玩意,想 ...

  3. 【原创分享·微信支付】 C# MVC 微信支付教程系列之扫码支付

    微信支付教程系列之扫码支付                  今天,我们来一起探讨一下这个微信扫码支付.何为扫码支付呢?这里面,扫的码就是二维码了,就是我们经常扫一扫的那种二维码图片,例如,我们自己添 ...

  4. 【原创分享·微信支付】 C# MVC 微信支付教程系列之公众号支付

    微信支付教程系列之公众号支付         今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后再通 ...

  5. 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送

    微信支付之微信模板消息推送                    今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...

  6. [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率

    使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...

  7. GJM : C#设计模式汇总整理——导航 【原创】

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  8. 信息安全-5:RSA算法详解(已编程实现)[原创]

    转发注明出处:http://www.cnblogs.com/0zcl/p/6120389.html 背景介绍 1976年以前,所有的加密方法都是同一种模式: (1)甲方选择某一种加密规则,对信息进行加 ...

  9. Atitit.你这些项目不都是模板吗?不是原创  集成和整合的方式大总结

    Atitit.你这些项目不都是模板吗?不是原创  集成和整合的方式大总结 1.1. 乔布斯的名言:创新即整合(Creativity is just connecting things).1 1.2. ...

随机推荐

  1. iOS取证将如漫漫长夜

    日前因恐攻一案,FBI对一支已上锁的iPhone 5c束手无策,美国法院出具命令要求苹果配合,但被苹果公司执行长库克以维护安全及隐私为由悍然拒绝. 平心而论,各有其立场,但在一个犯罪案件之中,真的可以 ...

  2. Windows Server 2008 R2 配置Exchange 2010邮件服务器

    windows server 服务器系统搭建邮件服务器一般两种情况: 1:Winmail server 软件 2:Exchange 参考教程:http://www.cnblogs.com/zhongw ...

  3. 事件委托和this

    JavaScript不仅门槛低,而且是一门有趣.功能强大和非常重要的语言.各行各业的人发现自己最混乱的选择是JavaSscript编程语言.由于有着各种各样的背景,所以不是每个人都对JavaScrip ...

  4. javaSE第二十二天

    第二十二天    312 1:登录注册IO版本案例(掌握)    312 2:数据操作流(操作基本类型数据的流)(理解)    313 (1)定义:    313 (2)流对象名称    313 (3 ...

  5. Java学生管理系统项目案例

    这是一个不错的Java学生管理系统项目案例,希望能够帮到大家的学习吧. 分代码如下 package com.student.util; import java.sql.Connection; impo ...

  6. .NET环境配置(二)

    打开IIS服务器   首先在设置程序池 应用程序池 设置  ASP.NET v4.0         ASP.NET v4.0 Classic CLassic.NET AppPool DefaultA ...

  7. 在Linux命令行窗口中,怎么向上翻页?

    解决方法:本机环境:vmware linux Redhat9.0版本 使用:Shift + PageUp 和 Shift + PageDown向上和向下翻页

  8. php无法加载Memcache缓存模块问题及Memcache的安装

    今天早上去迁移网站发现打开网站报错 然后我去phpinfo.php看了一下,果然我的测试页里面有加载到Memcache这个模块,如下图: 这时候,既然发现了问题的所在我们就要去排查问题,当前这个问题呢 ...

  9. SQLServer附加数据库5120错误

    装有MSSQL的电脑 需要附加的数据库文件(*.mdf)及其日志文件(*.ldf) 1. 打开SQL Server Management Studio,并连接上数据库.右键"数据库" ...

  10. kettle的job

    1.首先创建一个job 2.拖拽组件形成下面的图 这里需要注意,在作业中的连线分为三类: 黄色锁的线:这个步骤执行之后,无论失败与否都会执行下一个步骤 绿色对号线:步骤执行成功了,才会执行下一个步骤. ...