来点需要:我使用的数据库访问EF框架,但是,因为使用一个动态表来的统计报告中。单独是每天产生基于数据表,它是很难使用EF加盟前。所以我包装在两组数据库存取层的框内,一个是EF,一种是传统的ADO.NET。当设计使用动态表,我打电话跟ADO.NET进行数据库訪问操作了。

先看下View。这里我使用的是jquery easyUI里面的datagrid来做的报表。

例如以下:

单击选中日报:

年报例如以下:

  1. @model YKT.Model.SubCompanyReport
  2. @{
  3. ViewBag.Title = "分公司营收统计";
  4. Layout = "~/Views/Shared/Base.cshtml";
  5. }
  6. <style type="text/css">
  7. .datagrid-header-row .datagrid-cell-group
  8. {
  9. font-size:12px;
  10. font-weight:bold;
  11. }
  12. .datagrid-header td
  13. {
  14. font-weight:bold;
  15. }
  16. </style>
  17. <script src="../../Res/My97DatePicker/WdatePicker.js" type="text/javascript"></script>
  18. <script type="text/javascript">
  19. var cTime = "";
  20. var cUser = '<div style="text-align: left; float:left;">制表人:</div>';
  21. var dataDate = "";
  22. var yearMonthTitle = "";
  23. var dayMonthTitle = "";
  24. var tbTitle="";
  25.  
  26. //获取组织类型
  27. function getComponentType() {
  28. $("#sltCompany").empty();
  29. var url = "SubCompanyReport/GetComList"
  30. $.getJSON(url, function (data) {
  31. if (data != null) {
  32. $.each(data, function (i, item) {
  33. $("<option></option>")
  34. .val(item["COMPONENT_ID"])
  35. .text(item["COMPONENT_NAME"])
  36. .appendTo($("#sltCompany"));
  37. });
  38. }
  39. });
  40. }
  41.  
  42. //“查询”button。弹出查询框
  43. function flexiQuery() {
  44. if ($("#Start_Time").val() == "") {
  45. $.messager.alert('提示', '结算日期不能为空');
  46. }
  47. else {
  48. //将查询条件依照分隔符拼接成字符串
  49. var search = "Start_Time=" + $("#Start_Time").val() + "&&End_Time=" + $("#End_Time").val() + "&&sltCompany="
  50. + $("#sltCompany").val() + "&&sltReportType=" + $("#sltReportType").val();
  51.  
  52. var url = 'SubCompanyReport/GetData?' + search;
  53. cTime = '<div style="text-align: left; float:left;">制表时间:' + CurentDate() + '</div>';
  54.  
  55. var myDate = new Date();
  56. var startDate = StringToDate($("#Start_Time").val());
  57. dataDate = '<div style="text-align: left; float:left;">数据日期:';
  58. if ($("#sltReportType").val() == "0") {
  59. var endDate = StringToDate($("#End_Time").val());
  60. if (endDate == "") {
  61. dataDate += getDateByStr(startDate) + getWeek(startDate);
  62. }
  63. else {
  64. dataDate += getDateByStr(startDate) + getWeek(startDate) + " 到 " + getDateByStr(endDate) + getWeek(endDate);
  65. }
  66. dataDate += '</div>';
  67. $('#div1').panel('close');
  68. $('#div').panel('open');
  69. yearMonthTitle = "月累计";
  70. dayMonthTitle = "当日";
  71. //运行查询
  72. getData(url);
  73. }
  74. else if ($("#sltReportType").val() == "1") {
  75. $('#div1').panel('close');
  76. $('#div').panel('open');
  77. var v = getDateByStr(startDate);
  78. dataDate += v.substring(0, 8);
  79. dayMonthTitle = "当月";
  80. yearMonthTitle = "年累计";
  81. dataDate += '</div>';
  82. //运行查询
  83. getData(url);
  84. }
  85. else if ($("#sltReportType").val() == "2") {
  86. var v1 = getDateByStr(startDate);
  87. dataDate = v1.substring(0, 5);
  88. tbTitle = '公交总公司' + dataDate + '运营收入统计表(按分公司)';
  89. $('#div1').panel('open');
  90. $('#div').panel('close');
  91. dataDate += '</div>';
  92. //运行查询
  93. getData1(url);
  94. }
  95. }
  96. }
  97. $(function () {
  98. initData();
  99. $("#sltReportType").change(function () {
  100. if ($("#sltReportType").val() == "0") {
  101. $("#spnEndTime").css("display", "inline");
  102. } else {
  103. $("#spnEndTime").css("display", "none");
  104. }
  105. });
  106. });
  107. //初始化数据
  108. function initData() {
  109. var d = getDate(0);
  110. $("#Start_Time").val(d);
  111. //$("#End_Time").val(d);
  112. getComponentType();
  113. }
  114. //导出
  115. function outputExcel() {
  116. $.messager.confirm('操作提示', "确认导出数据吗?
  117.  
  118. ", function (r) {
  119. if (r) {
  120. //将查询条件依照分隔符拼接成字符串
  121. var search = "Start_Time=" + $("#Start_Time").val() + "&&End_Time=" + $("#End_Time").val() + "&&sltCompany=" + $("#sltCompany").val()
  122. + "&&sltReportType=" + $("#sltReportType").val();
  123. var url = 'SubCompanyReport/Export?' + search;
  124. window.location.href = url;
  125. }
  126. });
  127. }
  128. //日报表
  129. function getData(url) {
  130. var searchH = $("#divQuery").height();
  131. var h = document.documentElement.clientHeight - searchH - 26;
  132. //var w = document.documentElement.clientWidth;
  133. $('#flexigridData').datagrid({
  134. title: '分公司营收统计', //列表的标题
  135. iconCls: 'icon-site',
  136. // fit: true, //列表自己主动适应宽度
  137. width: 'auto',
  138. singleSelect: true,
  139. height: h,
  140. nowrap: false, //True 就会把数据显示在一行里。
  141. striped: true, //True 就把行条纹化。(即奇偶行使用不同背景色)
  142. collapsible: true, //可调节列宽
  143. //remoteSort: true, //定义是否从server给数据排序。
  144. url: url, //获取数据的url
  145.  
  146. toolbar: [],
  147. columns: [
  148. [{ title: '公交公司全日运营收入统计表(按分公司)', colspan: 17,align:'center'}], //第一行
  149. [{ title: '<div style="text-align: left; float:left;">制表单位:吴江公交总公司IC卡结算管理中心</div>', colspan: 8, headalign: 'left' },
  150.  { title: cTime, colspan: 7 }, { title: cUser, colspan: 2}], //第二行
  151. [{ title: dataDate, colspan: 17}], //第三行
  152. [{ title: '单位', rowspan: 3, field: 'ComponentName' }, { title: '投币收入', colspan: 4 }, { title: 'IC卡收入', colspan: 4 },
  153.  { title: 'IC卡收入占%', colspan: 4 }, { title: '合计', colspan: 4}], //第四行
  154. [{ title: dayMonthTitle, colspan: 2 }, { title: yearMonthTitle, colspan: 2 }, { title: dayMonthTitle, colspan: 2 },
  155. { title: yearMonthTitle, colspan: 2 }, { title: dayMonthTitle, colspan: 2 },
  156. { title: yearMonthTitle, colspan: 2 }, { title: dayMonthTitle, colspan: 2 }, { title: yearMonthTitle, colspan: 2}], //第五行
  157. [{ title: '人次(次)', field: 'tbrec' }, { title: '金额(元)', field: 'tbamt', width: 80 }, { title: '人次(次)', field: 'tbljrec' },
  158.  { title: '金额(元)', field: 'tbljamt', width: 80 },
  159. { title: '人次(次)', field: 'icrec' }, { title: '金额(元)', field: 'icamt', width: 80 }, { title: '人次(次)', field: 'icljrec' },
  160. { title: '金额(元)', field: 'icljamt', width: 80 },
  161. { title: '人次(次)', field: 'dayrecPer' }, { title: '金额(元)', field: 'dayAmtPer' }, { title: '人次(次)', field: 'monthrecPer' },
  162.  { title: '金额(元)', field: 'monthAmtPer' },
  163. { title: '人次(次)', field: 'dayrecTotal' }, { title: '金额(元)', field: 'dayAmtTotal',width:80 },
  164. { title: '人次(次)', field: 'monthrecTotal' }, { title: '金额(元)', field: 'monthAmtTotal',width:80}], //第六行
  165. ] //,
  166. //pagination: true, //在 datagrid 的底部显示分页栏。
  167.  
  168. //rownumbers: true //显示行号的列
  169. });
  170. //异步获取button
  171. //首先获取iframe标签的id值
  172. var iframeid = window.parent.$('#tabs').tabs('getSelected').find('iframe').attr("id");
  173.  
  174. //然后关闭AJAX对应的缓存
  175. $.ajaxSetup({
  176. cache: false
  177. });
  178.  
  179. //获取button值
  180. $.getJSON("../Home/GetToolbar", { id: iframeid }, function (data) {
  181. if (data == null) {
  182. return;
  183. }
  184. $('#flexigridData').datagrid("addToolbarItem", data);
  185.  
  186. });
  187. }
  188. //年报表
  189. function getData1(url) {
  190. var searchH = $("#divQuery").height();
  191. var h = document.documentElement.clientHeight - searchH - 26;
  192. //var w = document.documentElement.clientWidth;
  193. $('#flexigridData1').datagrid({
  194. title: '分公司营收统计', //列表的标题
  195. iconCls: 'icon-site',
  196. // fit: true, //列表自己主动适应宽度
  197. width: 'auto',
  198. singleSelect: true,
  199. height: h,
  200. nowrap: false, //True 就会把数据显示在一行里。
  201.  
  202. striped: true, //True 就把行条纹化。
  203.  
  204. (即奇偶行使用不同背景色)
  205. collapsible: true, //可调节列宽
  206. //remoteSort: true, //定义是否从server给数据排序。
  207.  
  208. url: url, //获取数据的url
  209.  
  210. toolbar: [],
  211. columns: [
  212. [{ title: tbTitle, colspan: 9, align: 'center'}], //第一行
  213. [{ title: '<span style="text">制表单位:吴江公交总公司IC卡结算管理中心</span>', colspan: 4, headalign: 'left' }, { title: cTime, colspan: 3 },
  214. { title: cUser, colspan: 2}], //第二行
  215. [{ title: '单位', rowspan: 2, field: 'ComponentName' }, { title: '投币收入', colspan: 2 }, { title: 'IC卡收入', colspan: 2 },
  216.  { title: 'IC卡收入占%', colspan: 2 }, { title: '合计', colspan: 2}], //第三行
  217. [{ title: '人次(次)', field: 'tbrec' }, { title: '金额(元)', field: 'tbamt', width: 120 }, { title: '人次(次)', field: 'icrec' },
  218.  { title: '金额(元)', field: 'icamt', width: 120 },
  219. { title: '人次(次)', field: 'yearrecPer' }, { title: '金额(元)', field: 'yearAmtPer', width: 120 }, { title: '人次(次)', field: 'yearrecTotal' },
  220.  { title: '金额(元)', field: 'yearAmtTotal', width: 120}]
  221. ] //,
  222. //pagination: true, //在 datagrid 的底部显示分页栏。
  223.  
  224. //rownumbers: true //显示行号的列
  225. });
  226. //异步获取按钮
  227. //首先获取iframe标签的id值
  228. var iframeid = window.parent.$('#tabs').tabs('getSelected').find('iframe').attr("id");
  229.  
  230. //然后关闭AJAX对应的缓存
  231. $.ajaxSetup({
  232. cache: false
  233. });
  234.  
  235. //获取按钮值
  236. $.getJSON("../Home/GetToolbar", { id: iframeid }, function (data) {
  237. if (data == null) {
  238. return;
  239. }
  240. $('#flexigridData1').datagrid("addToolbarItem", data);
  241.  
  242. });
  243. }
  244. </script>
  245. <div id="content" region="center" fit="true">
  246. <form id="form1">
  247. <div id="divQuery" style="padding: 5px; font-size: 12px;" title="查询列表" class="easyui-toolbar">
  248. <span>结算日期:</span><span>
  249. <input type="text" readonly="readonly" id="Start_Time" onclick="WdatePicker({maxDate:'#F{$dp.$D(\'End_Time\');}'})" />
  250. </span>
  251. <span id="spnEndTime">
  252. <input type="text" readonly="readonly" id="End_Time" onclick="WdatePicker({minDate:'#F{$dp.$D(\'Start_Time\');}'})" /></span>
  253. <span>公司类型:</span> <span><select id="sltCompany"></select></span>
  254. <span style=" margin:4px;">报表类型:</span><span><select id="sltReportType">
  255. <option value="0">日报</option>
  256. <option value="1">月报</option>
  257. <option value="2">年报</option>
  258. </select></span>
  259. <a href="javascript:flexiQuery()" class="easyui-linkbutton" data-options="iconCls:'icon-search'">查询</a>
  260. <a href="javascript:resetData()" class="easyui-linkbutton" data-options="iconCls:'icon-redo'"> 重置</a>
  261. </div>
  262. </form>
  263. <div id="div" class="easyui-panel" closed="true">
  264. <table id="flexigridData" style=" text-align:center">
  265. </table> </div>
  266. <div id="div1" class="easyui-panel" closed="true">
  267. <table id="flexigridData1" style=" text-align:center">
  268. </table>
  269. </div>
  270. </div>

