1、先來看看效果css
2、前臺實現代碼html
一、引入相對應得css及Javascript文件jquery
<link href="~/Content/css/bootstrap.css" rel="stylesheet" />
<link href="~/Content/css/css.css" rel="stylesheet" />
<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Scripts/js/bootstrap.min.js"></script>
<script src="~/Scripts/js/datepicker/WdatePicker.js"></script>
<script src="~/Scripts/js/highcharts.js"></script>
<script src="~/Scripts/js/exporting.js"></script>ajax
<style type="text/css">
#AssayItems {
width: 100%;
margin:10px auto;
text-align:center;
vertical-align:middle;
border: 1px solid #F8F8FF;
display: none;
}
#Loading {
text-align: center;
display: none;
}
</style>json
二、統計按鈕觸發的事件bootstrap
$("#statiBtn").click(function () {
var Processid = $("#Process_PTR").children('option:selected').val();
ItemNo = $("#ItemNo").children('option:selected').val();
selectTit = $("#ItemNo").children('option:selected').text();
v = $("#Process_PTR").children('option:selected').text();
var begintime = $("#beginDate").val();
var lasttime = $("#lastDate").val();
LoadMEIRange(ItemNo,currRV);
$.ajax({
type: "POST",
url: '../StatisticsAssay/LoadCharts',
data: { 'Process_PTR': Processid, 'ItemNo': ItemNo, 'beginDate': begintime, 'lastDate': lasttime },
dataType: "json",
error: function (request) {
alert("Connection error");
},
beforeSend: function () {
//加載圖標
$("#Loading").show();
$("#AssayItems").hide();
},
success: function (result) {
$("#AssayItems").show();
var assalyData = result;
var assaly = eval('(' + assalyData + ')');
var assalyd = eval('(' + assaly + ')');
var timeArr = new Array();
var resArr = new Array();
$.each(assalyd.ds, function (i, idtem) {
timeArr[i] = idtem.Timer; // 時間值
});
$.each(assalyd.res, function (i, idtem) {
resArr[i] = idtem.Result; // 檢測結果
});
//加載曲線圖
LoadCharts(timeArr, resArr);
$("#Loading").hide();
}
});
//防止Ajax頁面提交後被刷新
//return false;
});ide
三、生成曲線圖
url
function LoadCharts(t,c)
{
Highcharts.setOptions({
lang: {
printChart: "打印圖表",
downloadJPEG: "下載JPEG 圖片",
downloadPDF: "下載PDF文檔",
downloadPNG: "下載PNG 圖片",
downloadSVG: "下載SVG 矢量圖",
exportButtonTitle: "導出圖片"
}
});
$('#AssayItems').highcharts({
chart: {
type:'line'
},
title: {
text:''+v+'化驗分析曲線圖',
x: -20
},
xAxis: {//X軸標籤
categories: t,
labels: {
rotation: -25,
style: {
fontSize: '10px',
fontFamily: 'Verdana, sans-serif'
}
}
},
yAxis: {
title: {
text: '統計數'
},
plotLines: [{
value: SXNums,
color: 'red',
dashStyle: 'shortdash',
width: 2,
label: {
text: 'MEI下範圍('+SXNums+')'
}
},
{
value: MIDNums,
color: 'green',
dashStyle: 'shortdash',
width: 2,
label: {
text: 'MEI中範圍(' + MIDNums + ')'
}
},
{
value:XXNums,
color: 'red',
dashStyle: 'shortdash',
width: 2,
label: {
text: 'MEI上範圍(' + XXNums + ')'
}
}]
},
colors:
[
'#00B2EE'
],
legend: {
layout: 'vertical',
align: 'right',
verticalAlign: 'middle',
borderWidth: 0
},
series: [
{
name: '' + selectTit + '',
data: c
}
]
});
}spa
2、後臺實現代碼htm
一、獲取Mei範圍
public ActionResult LoadMEIRange()
{
int itemno = 0;
int processid = 0;
string meiStr = "";
if (Request["itemno"] != null && Request["itemno"].ToString() != "")
{
itemno = Convert.ToInt32(Request["itemno"].ToString());
processid = Convert.ToInt32(Request["processid"].ToString());
}
else
{
itemno = 1;
processid = 1;
}
string meiSql = "select MeiRange from Assay_ProcessDetails where Process_PTR="+processid+" and ItemNo="+itemno+"";
DataTable dt = SqlHelper.QueryTable(meiSql);
if (dt.Rows.Count > 0)
{
meiStr = dt.Rows[0]["MeiRange"].ToString();
}
return Content(meiStr);
}
3、博客地址:http://www.cnblogs.com/Resources-blogs/p/6600107.html