You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

338 lines
12 KiB

  1. @using Learun.Util
  2. @using Microsoft.Practices.ObjectBuilder2
  3. @model Learun.Application.TwoDevelopment.EducationalAdministration.StuInfoGraduateEntity
  4. <!DOCTYPE html
  5. PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  6. <!-- saved from url=(0051)http://localhost:8080/MDITIP/printOutContent.action -->
  7. <html xmlns="http://www.w3.org/1999/xhtml">
  8. <head>
  9. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
  10. <title>打印</title>
  11. <meta http-equiv="pragma" content="no-cache" />
  12. <meta http-equiv="cache-control" content="no-cache" />
  13. <meta http-equiv="expires" content="0" />
  14. <style>
  15. h4 {
  16. font-size: 23px;
  17. font-weight: 400;
  18. width: 50%;
  19. text-align: center;
  20. margin: 0 auto;
  21. }
  22. em {
  23. font-style: normal
  24. }
  25. b {
  26. margin-left: 20px;
  27. }
  28. input {
  29. border: 0;
  30. outline: none;
  31. cursor: pointer;
  32. }
  33. span {
  34. width: 30%;
  35. float: right;
  36. }
  37. table {
  38. width: 100%;
  39. border: 1px solid #222;
  40. border-top: none;
  41. border-bottom: none;
  42. border-collapse: collapse;
  43. border-spacing: 0px;
  44. }
  45. td {
  46. width: 14%;
  47. height: 44px;
  48. border: 1px solid #222;
  49. text-align: center;
  50. }
  51. .pageBreak {
  52. page-break-after: always;
  53. }
  54. .btn {
  55. width: 100px;
  56. height: 34px;
  57. line-height: 34px;
  58. text-align: center;
  59. margin: 30px auto;
  60. border: 1px solid #ccc;
  61. cursor: pointer;
  62. border-radius: 4px;
  63. }
  64. </style>
  65. </head>
  66. <body>
  67. <div id="print-content">
  68. <div class="header">
  69. <h4>长阳土家族自治县职业教育中心学生学籍卡</h4>
  70. </div>
  71. <p>
  72. <b><em>经办人:</em><input type="text" /></b>
  73. <span>打印日期:@ViewBag.PrintDate.ToShortDateString().Replace("/", "-")</span>
  74. </p>
  75. <!-- 页面记录信息 -->
  76. <table cellpadding="0" cellspacing="0">
  77. <tr>
  78. <td>姓名</td>
  79. <td>@Model.StuName</td>
  80. <td>性别</td>
  81. <td id="GenderNo">@Model.GenderNo</td>
  82. <td>出生日期</td>
  83. <td>@(Model.Birthday.HasValue ? Model.Birthday.Value.ToShortDateString().Replace("/", "-") : "")</td>
  84. <td rowspan="3"><img src="@Model.Photo" style="width: 80%;" alt="" /></td>
  85. </tr>
  86. <tr>
  87. <td>民族</td>
  88. <td id="NationalityNo">@Model.NationalityNo</td>
  89. <td>政治面貌</td>
  90. <td id="PartyFaceNo">@Model.PartyFaceNo</td>
  91. <td>班级</td>
  92. <td id="ClassNo">@Model.ClassNo</td>
  93. </tr>
  94. <tr>
  95. <td>学号</td>
  96. <td>@Model.StuNo</td>
  97. <td>学制</td>
  98. <td>@Model.EduSystem</td>
  99. <td>年级</td>
  100. <td>@Model.Grade</td>
  101. </tr>
  102. <tr>
  103. <td>学籍号</td>
  104. <td>@Model.StuCode</td>
  105. <td>专业</td>
  106. <td id="MajorNo">@Model.MajorNo</td>
  107. <td>身份证号</td>
  108. <td colspan="2">@Model.IdentityCardNo</td>
  109. </tr>
  110. <tr>
  111. <td>入学年月</td>
  112. <td>@(Model.EntranceDate.HasValue ? Model.EntranceDate.Value.ToShortDateString().Replace("/", "-") : "")</td>
  113. <td>入学方式</td>
  114. <td id="EntranceWay">@Model.EntranceWay</td>
  115. <td>学习形式</td>
  116. <td colspan="2" id="StudyModality">@Model.StudyModality</td>
  117. </tr>
  118. <tr>
  119. <td>家庭住址</td>
  120. <td colspan="3">@Model.MailAddress</td>
  121. <td>毕业时间</td>
  122. <td colspan="2">@(Model.FinishSchoolDate.HasValue ? Model.FinishSchoolDate.Value.ToShortDateString().Replace("/", "-") : "")</td>
  123. </tr>
  124. <tr>
  125. <td>异动情况</td>
  126. <td colspan="7"><input type="text" style="width: 90% ;" /></td>
  127. </tr>
  128. <tr>
  129. <td colspan="8">学业成绩</td>
  130. </tr>
  131. <tr>
  132. <td>学期</td>
  133. <td>课程名称</td>
  134. <td>成绩</td>
  135. <td>课程名称</td>
  136. <td>成绩</td>
  137. <td>课程名称</td>
  138. <td>成绩</td>
  139. </tr>
  140. </table>
  141. <div class="tablehtml">
  142. </div>
  143. <div class="btn">打印</div>
  144. </div>
  145. <script src="~/Content/jquery/plugin/fullcalendar/js/jquery-1.7.2.min.js"></script>
  146. <script src="~/Content/jquery/plugin/jqprint/jquery.jqprint-0.3.js"></script>
  147. <script>
  148. $('.btn').click(function () {
  149. window.print();
  150. });
  151. //绑定字典或源的值
  152. function GetDataSourceStr(code, value, text, valueStr, box) {
  153. $(box).html("");
  154. $.ajax({
  155. url: "/OnlineRegistrate/GetDataSourceMap?code=" + code,
  156. async: false,
  157. success: function (msg) {
  158. var msgObject = $.parseJSON(msg);
  159. if (msgObject.code == 200) {
  160. $.each(msgObject.data, function (i, item) {
  161. if (item[value] == valueStr) {
  162. $(box).html(item[text]);
  163. return;
  164. }
  165. });
  166. } else {
  167. layer.msg(msgObject.info);
  168. }
  169. },
  170. });
  171. return;
  172. };
  173. function GetDataItemStr(code, valueStr, box) {
  174. $(box).html("");
  175. $.ajax({
  176. url: "/OnlineRegistrate/GetDataItemMap?code=" + code,
  177. async: false,
  178. success: function (msg) {
  179. var msgObject = $.parseJSON(msg);
  180. if (msgObject.code == 200) {
  181. $.each(msgObject.data, function (i, item) {
  182. if (item["F_ItemValue"] == valueStr) {
  183. $(box).html(item["F_ItemName"]);
  184. return;
  185. }
  186. });
  187. } else {
  188. layer.msg(msgObject.info);
  189. }
  190. },
  191. });
  192. return;
  193. };
  194. GetDataItemStr("usersexbit", "@Model.GenderNo.ToString().ToLower()", "#GenderNo");
  195. GetDataItemStr("National", "@Model.NationalityNo", "#NationalityNo");
  196. GetDataItemStr("PolityStatus", "@Model.PartyFaceNo", "#PartyFaceNo");
  197. GetDataItemStr("StudyModality", "@Model.StudyModality", "#StudyModality");
  198. GetDataSourceStr("CdMajorInfo", "majorno", "majorname", "@Model.MajorNo", "#MajorNo");
  199. GetDataSourceStr("allbjqj", "classno", "classname", "@Model.ClassNo", "#ClassNo");
  200. $(window).load(function () {
  201. var listData1 = "@Model.StuScoreClassOneList.ToJson()";
  202. var listData = JSON.parse(listData1.replace(/&quot;/g, "\""));
  203. // 有六个学期
  204. var tableHtml = ""
  205. for (var j = 0; j < listData.length; j++) {
  206. tableHtml += "<table cellpadding='0' cellspacing='0' id='table" + j + "'>"
  207. var trNum = Math.ceil(listData[j].StuScoreList.length / 3)
  208. // 代表当前有几行 不确定是否每行都是满的
  209. var str = ""
  210. // 循环其行tr
  211. for (var i = 0; i < trNum; i++) {
  212. var std = ""
  213. str += "<tr>"
  214. // 开始循环6列 三门成绩
  215. // 循环3次td每次两个
  216. for (var k = 0; k < 2; k++) {
  217. if(k==0){
  218. // 如果是第一列
  219. if(i==0){
  220. // 如果是第一行的第一列
  221. std += `<td rowspan='5'>第${j + 1}学期</td>`
  222. }else{
  223. // 如果是不是第一行的第一列 则什么都不加
  224. }
  225. }else{
  226. // 如果不是第一列
  227. // i是第几行 i*3-1 (i-1)*3
  228. var startNum = (i)*3
  229. var endNum = (i+1)*3-1
  230. // 控制单元格从第几个开始,到底几个结束
  231. for(var tdsNum = startNum;tdsNum<=endNum;tdsNum++){
  232. // console.log(tdsNum,'222',listData[j].StuScoreList[3]['text'])
  233. // 有取到数据
  234. if(listData[j].StuScoreList[tdsNum]){
  235. std += `<td>${listData[j].StuScoreList[tdsNum]['LessonName']}</td><td>${listData[j].StuScoreList[tdsNum]['Score']}</td>`
  236. }else{
  237. // 无数据
  238. std +=`<td></td><td></td>`
  239. }
  240. }
  241. }
  242. }
  243. str += std + "</tr>"
  244. }
  245. tableHtml += str + "</table>"
  246. }
  247. setTimeout(() => {
  248. $(".tablehtml").html(tableHtml)
  249. },100)
  250. var yiH = $("#table0").height()
  251. var erH = $("#table1").height()
  252. var sanH = $("#table2").height()
  253. var siH = $("#table3").height()
  254. var wuH = $("#table4").height()
  255. var liuH = $("#table5").height()
  256. var siNumH = erH + sanH + siH
  257. // erDom.classList.add("pageBreak")
  258. $("#table1").addClass("pageBreak")
  259. // removeClass()
  260. if (yiH > 300) {
  261. $("#table0").addClass("pageBreak")
  262. $("#table5").addClass("pageBreak")
  263. }
  264. if (erH > 300) {
  265. $("#table0").addClass("pageBreak")
  266. $("#table1").removeClass("pageBreak")
  267. }
  268. if (sanH > 300) {
  269. $("#table1").removeClass("pageBreak")
  270. $("#table2").addClass("pageBreak")
  271. $("#table3").removeClass("pageBreak")
  272. $("#table4").removeClass("pageBreak")
  273. }
  274. if (siH > 400) {
  275. $("#table3").addClass("pageBreak")
  276. $("#table5").removeClass("pageBreak")
  277. $("#table4").removeClass("pageBreak")
  278. }
  279. if (wuH > 400) {
  280. $("#table4").addClass("pageBreak")
  281. liuDom.removeClass("pageBreak")
  282. }
  283. if (liuH > 400) {
  284. $("#table4").addClass("pageBreak")
  285. }
  286. if ((yiH + erH) > 200) {
  287. $("#table1").addClass("pageBreak")
  288. $("#table2").removeClass("pageBreak")
  289. $("#table3").removeClass("pageBreak")
  290. $("#table4").removeClass("pageBreak")
  291. $("#table5").removeClass("pageBreak")
  292. }
  293. if ((erH + sanH) > 600) {
  294. $("#table2").addClass("pageBreak")
  295. $("#table3").removeClass("pageBreak")
  296. $("#table4").removeClass("pageBreak")
  297. $("#table5").removeClass("pageBreak")
  298. }
  299. if ((sanH + siH) > 700) {
  300. // siDom.classList.add("pageBreak")
  301. $("#table4").removeClass("pageBreak")
  302. $("#table5").removeClass("pageBreak")
  303. }
  304. if ((siH + wuH) > 700) {
  305. $("#table4").addClass("pageBreak")
  306. $("#table5").removeClass("pageBreak")
  307. }
  308. if ((erH + sanH + siH) > 700) {
  309. $("#table2").addClass("pageBreak")
  310. $("#table3").removeClass("pageBreak")
  311. $("#table4").classList.add("pageBreak")
  312. }
  313. })
  314. </script>
  315. </body>
  316. </html>