控制器SubCompanyReportController例如以下:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.Mvc;
  6. using YKT.BLL;
  7. using YKT.Common;
  8. using YKT.Model;
  9. using System.IO;
  10. using Microsoft.Office.Interop.Excel;
  11. using System.Text;
  12.  
  13. namespace YKT.Controllers
  14. {
  15. public class CompanyClass
  16. {
  17. public string COMPONENT_ID { get; set; }
  18. public string COMPONENT_NAME { get; set; }
  19. }
  20.  
  21. public class SubCompanyReportController : Controller
  22. {
  23. #region 初始化
  24.  
  25. string ClassName = "SubCompanyReport"; //类名
  26. SubCompanyReportService _service;
  27. public SubCompanyReportController()
  28. {
  29. if (_service == null)
  30. {
  31. _service = new SubCompanyReportService();
  32. }
  33. }
  34.  
  35. ValidationErrors validationErrors = new ValidationErrors();
  36. OMOPERATIONLOGTB OperLog = new OMOPERATIONLOGTB();
  37.  
  38. #endregion
  39.  
  40. public ActionResult Index()
  41. {
  42. return View();
  43. }
  44. public JsonResult GetComList()
  45. {
  46. System.Data.DataTable data = _service.GetComList(1, -1, 0, "COMMON,BUS");
  47. List<CompanyClass> list = new List<CompanyClass>();
  48. if (data != null && data.Rows.Count > 0)
  49. {
  50. for (int i = 0; i < data.Rows.Count; i++)
  51. {
  52. list.Add(new CompanyClass { COMPONENT_ID = data.Rows[i][0].ToString(), COMPONENT_NAME = data.Rows[i][1].ToString() });
  53. }
  54. }
  55.  
  56. return Json(list, JsonRequestBehavior.AllowGet);
  57. }
  58.  
  59. [HttpPost]
  60. public JsonResult GetData(string sltReportType, string Start_Time, string End_Time, string sltCompany, string sltSubCompany)
  61. {
  62. List<SubCompanyReport> list = _service.GetTotalStatBySubCompany(sltReportType, Start_Time, End_Time);
  63.  
  64. return Json(list, JsonRequestBehavior.AllowGet);
  65. }
  66.  
  67. #region 导出
  68.  
  69. /// <summary>
  70. /// 数据导出
  71. /// </summary>
  72. /// <param name="search"></param>
  73. /// <returns></returns>
  74. public ActionResult Export(string sltReportType, string Start_Time, string End_Time, string sltCompany, string sltSubCompany)
  75. {
  76. List<SubCompanyReport> queryData = _service.GetTotalStatBySubCompany(sltReportType, Start_Time, End_Time);
  77. if (queryData == null || queryData.Count < 1)
  78. {
  79. Response.Write("<script> alert('没有要导出的数据!
  80.  
  81. '); </script>");
  82. return View("Index");
  83. }
  84.  
  85. int sheet;
  86. //结算起始时间
  87.  
  88. #region 导出Excel
  89.  
  90. string newpath = AppDomain.CurrentDomain.BaseDirectory + "Excel\\";
  91. string newFileName = newpath + "temp.xls";//+ Guid.NewGuid()
  92. if (!Directory.Exists(newpath))
  93. {
  94. Directory.CreateDirectory(newpath);
  95. }
  96. //string newpath = Server.MapPath(".") + @"\Excel\" + Guid.NewGuid() + ".xls";
  97. //调用的模板文件
  98. FileInfo mode = new FileInfo(Server.MapPath("~/xlsMode/营收报表.xls"));
  99. Application app = new Application();
  100. if (app == null)
  101. {
  102. return Json("当前用户电脑未安装EXCEL!", JsonRequestBehavior.AllowGet);
  103. }
  104. app.Application.DisplayAlerts = false;
  105. app.Visible = false;
  106.  
  107. if (mode.Exists)
  108. {
  109. Workbook tworkbook;
  110. Object missing = System.Reflection.Missing.Value;
  111.  
  112. app.Workbooks.Add(missing);
  113.  
  114. string beginTime = string.IsNullOrEmpty(Start_Time) ? string.Empty : DateTime.Parse(Start_Time).ToString("yyyyMMdd");
  115. string endTime = string.IsNullOrEmpty(End_Time) ?
  116.  
  117. string.Empty : DateTime.Parse(End_Time).ToString("yyyyMMdd");
  118.  
  119. //调用模板 写表头
  120. tworkbook = app.Workbooks.Open(mode.FullName, missing, missing, missing, missing, missing, missing, missing, missing,
  121. missing, missing, missing, missing, missing, missing);
  122. Worksheet tworksheet=new Worksheet();
  123. string ctitle = "制表时间:";
  124. string dataDateText = "数据日期:";
  125. switch (sltReportType)
  126. {
  127. case "0": //日报
  128. sheet = 8;
  129. tworksheet = (Worksheet)tworkbook.Sheets[sheet];
  130. if (!string.IsNullOrEmpty(beginTime) && string.IsNullOrEmpty(endTime))
  131. {
  132. dataDateText += ValueConvert.GetDatetimeString(beginTime);
  133. }
  134. else if (string.IsNullOrEmpty(beginTime) && !string.IsNullOrEmpty(endTime))
  135. {
  136. dataDateText += ValueConvert.GetDatetimeString(endTime);
  137. }
  138. else if (!string.IsNullOrEmpty(beginTime) && !string.IsNullOrEmpty(endTime))
  139. {
  140. dataDateText += ValueConvert.GetDatetimeString(beginTime) + " 到 " + ValueConvert.GetDatetimeString(endTime); ;
  141. }
  142. tworksheet.Cells[3, 9] = ctitle+ValueConvert.GetDatetimeString(DateTime.Now.ToString("yyyyMMdd"));
  143. tworksheet.Cells[4, 1] = dataDateText;
  144. break;
  145. case "1": //月报
  146. sheet = 9;
  147. tworksheet = (Worksheet)tworkbook.Sheets[sheet];
  148. tworksheet.Cells[1, 1] = "吴江市公交公司" + beginTime.Substring(4, 2) + "月份运营收入统计表(按分公司)";
  149. tworksheet.Cells[3, 9] = ctitle + ValueConvert.GetDatetimeString(DateTime.Now.ToString("yyyyMMdd"));
  150. break;
  151. case "2": //年报
  152. sheet = 10;
  153. tworksheet = (Worksheet)tworkbook.Sheets[sheet];
  154. tworksheet.Cells[1, 1] = "吴江市公交公司" + beginTime.Substring(0, 4) + "年运营收入统计表(按分公司)";
  155. tworksheet.Cells[3, 5] = ctitle + ValueConvert.GetDatetimeString(DateTime.Now.ToString("yyyyMMdd"));
  156. break;
  157. }
  158.  
  159. #region 写Excel的内容
  160.  
  161. if (queryData != null && queryData.Count > 0)
  162. {
  163. if (sltReportType == "0" || sltReportType == "1")
  164. {
  165. int m = 7;
  166. for (int i = 0; i < queryData.Count; i++)
  167. {
  168. tworksheet.Cells[m + i, 1] = queryData[i].ComponentName;
  169.  
  170. tworksheet.Cells[m + i, 2] = queryData[i].tbrec;
  171. tworksheet.Cells[m + i, 3] = queryData[i].tbamt;
  172. tworksheet.Cells[m + i, 4] = queryData[i].tbljrec;
  173. tworksheet.Cells[m + i, 5] = queryData[i].tbljamt;
  174.  
  175. tworksheet.Cells[m + i, 6] = queryData[i].icrec;
  176. tworksheet.Cells[m + i, 7] = queryData[i].icamt;
  177. tworksheet.Cells[m + i, 8] = queryData[i].icljrec;
  178. tworksheet.Cells[m + i, 9] = queryData[i].icljamt;
  179.  
  180. tworksheet.Cells[m + i, 10] = queryData[i].dayrecPer;
  181. tworksheet.Cells[m + i, 11] = queryData[i].dayAmtPer;
  182. tworksheet.Cells[m + i, 12] = queryData[i].monthrecPer;
  183. tworksheet.Cells[m + i, 13] = queryData[i].monthAmtPer;
  184.  
  185. tworksheet.Cells[m + i, 14] = queryData[i].dayrecTotal;
  186. tworksheet.Cells[m + i, 15] = queryData[i].dayAmtTotal;
  187. tworksheet.Cells[m + i, 16] = queryData[i].monthrecTotal;
  188. tworksheet.Cells[m + i, 17] = queryData[i].monthAmtTotal;
  189. }
  190. }
  191. else if (sltReportType == "2")
  192. {
  193. int m = 4;
  194. for (int i = 0; i < queryData.Count; i++)
  195. {
  196. tworksheet.Cells[m + i, 1] = queryData[i].ComponentName;
  197.  
  198. tworksheet.Cells[m + i, 2] = queryData[i].tbrec;
  199. tworksheet.Cells[m + i, 3] = queryData[i].tbamt;
  200. tworksheet.Cells[m + i, 4] = queryData[i].icrec;
  201. tworksheet.Cells[m + i, 5] = queryData[i].icamt;
  202.  
  203. tworksheet.Cells[m + i, 6] = queryData[i].yearrecPer;
  204. tworksheet.Cells[m + i, 7] = queryData[i].yearAmtPer;
  205. tworksheet.Cells[m + i, 8] = queryData[i].yearrecTotal;
  206. tworksheet.Cells[m + i, 9] = queryData[i].yearAmtTotal;
  207. }
  208. }
  209.  
  210. }
  211.  
  212. #endregion
  213.  
  214. tworksheet.SaveAs(newFileName, missing, missing, missing, missing, missing, missing, missing, missing, missing);
  215. tworkbook.Close(false, mode.FullName, missing);
  216. app.Workbooks.Close();
  217. app.Quit();
  218. tworkbook = null;
  219. app = null;
  220. //强制对全部代进行垃圾回收
  221. GC.Collect();
  222. }
  223.  
  224. System.IO.FileInfo file = new System.IO.FileInfo(newFileName);
  225. Response.Clear();
  226. Response.Charset = "GB2312";
  227. Response.ContentEncoding = System.Text.Encoding.Default;
  228. // 加入头信息,为"文件下载/另存为"对话框指定默认文件名称
  229. string nm = "分公司_" + mode.Name;
  230. Response.AddHeader("Content-Disposition", "attachment; filename=" +HttpUtility.UrlEncode(nm, Encoding.UTF8).ToString() );
  231. //Server.UrlEncode(mode.Name));
  232. // 加入头信息,指定文件大小。让浏览器可以显示下载进度
  233. Response.AddHeader("Content-Length", file.Length.ToString());
  234. // 指定返回的是一个不能被client读取的流。必须被下载
  235. Response.ContentType = "application/ms-excel";
  236. // 把文件流发送到client
  237. Response.WriteFile(file.FullName);
  238. // 停止页面的运行
  239. Response.End();
  240. return Json("导出成功!", JsonRequestBehavior.AllowGet);
  241.  
  242. #endregion
  243. }
  244.  
  245. #endregion
  246.  
  247. }
  248. }

版权声明:本文博客原创文章。博客,未经同意,不得转载。

5、VS2010+ASP.NET MVC4+EF4+JqueryEasyUI+Oracle该项目的开发——使用datagrid做报表的更多相关文章

  1. 3、VS2010+ASP.NET MVC4+EF4+JqueryEasyUI+Oracle项目开发之——用户登录

    近期因为项目赶着上线,一直没时间接着写博客,今天最终空出了时间.声名:我不是专业美工,所以界面问题,希望大家不要拍砖.登录界面例如以下: 在ASP.NET MVC中,要新增一个功能,我们首先要加入一个 ...

  2. ASP.NET MVC4中用 BundleCollection使用问题手记

    ASP.NET MVC4中对JS和CSS的引用又做了一次变化,在MVC3中我们这样引用资源文件: <link href="@Url.Content("~/Content/Si ...

  3. ASP.NET MVC4中用 BundleCollection

    来源:http://www.cnblogs.com/madyina/p/3702314.html ASP.NET MVC4中对JS和CSS的引用又做了一次变化,在MVC3中我们这样引用资源文件: &l ...

  4. ASP.NET MVC4中对JS和CSS的引用

    https://www.cnblogs.com/madyina/p/3702314.html ASP.NET MVC4中对JS和CSS的引用又做了一次变化,在MVC3中我们这样引用资源文件: < ...

  5. Asp.Net MVC4 + Oracle + EasyUI 学习 第二章

    Asp.Net MVC4 + Oracle + EasyUI 第二章 --使用Ajax提升网站性能 本文链接:http://www.cnblogs.com/likeli/p/4236723.html ...

  6. Asp.Net MVC4 + Oracle + EasyUI 学习 第一章

    Asp.Net MVC4 + Oracle + EasyUI  第一章 --操作数据和验证 本文链接:http://www.cnblogs.com/likeli/p/4234238.html 文章集合 ...

  7. Asp.Net MVC4 + Oracle + EasyUI 学习 序章

    Asp.Net MVC4 + Oracle + EasyUI  序章 -- 新建微软实例 本文链接:http://www.cnblogs.com/likeli/p/4233387.html 1.  简 ...

  8. Asp.Net MVC4 + Oracle + EasyUI + Bootstrap

    Asp.Net MVC4 + Oracle + EasyUI + Bootstrap --操作数据和验证 本文链接:http://www.cnblogs.com/likeli/p/4234238.ht ...

  9. Asp.Net MVC4 + Oracle + EasyUI + Bootstrap 1

    Asp.Net MVC4 + Oracle + EasyUI + Bootstrap 序章 Asp.Net MVC4 + Oracle + EasyUI + Bootstrap 序章 -- 新建微软实 ...

随机推荐

  1. 苹果公司的新的编程语言 Swift 高级语言(十一)--初始化类的析构函数的一个实例

    一 .实例的初始化          实例的初始化是准备一个类.结构或枚举的实例以便使用的过程. 初始化包含设置一个实例的每个存储属性为一个初始值,以及运行不论什么其他新的实例可以使用之前须要的设置或 ...

  2. Android从无知到有知——NO.7

    的ip拨号器在监听外拨电话时用的是系统提供的广播事件.而有些时候我们须要自己设定广播事件来满足特定的须要. Ok,今天整一下自己定义广播事件,我们用一个状态监測模块向一个3G模块发送报警信息来实现这一 ...

  3. 【程序猿助手】Emacs,最强的编辑器,之间的不

     wx_fmt=png" alt="" style="max-width:100%; height:auto!important"> 内容简单 ...

  4. linux 手动安装 oracle(转)

    Linux下安装Oracle 11 此为参照CU论坛上的高人写的文章并结合自身环境增加了点细节性的东西 操作系统 CentOS 4.2 2.6.11.8内核 安装准备 下载Oracle11安装包 内存 ...

  5. 四个漂亮CSS样式表

    1. 单像素的边框CSS表格 这是一个非常所用的表格风格. 源码: <!-- CSS goes in the document HEAD or added to your external st ...

  6. WPF技术触屏上的应用系列(一): 3D 图片(照片)墙、柱面墙(凹面墙或者叫远景墙、凸面墙或者叫近景墙)实现

    原文:WPF技术触屏上的应用系列(一): 3D 图片(照片)墙.柱面墙(凹面墙或者叫远景墙.凸面墙或者叫近景墙)实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7 ...

  7. 使用hadoop命令rcc生成Record 一个简单的方法来实现自己的定义writable对象

    hadoop 的bin文件夹以下一个rcc命令,网上介绍非常少.看了一下源代码.发现能够用来生成 java和c++的hadoop Record 类代码,比起自己直接实现writable 接口.简单非常 ...

  8. 在前端一定要了解的HTML,CSS知识

    盒子模型 每个盒子都有4个属性:内容(content).填充(padding).边框(border).边界(margin) 每个属性都有四个部分:上.右.下.左 块级元素 内联元素 块级元素(bloc ...

  9. SQL Server管理员专用连接的使用

    原文:SQL Server管理员专用连接的使用 作为一名DBA,经常会处理一些比较棘手的服务无响应问题,鉴于事态的严重性,多数DBA可能直接用“重启”大法,以便尽快的恢复生产环境的正常运转,但是多数情 ...

  10. Visual Studio中开发

    如何在Visual Studio中开发自己的代码生成器插件    Visual Studio是美国微软公司开发的一个基本完整的开发工具集,它包括了整个软件生命周期中所需要的大部分工具,如UML工具.代 ...