DataList.html 47 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216
  1. <!DOCTYPE html>
  2. <html class="x-admin-sm">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="renderer" content="webkit">
  6. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  7. <meta name="viewport"
  8. content="width=device-width,user-scalable=yes, minimum-scale=0.4, initial-scale=0.8,target-densitydpi=low-dpi"/>
  9. <link rel="shortcut icon" href="/static/favicon.ico">
  10. <link rel="bookmark" href="/static/favicon.ico">
  11. <link rel="stylesheet" href="/static/css/font.css">
  12. <link rel="stylesheet" href="/static/css/xadmin.css">
  13. <script src="/static/js/jquery.min.js"></script>
  14. <script src="/static/js/jquery.cookie.min.js"></script>
  15. <script src="/static/lib/layui/layui.js" charset="utf-8"></script>
  16. <script type="text/javascript" src="/static/js/xadmin.js"></script>
  17. </head>
  18. <body>
  19. <div class="x-nav">
  20. <span class="layui-breadcrumb">
  21. <a href="">首页</a>
  22. <a><cite>数据展示</cite></a>
  23. </span>
  24. <a class="layui-btn layui-btn-normal" style="line-height:1.6em;margin-top:3px;float:right"
  25. onclick="location.reload()" title="刷新">
  26. <i class="layui-icon layui-icon-refresh" style="line-height:30px"></i>
  27. </a>
  28. </div>
  29. <div class="layui-fluid">
  30. <div class="layui-row" style="display: flex;">
  31. <!-- 传感器 选择 start-->
  32. <div style="width: 340px">
  33. <div class="layui-card">
  34. <div class="layui-card-body ">
  35. <form class="layui-form layui-col-space5" οnsubmit="return false;">
  36. <div class="layui-input-inline layui-show-xs-block">
  37. <input value="" type="text" id="D_T_sn" name="D_T_sn" placeholder="请输入 SN"
  38. autocomplete="off"
  39. class="layui-input"></div>
  40. <div class="layui-input-inline layui-show-xs-block">
  41. <input value="" type="text" id="D_Name" name="D_Name" placeholder="请输入 传感器名称"
  42. autocomplete="off"
  43. class="layui-input"></div>
  44. <div class="layui-input-inline layui-show-xs-block" style="width: 168px">
  45. <select id="Class_1" name="Class_1">
  46. <option value=0>所有分类</option>
  47. {{range $index, $elem := .Class_List}}
  48. <option value={{$elem.Id}}>{{$elem.T_name}}</option>
  49. {{end}}
  50. </select>
  51. </div>
  52. <div class="layui-input-inline layui-show-xs-block">
  53. <div class="layui-btn layui-btn-normal"
  54. onclick="get_DeviceSensor_list(0)">
  55. <i class="layui-icon">&#xe615;</i></div>
  56. </div>
  57. </form>
  58. <hr>
  59. </div>
  60. <div class="layui-card-body " style="margin-top: -20px">
  61. <div id="DeviceSensor_list" style="width: 98%; overflow: hidden;max-height: 616px;overflow-y: auto">
  62. <div style="color: #1E9FFF;text-align: center;font-size: 15px;margin-top: 150px">加载中...</div>
  63. </div>
  64. </div>
  65. <div class="layui-card-body ">
  66. <div style="height: 70px">
  67. <div class="layui-card-body " style="text-align: center">
  68. <div class="layui-input-inline layui-show-xs-block">
  69. <div class="layui-btn layui-btn-normal"
  70. onclick="Checkboxs_All()">
  71. <i class="layui-icon">全选择</i>
  72. </div>
  73. </div>
  74. <div class="layui-input-inline layui-show-xs-block">
  75. <div class="layui-btn layui-btn-normal"
  76. onclick="Checkboxs_Allno()">
  77. <i class="layui-icon">全取消</i>
  78. </div>
  79. </div>
  80. <div class="layui-input-inline layui-show-xs-block">
  81. <div class="layui-btn layui-btn-normal"
  82. onclick="Checkboxs_Allto()">
  83. <i class="layui-icon">反选</i>
  84. </div>
  85. </div>
  86. <div style="color: #1E9FFF;text-align: center" id="DeviceSensor_list_Pages_x"></div>
  87. </div>
  88. </div>
  89. </div>
  90. </div>
  91. </div>
  92. <!-- 传感器 选择 end-->
  93. <div style="padding-left: 15px; height: 100%;flex:1;">
  94. <div class="layui-card">
  95. <!-- 传感器数据时间选择 选择 start-->
  96. <div class="layui-card-body ">
  97. <div class="layui-form layui-col-space5" οnsubmit="return false;">
  98. <div class="layui-input-inline layui-show-xs-block">
  99. <div class="layui-btn layui-btn-normal"
  100. onclick="quick_1()">
  101. <i class="layui-icon">今天</i>
  102. </div>
  103. </div>
  104. <div class="layui-input-inline layui-show-xs-block">
  105. <div class="layui-btn layui-btn-normal"
  106. onclick="quick_2()">
  107. <i class="layui-icon">近一周</i>
  108. </div>
  109. </div>
  110. <div class="layui-input-inline layui-show-xs-block">
  111. <div class="layui-btn layui-btn-normal"
  112. onclick="quick_3()">
  113. <i class="layui-icon">近一月</i>
  114. </div>
  115. </div>
  116. <div class="layui-input-inline layui-show-xs-block">
  117. <div class="layui-btn layui-btn-normal"
  118. onclick="quick_4()">
  119. <i class="layui-icon">近一季度</i>
  120. </div>
  121. </div>
  122. <div class="layui-input-inline layui-show-xs-block">
  123. 自定义时间:
  124. </div>
  125. <div class="layui-inline layui-show-xs-block">
  126. <input class="layui-input" autocomplete="off" placeholder="开始日" name="Time_start"
  127. id="Time_start" lay-key="1"></div>
  128. <div class="layui-inline layui-show-xs-block">
  129. <input class="layui-input" autocomplete="off" placeholder="截止日" name="Time_end"
  130. id="Time_end" lay-key="2"></div>
  131. <div class="layui-input-inline layui-show-xs-block">
  132. <div class="layui-btn layui-btn-normal"
  133. onclick="get_DeviceSensor_data(0)">
  134. <i class="layui-icon">&#xe615;</i></div>
  135. </div>
  136. <div class="layui-input-inline layui-show-xs-block" style="float: right">
  137. <button class="layui-btn layui-btn-normal" id="importData">导入数据</button>
  138. <button class="layui-btn layui-btn-normal" id="exportData" onclick="exportData()">导出数据
  139. </button>
  140. <button class="layui-btn layui-btn-normal" onclick="F_moban()">导入模板说明</button>
  141. </div>
  142. </div>
  143. <hr>
  144. <div>
  145. <button class="layui-btn layui-btn-normal" onclick="selectAll()">全选</button>
  146. <button class="layui-btn layui-btn-normal" onclick="reverseSelect()">反选</button>
  147. <button class="layui-btn layui-btn-normal" onclick="noSelect()">全不选</button>
  148. <button class="layui-btn layui-btn-danger" onclick="deleteSelect()">删除</button>
  149. <button class="layui-btn layui-btn-danger" onclick="deleteSelectTime()">删除选择时间范围
  150. </button>
  151. </div>
  152. </div>
  153. <!-- 传感器数据时间选择 选择 end-->
  154. <div class="layui-card-body">
  155. <table class="layui-table ">
  156. <colgroup>
  157. <col width="100">
  158. <col>
  159. <col>
  160. <col>
  161. <col>
  162. <col>
  163. <col>
  164. </colgroup>
  165. <thead>
  166. <tr>
  167. <th>选择</th>
  168. <th style="width: 120px;">采集时间
  169. <button type="button" class="layui-btn-primary layui-btn-xs layui-btn-radius sort" onclick="SortButton()">
  170. <i class="layui-icon layui-icon-up"></i>
  171. </button>
  172. <button type="button" class="layui-btn-primary layui-btn-xs layui-btn-radius sort" onclick="SortButton()">
  173. <i class="layui-icon layui-icon-down"></i>
  174. </button>
  175. </th>
  176. <th>温度℃</th>
  177. <th>湿度%</th>
  178. <th>GPS</th>
  179. <th>录入时间</th>
  180. <th>操作</th>
  181. </tr>
  182. </thead>
  183. <tbody id="DeviceSensor_data">
  184. </tbody>
  185. </table>
  186. </div>
  187. <div class="layui-card-body " style="display: flex;justify-content: space-between">
  188. <!--按钮部分 start-->
  189. <div>
  190. <span>每页显示:</span>
  191. <select id="perPageSelect">
  192. <option value="10">10条/页</option>
  193. <option value="100">100条/页</option>
  194. <option value="300">300条/页</option>
  195. <option value="500">500条/页</option>
  196. <option value="800">800条/页</option>
  197. <option value="1000">1000条/页</option>
  198. <option value="2000">2000条/页</option>
  199. <option value="3000">3000条/页</option>
  200. <option value="4000">4000条/页</option>
  201. <option value="5000">5000条/页</option>
  202. </select>
  203. </div>
  204. <!--按钮部分 end-->
  205. <!--分页部分 start-->
  206. <div id="pageTool">
  207. </div>
  208. <!-- <input type="number" id="perPageInput" min="1" value="10">-->
  209. <!--分页部分 end-->
  210. </div>
  211. </div>
  212. </div>
  213. </div>
  214. <!--数据记录展示-->
  215. <div id="recordShow" style="display: none">
  216. <table class="layui-table">
  217. <colgroup>
  218. <col width="20px">
  219. <col width="20px">
  220. <col>
  221. <col>
  222. <col>
  223. <col>
  224. </colgroup>
  225. <thead>
  226. <tr>
  227. <th>温度</th>
  228. <th>湿度</th>
  229. <th>GPS</th>
  230. <th>操作人</th>
  231. <th>录入时间</th>
  232. <th>操作</th>
  233. </tr>
  234. </thead>
  235. <tbody id="recordTableBody"></tbody>
  236. </table>
  237. </div>
  238. </div>
  239. </body>
  240. <script>
  241. let uploadInst
  242. //获取GET
  243. function getPar(par) {
  244. //获取当前URL
  245. var local_url = document.location.href;
  246. //获取要取得的get参数位置
  247. var get = local_url.indexOf(par + "=")
  248. ;
  249. if (get == -1) {
  250. return false;
  251. }
  252. //截取字符串
  253. //截取字符串
  254. var get_par = local_url.slice(par.length + get + 1);
  255. //判断截取后的字符串是否还有其他get参数
  256. var nextPar = get_par.indexOf("&")
  257. ;
  258. if (nextPar != -1) {
  259. get_par = get_par.slice(0, nextPar);
  260. }
  261. return get_par;
  262. }
  263. function ChangeDiv(e) {
  264. // var divs = document.getElementsByClassName("ChangeDiv");
  265. // var len = divs.length;
  266. // for(var i=0;i<len;i++){
  267. // divs[i].style.border = "1px solid #ffffff";
  268. // }
  269. // e.style.border = "1px solid #ed0000";
  270. }
  271. // 今天
  272. function quick_1() {
  273. var myDate = new Date();
  274. y = myDate.getFullYear(); //获取当前年份(2位)
  275. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  276. d = myDate.getDate(); //获取当前日(1-31)
  277. console.log(y + "-" + m + "-" + d)
  278. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  279. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  280. $("#Time_start").val(Time_start)
  281. $("#Time_end").val(Time_end)
  282. get_DeviceSensor_data(0)
  283. }
  284. // 近一周
  285. function quick_2() {
  286. var myDate = new Date();
  287. y = myDate.getFullYear(); //获取当前年份(2位)
  288. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  289. d = myDate.getDate(); //获取当前日(1-31)
  290. console.log(y + "-" + m + "-" + d)
  291. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  292. $("#Time_end").val(Time_end)
  293. myDate = myDate.setDate(myDate.getDay() - 6);
  294. myDate = new Date(myDate);
  295. y = myDate.getFullYear(); //获取当前年份(2位)
  296. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  297. d = myDate.getDate(); //获取当前日(1-31)
  298. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  299. $("#Time_start").val(Time_start)
  300. get_DeviceSensor_data(0)
  301. }
  302. // 近一月
  303. function quick_3() {
  304. var myDate = new Date();
  305. y = myDate.getFullYear(); //获取当前年份(2位)
  306. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  307. d = myDate.getDate(); //获取当前日(1-31)
  308. console.log(y + "-" + m + "-" + d)
  309. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  310. $("#Time_end").val(Time_end)
  311. myDate = myDate.setDate(myDate.getDate() - 30);
  312. myDate = new Date(myDate);
  313. y = myDate.getFullYear(); //获取当前年份(2位)
  314. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  315. d = myDate.getDate(); //获取当前日(1-31)
  316. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  317. $("#Time_start").val(Time_start)
  318. get_DeviceSensor_data(0)
  319. }
  320. // 近一季度
  321. function quick_4() {
  322. var myDate = new Date();
  323. y = myDate.getFullYear(); //获取当前年份(2位)
  324. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  325. d = myDate.getDate(); //获取当前日(1-31)
  326. console.log(y + "-" + m + "-" + d)
  327. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  328. $("#Time_end").val(Time_end)
  329. myDate = myDate.setDate(myDate.getDate() - 30 * 3);
  330. myDate = new Date(myDate);
  331. y = myDate.getFullYear(); //获取当前年份(2位)
  332. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  333. d = myDate.getDate(); //获取当前日(1-31)
  334. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  335. $("#Time_start").val(Time_start)
  336. get_DeviceSensor_data(0)
  337. }
  338. layui.use(['laydate', 'form', 'element'],
  339. function () {
  340. var laydate = layui.laydate;
  341. //执行一个laydate实例
  342. laydate.render({
  343. elem: '#Time_start' //指定元素
  344. , type: 'datetime'
  345. });
  346. //执行一个laydate实例
  347. laydate.render({
  348. elem: '#Time_end' //指定元素
  349. , type: 'datetime'
  350. });
  351. var element = layui.element;
  352. element.length = 30
  353. });
  354. var T_name = ""
  355. var T_sn = ""
  356. var T_class_id = 0
  357. var T_id = 0
  358. var T_sn_T_id = ""
  359. var Time_start = ""
  360. var Time_end = ""
  361. var sort = "DESC"
  362. var DeviceSensor_lite = []
  363. var DeviceSensor_data = []
  364. var DeviceSensor_snid_list = ""
  365. /// --------------- 传感器列表
  366. // 页面 加载完成后执行
  367. window.onload = function () {
  368. console.log("页面 加载完成后执行")
  369. quick_1()
  370. get_DeviceSensor_list(0)
  371. }
  372. //获取div中所有的复选框 .value
  373. var checkboxs = document.getElementsByClassName("checkboxxx");
  374. function Checkboxs_All() {
  375. for (var i = 0; i < checkboxs.length; i++) {
  376. checkboxs[i].checked = true
  377. }
  378. }
  379. function Checkboxs_Allno() {
  380. for (var i = 0; i < checkboxs.length; i++) {
  381. checkboxs[i].checked = false
  382. }
  383. }
  384. function Checkboxs_Allto() {
  385. for (var i = 0; i < checkboxs.length; i++) {
  386. if (checkboxs[i].checked) {
  387. checkboxs[i].checked = false
  388. } else {
  389. checkboxs[i].checked = true
  390. }
  391. }
  392. }
  393. function Checkboxs_GetAll() {
  394. DeviceSensor_snid_list = ""
  395. for (var i = 0; i < checkboxs.length; i++) {
  396. if (checkboxs[i].checked) {
  397. DeviceSensor_snid_list = DeviceSensor_snid_list + checkboxs[i].value + "|"
  398. }
  399. }
  400. }
  401. function SortButton(){
  402. sort = sort === "DESC"? "ASC" : "DESC"
  403. get_DeviceSensor_data(0)
  404. }
  405. function get_DeviceSensor_list(page) {
  406. T_sn = $("#D_T_sn").val();
  407. T_name = $("#D_Name").val();
  408. T_class_id = $("#Class_1").val();
  409. $.ajax({
  410. type: 'POST',
  411. url: '/Data/Device_Sensor_List',//发送请求
  412. data: {
  413. User_tokey: $.cookie("User_tokey"),
  414. T_sn: T_sn,
  415. T_name: T_name,
  416. T_class_id: parseInt(T_class_id),
  417. page: page,
  418. page_z: 1000,
  419. },
  420. success: function (result) {
  421. console.log(result)
  422. if (result.Code == 200) {
  423. if (page == 0)
  424. $('#DeviceSensor_list').html("")
  425. // $('#DeviceSensor_list_Pages').html("")
  426. // $('#DeviceSensor_list_Pages_x').html("")
  427. DeviceSensor_lite = result.Data.DeviceSensor_lite
  428. if (DeviceSensor_lite.length == 0) {
  429. $('#DeviceSensor_list').html("<div style=\"color: #1E9FFF;text-align: center;font-size: 15px;margin-top: 150px\">没有设备</div>")
  430. return
  431. }
  432. Add_DeviceSensor_list(result.Data.DeviceSensor_lite) // 列表
  433. // Add_DeviceSensor_list_Pages(result.Data.Pages) // 分页
  434. $('#DeviceSensor_list_Pages_x').html(" 传感器 总数:" + result.Data.Num);
  435. if (result.Data.Page_size > result.Data.Page) {
  436. get_DeviceSensor_list(result.Data.Page + 1)
  437. }
  438. } else {
  439. }
  440. }
  441. });
  442. return false
  443. }
  444. //选择所有选择框
  445. let sensors = []
  446. function selectAll() {
  447. sensors = []
  448. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  449. $(e).prop('checked', true)
  450. })
  451. }
  452. //反选
  453. function reverseSelect() {
  454. sensors = []
  455. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  456. $(e).prop('checked', !$(e).prop('checked'))
  457. })
  458. }
  459. //全不选
  460. function noSelect() {
  461. sensors = []
  462. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  463. $(e).prop('checked', false)
  464. })
  465. }
  466. //删除所选择的内容
  467. function deleteSelect() {
  468. //获取选择的行
  469. sensors = []
  470. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  471. if ($(e).prop('checked')) {
  472. let t = {
  473. t_sn: $(e).attr('data-sn'),
  474. t_id: Number.parseInt($(e).attr('data-id')),
  475. create_time: ($(e).attr('data-createtime')),
  476. t_t: Number.parseFloat($(e).attr('data-tt')),
  477. t_rh: Number.parseFloat($(e).attr('data-trh')),
  478. t_site: $(e).attr('data-site'),
  479. }
  480. sensors.push(t)
  481. }
  482. })
  483. console.log(sensors)
  484. if (sensors.length == 0) {
  485. layui.layer.msg('没有选中要删除的记录哦!')
  486. return
  487. }
  488. layui.layer.confirm(`是否删除选中${sensors.length}条记录`, {title: '删除记录'}, function (index) {
  489. $.ajax({
  490. type: "POST",
  491. url: '/Data/Device_Sensor_List_Delete',
  492. data: JSON.stringify(sensors),
  493. cookie: $.cookie("User_tokey"),
  494. contentType: 'application/json;charset=utf-8',
  495. success: function (rlt) {
  496. if (rlt.Code == 200) {
  497. layui.layer.msg(`删除${sensors.length}条数据成功!`)
  498. get_DeviceSensor_data(0)
  499. } else {
  500. layui.layer.msg(rlt.Msg)
  501. }
  502. }
  503. })
  504. layui.layer.close(index);
  505. });
  506. }
  507. //删除选择时间范围
  508. function deleteSelectTime() {
  509. // 获取选择的行
  510. console.log("删除选中事件范围")
  511. const Time_start = $("#Time_start").val();
  512. const Time_end = $("#Time_end").val();
  513. console.log("删除选中事件范围", Time_start, Time_end)
  514. let checkboxes = $('.checkboxxx');
  515. let querys = {
  516. t_sn: [],
  517. t_id: [],
  518. time_start:Time_start,
  519. time_end:Time_end,
  520. };
  521. checkboxes.each(function () {
  522. if ($(this).is(':checked')) {
  523. const checkboxValue = $(this).val();
  524. const values = checkboxValue.split(',');
  525. const sn = values[0];
  526. const id = values[1];
  527. console.log(sn, id);
  528. querys.t_sn.push(sn);
  529. querys.t_id.push(id);
  530. }
  531. });
  532. if (querys.length === 0) {
  533. layui.layer.msg('没有选中要删除的记录哦!')
  534. }else {
  535. layui.layer.confirm(`是否删除选中时间: ${Time_start}-------${Time_end} 的数据`, function (index) {
  536. $.ajax({
  537. type: "POST",
  538. url: `/Data/Device_Sensor_List_Delete_Time`,
  539. data: JSON.stringify(querys),
  540. contentType: 'application/json;charset=utf-8',
  541. success: function (res) {
  542. console.log(res.Code)
  543. if (res.Code === 200) {
  544. layui.layer.msg(`成功删除 ${res.Data} 条数据`);
  545. get_DeviceSensor_data(0);
  546. } else {
  547. layui.layer.msg(res.Msg);
  548. }
  549. }
  550. });
  551. layui.layer.close(index);
  552. });
  553. }
  554. }
  555. //删除当前行,当当前行按钮被点击后
  556. function deleteOne(e) {
  557. e = $(e).parent().prevAll()
  558. e = e[e.length - 1]
  559. e = $(e).children()[0]
  560. // console.log(e, "==============")
  561. let t = {
  562. t_sn: $(e).attr('data-sn'),
  563. t_id: Number.parseInt($(e).attr('data-id')),
  564. create_time: ($(e).attr('data-createtime')),
  565. t_t: Number.parseFloat($(e).attr('data-tt')),
  566. t_rh: Number.parseFloat($(e).attr('data-trh')),
  567. t_site: $(e).attr('data-site'),
  568. }
  569. layui.layer.confirm(`是否删除选中 sn: ${t.t_sn} 1 条记录`, {title: '删除记录'}, function (index) {
  570. $.ajax({
  571. type: "POST",
  572. url: '/Data/Device_Sensor_List_Delete',
  573. data: JSON.stringify([t]),
  574. contentType: 'application/json;charset=utf-8',
  575. success: function (rlt) {
  576. if (rlt.Code == 200) {
  577. layui.layer.msg(`删除1条数据成功!`)
  578. get_DeviceSensor_data(0)
  579. } else {
  580. layui.layer.msg(rlt.Msg)
  581. }
  582. }
  583. })
  584. layui.layer.close(index);
  585. });
  586. }
  587. function Add_DeviceSensor_list(DS_lite) {
  588. for (let i = 0; i < DS_lite.length; i++) {
  589. if (T_id == 0) {
  590. T_id = DS_lite[i].T_id;
  591. T_sn_T_id = DS_lite[i].T_sn;
  592. get_DeviceSensor_data(0)
  593. }
  594. $('#DeviceSensor_list').append("" +
  595. "<div class=\"layui-col ChangeDiv\" onclick=\"ChangeDiv(this);T_id = " + DS_lite[i].T_id + ";T_sn_T_id = '" + DS_lite[i].T_sn + "';\" \n" +
  596. " style=\"border: 1px solid #ffffff;height: 52px;background-color: #fafafa;border-radius:5px;padding-top: 2px;margin-top: 6px;\">\n" +
  597. " <input type=\"checkbox\" id='sn_id_" + DS_lite[i].T_sn + "_" + DS_lite[i].T_id + "' name='checkboxxx' class='checkboxxx' value='" + DS_lite[i].T_sn + "," + DS_lite[i].T_id + "' style='float: left;width: 18px;height: 18px;margin-top: 16px;margin-left: 10px;'/>" +
  598. "<img style=\"float: left;width: 50px;margin: 0px 10px\" src=\"/static/images/温湿度传感器-1.png\"\n" +
  599. " height=\"50\"\n" +
  600. " width=\"40\"/>\n" +
  601. " <div style=\"float: left;\">\n" +
  602. " <div style=\"margin-top: 4px;font-size: 14px;height: 24px;\">" + DS_lite[i].T_name + "</div>\n" +
  603. " <div style=\"margin-top: -3px;font-size: 12px\">SN:" + DS_lite[i].T_sn + " [" + DS_lite[i].T_id + "]</div>\n" +
  604. " </div>\n" +
  605. " <div class=\"layui-card-header\"\n" +
  606. " style=\"float: right;padding-left: 0px;padding-top: 6px;color: #1E9FFF\">\n" +
  607. " \n" +
  608. " </div>\n" +
  609. " </div>")
  610. }
  611. }
  612. $('#perPageSelect').on('change', function () {
  613. let itemsPerPage = $(this).val();
  614. get_DeviceSensor_data(0, itemsPerPage); // 调用获取数据函数,传入新的每页条数
  615. });
  616. // 如果是输入框,则可能需要验证用户输入并做相应的处理
  617. $('#perPageInput').on('input', function () {
  618. let itemsPerPage = parseInt($(this).val());
  619. if (!isNaN(itemsPerPage)) {
  620. get_DeviceSensor_data(0, itemsPerPage);
  621. } else {
  622. alert('请输入有效的数字!');
  623. $(this).val('10'); // 重置为默认值
  624. }
  625. });
  626. function get_DeviceSensor_data(page, itemsPerPage) {
  627. if ($("#Time_start").val().length > 0) {
  628. Time_start = $("#Time_start").val();
  629. } else {
  630. Time_start = ""
  631. }
  632. if ($("#Time_end").val().length > 0) {
  633. Time_end = $("#Time_end").val();
  634. } else {
  635. Time_end = ""
  636. }
  637. Checkboxs_GetAll()
  638. var loading = layer.load(0, {
  639. shade: false,
  640. time: 99 * 1000
  641. });
  642. $.ajax({
  643. type: 'POST',
  644. url: 'Device_Sensor_Data_More',//发送请求
  645. data: {
  646. User_tokey: $.cookie("User_token"),
  647. Time_start: Time_start,
  648. Time_end: Time_end,
  649. T_snid: DeviceSensor_snid_list,
  650. sort: sort,
  651. page: page,
  652. page_z: itemsPerPage,
  653. },
  654. success: function (result) {
  655. layer.close(loading)
  656. if (result.Code == 200) {
  657. $('#DeviceSensor_data').html("")
  658. $('#DeviceSensor_data_Pages').html("")
  659. $('#DeviceSensor_data_Pages_x').html("")
  660. if (result.Data != null) {
  661. DeviceSensor_data = result.Data.list
  662. }
  663. if (DeviceSensor_data.length == 0) {
  664. $('#DeviceSensor_data').html("<div style=\"color: #1E9FFF;text-align: center;font-size: 15px;margin-top: 150px\">没有数据</div>")
  665. return
  666. }
  667. addDeviceSensorData(result.Data.list)
  668. addDeviceSensorDataPage(result.Data, itemsPerPage)
  669. } else {
  670. }
  671. }
  672. });
  673. return false
  674. }
  675. function f_Device_Sensor_Data_Pu_data(Sn, tap, num, id) {
  676. $.ajax({
  677. type: 'POST',
  678. url: 'Device_Sensor_Data_Pu_data',//发送请求
  679. data: {
  680. Sn: Sn,
  681. tap: tap,
  682. num: num,
  683. id: id,
  684. },
  685. success: function (result) {
  686. if (result.Code != 200) {
  687. layer.msg(result.Msg);
  688. }
  689. }
  690. });
  691. }
  692. function f_Device_Sensor_Data_Del_data(Sn, id) {
  693. $.ajax({
  694. type: 'POST',
  695. url: 'Device_Sensor_Data_Del_data',//发送请求
  696. data: {
  697. Sn: Sn,
  698. id: id,
  699. },
  700. success: function (result) {
  701. if (result.Code != 200) {
  702. layer.msg(result.Msg);
  703. }
  704. get_DeviceSensor_data(0)
  705. }
  706. });
  707. }
  708. function ShowElement(element) {
  709. var oldhtml = element.innerHTML;
  710. var newobj = document.createElement('input');
  711. //创建新的input元素
  712. newobj.type = 'text';
  713. //为新增元素添加类型
  714. console.log(oldhtml)
  715. console.log(element.dataset.th)
  716. console.log(element.dataset.sn)
  717. console.log(element.dataset.id)
  718. newobj.value = oldhtml
  719. newobj.onblur = function () {
  720. console.log(this.value)
  721. element.innerHTML = this.value ? this.value : oldhtml;
  722. if (element.dataset.th == 1) {
  723. f_Device_Sensor_Data_Pu_data(element.dataset.sn, "t_t", this.value, element.dataset.id)
  724. } else {
  725. f_Device_Sensor_Data_Pu_data(element.dataset.sn, "t_rh", this.value, element.dataset.id)
  726. }
  727. //当触发时判断新增元素值是否为空,为空则不修改,并返回原有值
  728. }
  729. element.innerHTML = '';
  730. element.appendChild(newobj);
  731. newobj.focus();
  732. }
  733. //分页添加
  734. function addDeviceSensorDataPage(pageInfo, itemsPerPage) {
  735. let start, end
  736. start = pageInfo.currentPage - 5 < 1 ? 1 : pageInfo.currentPage - 5
  737. end = pageInfo.currentPage + 5 > pageInfo.totalPage ? pageInfo.totalPage : pageInfo.currentPage + 5
  738. end = end + Math.abs(end - start - 10) > pageInfo.totalPage ? pageInfo.totalPage : end + Math.abs(end - start - 10)
  739. $('#pageTool').html('')
  740. $('#pageTool').append(`<span style="padding: 0 10px;color: #0bace6">共${pageInfo.totalPage}页 / 当前${pageInfo.currentPage}页 共${pageInfo.totalCount}条数据</span>`)
  741. //上一页
  742. if (pageInfo.previousPage) {
  743. $('#pageTool').append(`<button class="layui-btn layui-btn-primary layui-btn-sm" onclick="get_DeviceSensor_data(${pageInfo.currentPage - 1},${itemsPerPage})">上一页</button>`)
  744. } else {
  745. $('#pageTool').append(`<button class="layui-btn layui-btn-disabled layui-btn-primary layui-btn-sm">上一页</button>`)
  746. }
  747. //页码
  748. for (; start <= end; start++) {
  749. if (start == pageInfo.currentPage) {
  750. $('#pageTool').append(`<button class="layui-btn layui-btn-disabled layui-btn-primary layui-btn-sm">${start}</button>`)
  751. } else {
  752. $('#pageTool').append(`<button class="layui-btn layui-btn-primary layui-btn-sm" onclick="get_DeviceSensor_data(${start},${itemsPerPage})">${start}</button>`)
  753. }
  754. }
  755. //下一页
  756. if (pageInfo.nextPage) {
  757. $('#pageTool').append(`<button class="layui-btn layui-btn-primary layui-btn-sm" onclick="get_DeviceSensor_data(${pageInfo.currentPage + 1},${itemsPerPage})">下一页</button>`)
  758. } else {
  759. $('#pageTool').append(`<button class="layui-btn layui-btn-disabled layui-btn-primary layui-btn-sm">下一页</button>`)
  760. }
  761. }
  762. //添加设备数据
  763. function addDeviceSensorData(list) {
  764. let style
  765. for (let v of list) {
  766. if (v.t_t < v.t_tl || v.t_rh < v.t_rhl) {
  767. style = 'style="background-color: #a8f7ff'
  768. }
  769. if (v.t_t > v.t_tu || v.t_rh > v.t_rhu) {
  770. style = 'style="background-color: #ff8585'
  771. }
  772. $('#DeviceSensor_data').append(`
  773. <tr>
  774. <td><input type="checkbox" class="layui-form-checkbox" data-sn="${v.t_sn}" data-id="${v.t_id}" data-tt="${v.t_t}" data-trh="${v.t_rh}" data-site="${v.t_site}" data-createTime="${v.create_time}"/></td>
  775. <td ondblclick="changeData(this)" data-type="t_time">${v.t_time}</td>
  776. <td ondblclick="changeData(this)" data-type="t_t">${v.t_t}</td>
  777. <td ondblclick="changeData(this)" data-type="t_rh">${v.t_rh}</td>
  778. <td ondblclick="changeData(this)" data-type="t_site">${v.t_site}</td>
  779. <td ondblclick="changeData(this)" data-type="create_time">${v.create_time}</td>
  780. <td>
  781. <button class="layui-btn layui-btn-danger layui-btn-sm" onclick="deleteOne(this)">删除</button>
  782. <button class="layui-btn layui-bg-blue layui-btn-sm" onclick="copyAndAdds(this, '${v.t_sn}', ${v.t_id}, ${v.t_t}, ${v.t_rh}, '${v.t_site}', '${v.create_time}')">复制添加</button>
  783. </td>
  784. </tr>
  785. `)
  786. /*
  787. <button class="layui-btn layui-btn-normal layui-btn-sm" onclick="showRecord(this)">记录</button>
  788. */
  789. }
  790. }
  791. // 新增copyAndAdd函数实现复制并添加新行
  792. function copyAndAdds(button, t_sn, t_id, t_t, t_rh, t_site, create_time) {
  793. // 准备发送给后端的数据对象
  794. let dataToSend = {
  795. t_sn: t_sn,
  796. t_id: t_id,
  797. t_t: t_t,
  798. t_rh: t_rh,
  799. t_site: t_site,
  800. createTime: create_time
  801. };
  802. // 提交数据到后端
  803. $.ajax({
  804. url: '/Device/Device_Copy', // 替换为你的后端接口地址
  805. type: 'POST',
  806. contentType: 'application/json',
  807. data: JSON.stringify(dataToSend),
  808. success: function (response) {
  809. console.log("数据提交成功,响应:", response.Data);
  810. // 假设后端返回了新行ID或者其他需要的数据,这里可以根据需要处理response
  811. let newRowId = response.id; // 假设后端返回了新行的唯一ID
  812. // 根据后端返回的数据(如果有的话)来构造新行的HTML
  813. let newRowHtml = `
  814. <tr class="new-row" data-id="${response.id}" style="background-color: #f0f8ff; border-left: 4px solid #007bff;">
  815. <td>
  816. <input
  817. type="checkbox"
  818. class="layui-form-checkbox"
  819. data-sn="${response.Data.t_sn}"
  820. data-id="${response.Data.t_id}"
  821. data-tt="${response.Data.t_t}"
  822. data-trh="${response.Data.t_rh}"
  823. data-site="${response.Data.t_site}"
  824. data-createTime="${response.Data.createTime}"
  825. />
  826. </td>
  827. <td ondblclick="changeData(this)" data-type="t_time" style="color: #007bff;">${response.Data.createTime}</td>
  828. <td ondblclick="changeData(this)" data-type="t_t" style="color: #007bff;">${response.Data.t_t}</td>
  829. <td ondblclick="changeData(this)" data-type="t_rh" style="color: #007bff;">${response.Data.t_rh}</td>
  830. <td ondblclick="changeData(this)" data-type="t_site" style="color: #007bff;">${response.Data.t_site}</td>
  831. <td ondblclick="changeData(this)" data-type="create_time" style="color: #007bff;">${response.Data.createTime}</td>
  832. <td>
  833. <button class="layui-btn layui-btn-danger layui-btn-sm" onclick="deleteOne(this)">删除</button>
  834. <button class="layui-btn layui-bg-blue layui-btn-sm" onclick="copyAndAdds(this, '${t_sn}', ${t_id}, ${t_t}, ${t_rh}, '${t_site}', '${create_time}')">复制添加</button>
  835. <!-- 注意:此处可能不需要再提供复制添加按钮,因为数据已持久化 -->
  836. </td>
  837. </tr>
  838. `;
  839. // 在当前行的下一行兄弟元素(下一行)之前插入新行
  840. $(button).closest('tr').after(newRowHtml);
  841. // window.location.reload()
  842. // 这里可以添加成功后的其他操作,如提示用户、更新界面等
  843. },
  844. error: function (jqXHR, textStatus, errorThrown) {
  845. console.error("数据提交失败:", textStatus, errorThrown);
  846. // 处理错误情况,比如提示用户
  847. alert("数据提交失败,请重试!");
  848. }
  849. });
  850. }
  851. function showRecord(e) {
  852. e = $(e).parent().prevAll()
  853. e = e[e.length - 1]
  854. e = $(e).children()[0]
  855. console.log(e)
  856. $.ajax({
  857. type: "post",
  858. url: "/Data/Device_Sensor_Record",
  859. data: {
  860. sn: $(e).attr('data-sn'),
  861. tId: $(e).attr('data-id'),
  862. createTime: $(e).attr('data-createTime')
  863. },
  864. success: function (rlt) {
  865. if (rlt.Code === 200) {
  866. if (rlt.Data == null) {
  867. layui.layer.msg("没有数据!")
  868. return
  869. }
  870. for (let v of rlt.Data) {
  871. $('#tableBody').append(`
  872. <tr>
  873. <td>${v.t_t}</td>
  874. <td>${v.t_rh}</td>
  875. <td>${v.t_site}</td>
  876. <td>${v.t_uuid}</tdj>
  877. <td>${v.create_time}</td>
  878. <td>
  879. <button class="layui-btn layui-btn-normal" onclick="">更新</button>
  880. </td>
  881. </tr>
  882. `)
  883. }
  884. layui.layer.open({
  885. type: 1,
  886. area: ['1200px', '800px'],
  887. content: $('#recordShow'),
  888. isOutAnim: true
  889. })
  890. }
  891. }
  892. })
  893. }
  894. //双击表格改变值
  895. function changeData(even) {
  896. let e = $(even).prevAll()
  897. console.log(e)
  898. e = $(e[e.length - 1]).children()[0]
  899. // console.log(e)
  900. let t = {
  901. t_sn: $(e).attr('data-sn'),
  902. t_id: Number.parseInt($(e).attr('data-id')),
  903. create_time: ($(e).attr('data-createtime')),
  904. t_t: Number.parseFloat($(e).attr('data-tt')),
  905. t_rh: Number.parseFloat($(e).attr('data-trh')),
  906. t_site: $(e).attr('data-site'),
  907. }
  908. // console.log(t)
  909. let type = $(even).attr('data-type')
  910. // console.log(t,"============修改值==================")
  911. let input = $(`<input class="layui-input" type="text" value="${even.innerText}">`)
  912. input[0].onblur = function () {
  913. t["type"] = type
  914. t["value"] = $(this).val()
  915. t["User_tokey"] = $.cookie("User_tokey")
  916. if (t[type] == t.value) {
  917. } else {
  918. $.ajax({
  919. type: "POST",
  920. url: "/Data/Device_Sensor_Update",
  921. data: t,
  922. cookie: $.cookie("User_token"),
  923. success: function (rlt) {
  924. console.log(rlt)
  925. }
  926. })
  927. }
  928. console.log(t)
  929. even.innerHTML = this.value
  930. $(e).attr(`data-${type}`, $(this).val())
  931. }
  932. $(even).html('')
  933. $(even).append(input)
  934. input.focus()
  935. }
  936. //点击上传按钮
  937. layui.use('upload', function () {
  938. let upload = layui.upload;
  939. //执行实例
  940. let uploadInst = upload.render({
  941. elem: '#importData',
  942. url: '/Data/importData' //上传接口
  943. , accept: 'file',
  944. data: {
  945. User_tokey: $.cookie("User_tokey"),
  946. }
  947. , field: 'file'
  948. , done: function (res) {
  949. layui.layer.msg(res.Msg)
  950. // layui.layer.close(index)
  951. }
  952. , error: function () {
  953. //请求异常回调
  954. layui.layer.msg('上传错误!')
  955. }
  956. })
  957. })
  958. //导出数据
  959. function exportData() {
  960. if ($("#Time_start").val().length > 0) {
  961. Time_start = $("#Time_start").val();
  962. } else {
  963. Time_start = ""
  964. }
  965. if ($("#Time_end").val().length > 0) {
  966. Time_end = $("#Time_end").val();
  967. } else {
  968. Time_end = ""
  969. }
  970. let checkboxes = $('.checkboxxx');
  971. checkboxes.each(function () {
  972. if ($(this).is(':checked')) {
  973. var checkboxValue = $(this).val();
  974. var values = checkboxValue.split(',');
  975. var sn = values[0];
  976. var id = values[1];
  977. console.log(checkboxValue);
  978. if (checkboxValue) {
  979. $.ajax({
  980. type: "post",
  981. url: "/Data/EXportData",
  982. data: {
  983. T_snid: checkboxValue,
  984. Time_start: Time_start,
  985. Time_end: Time_end,
  986. },
  987. success: function (rlt) {
  988. console.log(rlt);
  989. if (rlt.Code === 200) {
  990. let link = document.createElement('a');
  991. link.href = rlt.Data;
  992. link.click(); // 触发点击事件以开始下载
  993. link.remove();
  994. }
  995. }
  996. });
  997. }
  998. }
  999. });
  1000. if (!checkboxes.is(':checked')) {
  1001. layui.layer.msg("请选择导出项");
  1002. }
  1003. }
  1004. function Add_DeviceSensor_data(DS_lite) {
  1005. console.log(DS_lite)
  1006. for (let i = 0; i < DS_lite.length; i++) {
  1007. style_s = ""
  1008. if (DS_lite[i].T_t < DS_lite[i].T_Tlower || DS_lite[i].T_rh < DS_lite[i].T_RHlower) {
  1009. style_s = " style='background-color: #a8f7ff' "
  1010. }
  1011. if (DS_lite[i].T_t > DS_lite[i].T_Tupper || DS_lite[i].T_rh > DS_lite[i].T_RHupper) {
  1012. style_s = " style='background-color: #ff8585' "
  1013. }
  1014. $('#DeviceSensor_data').append("" +
  1015. "<tr " + style_s + ">\n" +
  1016. // " <td>"+DS_lite[i].T_sn+"</td>\n" +
  1017. " <td>" + DS_lite[i].T_name + " [" + DS_lite[i].T_id + "]</td>\n" +
  1018. " <td ondblclick=\"ShowElement(this)\" data-th=1 data-sn=\"" + DS_lite[i].T_sn + "\" data-id=" + DS_lite[i].T_id + " >" + DS_lite[i].T_t + "</td>\n" +
  1019. " <td ondblclick=\"ShowElement(this)\" data-th=2 data-sn=\"" + DS_lite[i].T_sn + "\" data-id=" + DS_lite[i].T_id + " >" + DS_lite[i].T_rh + "</td>\n" +
  1020. " <td>" + DS_lite[i].T_tl + "~" + DS_lite[i].T_tu + "</td>\n" +
  1021. " <td>" + DS_lite[i].T_rhl + "~" + DS_lite[i].T_rhu + "</td>\n" +
  1022. " <td>" + DS_lite[i].T_time + "</td>\n" +
  1023. " <td> <span class='layui-btn layui-btn-danger' onclick='f_Device_Sensor_Data_Del_data(\"" + DS_lite[i].T_sn + "\"," + DS_lite[i].ID + ")'>删除</span>" + `<span class='layui-btn layui-btn-normal'>记录</span>` + "</td>\n" +
  1024. "</tr>")
  1025. }
  1026. }
  1027. function Add_DeviceSensor_data_Pages(Pages) {
  1028. for (let i = 0; i < Pages.length; i++) {
  1029. elem = Pages[i]
  1030. switch (elem.A) {
  1031. case 1:
  1032. $('#DeviceSensor_data_Pages').append("<a class=\"prev\" onclick='get_DeviceSensor_data(" + elem.V + ")' >&lt;&lt;</a>\n");
  1033. break;
  1034. case 2:
  1035. $('#DeviceSensor_data_Pages').append("<a class=\"num\" onclick='get_DeviceSensor_data(" + elem.V + ")' >" + elem.V + "</a>\n");
  1036. break;
  1037. case 3:
  1038. $('#DeviceSensor_data_Pages').append("<span class=\"current\">" + elem.V + "</span>\n");
  1039. break;
  1040. case 4:
  1041. $('#DeviceSensor_data_Pages').append("<a class=\"num\" onclick='get_DeviceSensor_data(" + elem.V + ")' >" + elem.V + "</a>\n");
  1042. break;
  1043. case 5:
  1044. $('#DeviceSensor_data_Pages').append("<a class=\"next\" onclick='get_DeviceSensor_data(" + elem.V + ")' >&gt;&gt;</a>\n");
  1045. break;
  1046. }
  1047. }
  1048. }
  1049. function get_DeviceSensor_Excel() {
  1050. if ($("#Time_start").val().length > 0) {
  1051. Time_start = $("#Time_start").val();
  1052. } else {
  1053. Time_start = ""
  1054. }
  1055. if ($("#Time_end").val().length > 0) {
  1056. Time_end = $("#Time_end").val();
  1057. } else {
  1058. Time_end = ""
  1059. }
  1060. Checkboxs_GetAll()
  1061. var loading = layer.load(0, {
  1062. shade: false,
  1063. time: 99 * 1000
  1064. });
  1065. $.ajax({
  1066. type: 'POST',
  1067. url: 'Device_Sensor_Data_Excel',//发送请求
  1068. data: {
  1069. User_tokey: $.cookie("User_tokey"),
  1070. Time_start: Time_start,
  1071. Time_end: Time_end,
  1072. T_snid: DeviceSensor_snid_list,
  1073. },
  1074. success: function (result) {
  1075. console.log(result)
  1076. layer.close(loading)
  1077. if (result.Code != 200) {
  1078. layer.msg(result.Msg);
  1079. return
  1080. }
  1081. window.location.href = result.Data;
  1082. }
  1083. });
  1084. return false
  1085. }
  1086. function F_moban() {
  1087. layer.open({
  1088. title: '导入模版'
  1089. , content: '1、导入模板需先导出然后根据导出模板进行填写导入<hr>' +
  1090. '2、导入文件名为 SN编号,如 2024xxxxxxxxxx.xlsx <hr>'
  1091. });
  1092. }
  1093. </script>
  1094. </html>