博客列表 >固定表头/文本框只能输入数字

固定表头/文本框只能输入数字

岂几岂几
岂几岂几原创
2020年06月29日 15:09:091281浏览

滚动固定表头/文本框只能输入数字

1. 滚动固定表头

实现过程:

  • 创建两个表格,第一个只有表头信息(.head-tbl),第二个就是完整的数据表(.data-tbl)。
  • 使用定位的方式把.head-tbl表固定在顶部
    • .head-tbl表默认隐藏
    • 需要加z-index样式,且数值要比.data-tblz-index样式的数值大, 否则滚动时.head-tbl表将会被.data-tbl覆盖.
      1. <style>
      2. .head-tbl {
      3. display: none;
      4. /* 相对于浏览器窗口定位 */
      5. position: fixed;
      6. /* 可能是body元素的padding-top没有置为0, 所以需要微调距离顶部的距离为-10px才能贴住浏览器上方 */
      7. top: -10px;
      8. z-index: 2;
      9. }
      10. </style>
  • 编写<body>元素的onloadonresize事件的处理脚本, 在加载页面/页面大小发生变化时, 调整.head-tbl表的整体宽度和列宽度

    • 在使用定位的方式固定.head-tbl表后, 它的宽度和列宽都会发生变化(可能是脱离了原文档流). 所以需要触发事件调整其宽度.
    • 在<script>中的全局区域, 也需要触发一次调整整体宽度和列宽度的处理脚本. 相当于在进入页面时重调.
    • 整体宽度的调整, 获取当前窗口的宽度, 减去父容器的padding-leftpadding-right就能得到.head-tbl可布局的宽度.
    • 整体宽度的调整, 使用css()方法设置width样式即可.
      1. /* 加载完成/窗口大小变化时, 调整表格的宽度 */
      2. function resizeWidth() {
      3. $ = layui.jquery;
      4. console.log('redizing');
      5. /* 获取body元素的宽度(不包含纵向滚动条), 20是父容器左右内边距之和 */
      6. var width = document.body.clientWidth - 20 + "";
      7. $('table:first-of-type').css('width', width );
      8. // 调整固定表头列宽度
      9. resizeThWidth();
      10. }
    • 调整.head-tbl表的列宽, 每列列宽等于.data-tbltbody中第一行数据的对应列宽.
    • 获取.data-tble表的列宽, 务必要用td元素的offsetWidth属性获取, td.style.width获取不到的!
    • 设置.head-tble表的列宽, 无比要给td元素的width属性赋值, 给td.style.width赋值是无效的!
    • td.offsetWidth的值的是”内容区宽度+左右内边距+边框[不确定]”的和; 而td.width属性是设置内容区宽度的值. 所以td2.width = td1.offsetWidth - 左右边距 - 左右边框宽度.
      1. /* 根据表格中的数据, 调整固定表头的列宽度 */
      2. function resizeThWidth() {
      3. $ = layui.jquery;
      4. // 表头表中的<tr>元素列表
      5. var thHead = $('table:first-of-type > thead > tr');
      6. // 数据表的内容区第一行的<td>列表, 因为本实例中是两层表头, 所以有两个<tr>元素
      7. var thData = $('table:last-of-type > tbody > tr:first-of-type > td');
      8. // 遍历数据表的内容区第一行的<td>列表
      9. for(var i = 0; i < thData.length; i++) {
      10. $(thData[i]).css('padding');
      11. // 前7个td宽度设置给表头表的第一个tr对应的th的宽度
      12. if(i < 7) {
      13. ths = thHead[0].querySelectorAll('th');
      14. // 30为padding-left和padding-right, 1是找平的, 不懂为啥会多处1
      15. ths[i].width = thData[i].offsetWidth - 30 - 1;
      16. } else if(i >=7 && i < 16) { // 生于的td宽度设置给表头表的第二个tr对应的th的宽度
      17. ths = thHead[1].querySelectorAll('th');
      18. // 30为padding-left和padding-right, 1是找平的, 不懂为啥会多处1
      19. ths[i - 7].width = thData[i].offsetWidth - 30 - 1;
      20. }
      21. }
      22. }
    • 监听窗口滚动事件, 当窗口的滚动高度scrollTop大于.data-tbl表的offsetTop属性值(即.data-tbl表相对于窗口顶部的偏移量)时, 把.head-tbl表的display样式属性值设置为table; 否则设置为hidden.
      1. window.addEventListener("scroll", function(e) {
      2. /* console.log($('table:last-of-type')[0].offsetTop);
      3. console.log($('table:last-of-type')[0].scrollTop);
      4. console.log(document.documentElement.scrollTop);
      5. console.log('---'); */
      6. if(document.documentElement.scrollTop > $('table:last-of-type')[0].offsetTop) {
      7. console.log('show!');
      8. $('.head-tbl').css('display', 'table');
      9. // resizeThWidth();
      10. } else {
      11. console.log('hide!');
      12. $('.head-tbl').css('display', 'none');
      13. }
      14. }, false);

      2. 文本框只能输入数字

实现思路:

  • 文本框设置maxlength属性, 限制文本域能输入的字符数上限.
  • 文本框设置onpast="return false;"来屏蔽文本框粘贴功能. 避免通过粘贴向文本框中输入非数字字符.
  • 文本快设置style="ime-mode:disabled"样式来屏蔽中文输入, 但貌似并没有成功屏蔽.
    1. <input type="text" class="layui-input" name="zhipinshuhao" id="zhipinshuhao" placeholder="4位书号" maxlength="4" style="ime-mode:disabled" onpaste="return false;" onkeyup="this.value = check(this.value)" value="{{$book['zhipinshuhao']}}">
  • 为文本快添加keypress事件的处理脚本, 当发生按键点按事件时, 判断此次点按输入的字符是否是数字, 是则返回此次输入的字符; 否则不返回输入的字符(主要是过滤非中文的非法字符).
    1. <script>
    2. // 判断按键的编码是不是数字,如果不是,则不返回这个按键值(对中文无效)
    3. $('#zhipinshuhao').on('keypress', function() {
    4. // 本次点按的按键是回车
    5. if(event.keyCode == 13) {
    6. layer.msg(event.keyCode);
    7. }
    8. var val = event.target.value.toString();
    9. // 0的ascii码值是48; 9的ascii码值是57
    10. if(event.keyCode < 48 || event.keyCode > 57) {
    11. // 本次点按的按键对应的字符不是数字, 则不反悔输入的字符
    12. event.returnValue = false;
    13. } else {
    14. // 本次点按的按键对应的字符是数字, 返回输入的字符
    15. event.returnValue = true;
    16. }
    17. });
    18. </script>
  • 文本框设置onkeyup="this.value = check(this.value)", 实现在按键抬起时, 再验证一次输入的文本是否有非数字字符(主要是中文字符).
    1. <script>
    2. // 只能输入整数的双保险, 不做这个check,则可以输入中文字符
    3. function check(str) {
    4. var temp=""
    5. for(var i=0;i<str.length;i++)
    6. if(str.charCodeAt(i)>=48&&str.charCodeAt(i)<=57)
    7. temp+=str.charAt(i)
    8. return temp;
    9. }
    10. </script>

代码清单

  • 1- 滚动固定表头

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    6. <title>图书校对进度表</title>
    7. <link rel="stylesheet" href="/static/plugin/layui/css/layui.css">
    8. <script src="/static/plugin/layui/layui.js"></script>
    9. <style>
    10. body {
    11. padding: 0 10px 10px 10px;
    12. }
    13. h2 {
    14. margin-bottom: 20px;
    15. }
    16. tr, th {
    17. text-align: end;
    18. }
    19. .head-tbl {
    20. display: none;
    21. position: fixed;
    22. top: -10px;
    23. z-index: 2;
    24. }
    25. .data-tbl{
    26. z-index: 1;
    27. }
    28. .data-tbl td{
    29. padding: 5px;
    30. }
    31. .fun-area {
    32. width: 100%;
    33. display: flex;
    34. flex-flow: row wrap;
    35. justify-content: flex-end;
    36. }
    37. </style>
    38. </head>
    39. <body onload="resizeWidth()" onresize="resizeWidth()">
    40. <div style="text-align: center; color: #666;">
    41. <h2>图书校对进度表</h2>
    42. </div>
    43. <div class="layui-form">
    44. <div class="layui-form-item">
    45. <div class="layui-inline">
    46. <label for="search_words" class="layui-form-label">关键字</label>
    47. <div class="layui-input-inline">
    48. <input type="text" class="layui-input" name="search_words" id="search_words" value="{{$searchwords}}">
    49. </div>
    50. </div>
    51. <div class="layui-inline">
    52. <label for="status_0" class="layui-form-label">校对状态</label>
    53. <div class="layui-input-inline" style="width: 280px">
    54. <input type="radio" name="status" id="status_0" value= "0" title="未完成" {{$status=='0' ? 'checked' : ''}}>
    55. <input type="radio" name="status" id="status_1" value= "1" title="已完成" {{$status=='1' ? 'checked' : ''}}>
    56. <input type="radio" name="status" id="status_2" value= "2" title="全部" {{$status=='2' ? 'checked' : ''}}>
    57. </div>
    58. </div>
    59. <div class="layui-inline">
    60. <div class="layui-input-block">
    61. <button type="button" onclick="doQuery()" class="layui-btn layui-btn-success">搜索</button>
    62. </div>
    63. </div>
    64. </div>
    65. </div>
    66. <div class="fun-area">
    67. <button type="button" onclick="add()" class="layui-btn layui-btn-success">新增</button>
    68. </div>
    69. <table class="layui-table head-tbl">
    70. <thead style="text-align: center;">
    71. <tr>
    72. <th rowspan="2">序号</th>
    73. <th rowspan="2">丛书名</th>
    74. <th rowspan="2">书名</th>
    75. <th rowspan="2">书号</th>
    76. <th rowspan="2">版印次</th>
    77. <th rowspan="2">字数</th>
    78. <th rowspan="2">责任校对</th>
    79. <th colspan="3">一校</th>
    80. <th colspan="3">二校</th>
    81. <th colspan="3">三校</th>
    82. <th rowspan="2">操作</th>
    83. </tr>
    84. <tr>
    85. <th>校对员</th>
    86. <th>开始时间</th>
    87. <th>完成时间</th>
    88. <th>校对员</th>
    89. <th>开始时间</th>
    90. <th>完成时间</th>
    91. <th>校对员</th>
    92. <th>开始时间</th>
    93. <th>完成时间</th>
    94. </tr>
    95. </thead>
    96. </table>
    97. <table class="layui-table data-tbl">
    98. <thead style="text-align: center;">
    99. <tr>
    100. <th rowspan="2">序号</th>
    101. <th rowspan="2">丛书名</th>
    102. <th rowspan="2">书名</th>
    103. <th rowspan="2">书号</th>
    104. <th rowspan="2">版印次</th>
    105. <th rowspan="2">字数</th>
    106. <th rowspan="2">责任校对</th>
    107. <th colspan="3">一校</th>
    108. <th colspan="3">二校</th>
    109. <th colspan="3">三校</th>
    110. <th rowspan="2">操作</th>
    111. </tr>
    112. <tr>
    113. <th>校对员</th>
    114. <th>开始时间</th>
    115. <th>完成时间</th>
    116. <th>校对员</th>
    117. <th>开始时间</th>
    118. <th>完成时间</th>
    119. <th>校对员</th>
    120. <th>开始时间</th>
    121. <th>完成时间</th>
    122. </tr>
    123. </thead>
    124. <tbody>
    125. @if(!empty($books))
    126. @for($index = 0; $index < count($books); $index++)
    127. <tr>
    128. <td>{{$index + 1}}</td>
    129. <td>{{$books[$index]['congshuming']}}</td>
    130. <td>{{$books[$index]['zhipinmingcheng']}}</td>
    131. <td>{{$books[$index]['zhipinshuhao']}}</td>
    132. <td>{{$books[$index]['zhipinbanci'] . '/' . $books[$index]['zhipinyinci']}}</td>
    133. <td>{{$books[$index]['qianzishu']}}</td>
    134. <td>{{$admins[$books[$index]['zerenjiaodui']] ?? ''}}</td>
    135. <td>{{$admins[$books[$index]['yijiaorenyuan']] ?? ''}}</td>
    136. <td>{{$books[$index]['yijiaokaishishijian'] == 0 ? '' : Date('Y-m-d', $books[$index]['yijiaokaishishijian'])}}</td>
    137. <td>{{$books[$index]['yijiaowanchengshijian'] == 0 ? '' : Date('Y-m-d', $books[$index]['yijiaowanchengshijian'])}}</td>
    138. <td>{{$admins[$books[$index]['erjiaorenyuan']] ?? ''}}</td>
    139. <td>{{$books[$index]['erjiaokaishishijian'] == 0 ? '' : Date('Y-m-d', $books[$index]['erjiaokaishishijian'])}}</td>
    140. <td>{{$books[$index]['erjiaowanchengshijian'] == 0 ? '' : Date('Y-m-d', $books[$index]['erjiaowanchengshijian'])}}</td>
    141. <td>{{$admins[$books[$index]['sanjiaorenyuan']] ?? ''}}</td>
    142. <td>{{$books[$index]['sanjiaokaishishijian'] == 0 ? '' : Date('Y-m-d', $books[$index]['sanjiaokaishishijian'])}}</td>
    143. <td>{{$books[$index]['sanjiaowanchengshijian'] == 0 ? '' : Date('Y-m-d', $books[$index]['sanjiaowanchengshijian'])}}</td>
    144. <td>
    145. <button type="button" onclick="edit({{$books[$index]['id']}})" class="layui-btn layui-btn-success layui-btn-xs">修改</button>
    146. <button type="button" onclick="del({{$books[$index]['id']}})" class="layui-btn layui-btn-warm layui-btn-xs">删除</button>
    147. </td>
    148. </tr>
    149. @endfor
    150. @endif
    151. <!-- @for($index = 0; $index < 100; $index++)
    152. <tr>
    153. <td>row1</td>
    154. <td>row2</td>
    155. <td>row3</td>
    156. <td>row4</td>
    157. <td>row5</td>
    158. <td>row6</td>
    159. <td>row7</td>
    160. <td>row8</td>
    161. <td>row9</td>
    162. <td>row10</td>
    163. <td>row11</td>
    164. <td>row12</td>
    165. <td>row13</td>
    166. <td>row14</td>
    167. <td>row15</td>
    168. <td>row16</td>
    169. <td>row17</td>
    170. </tr>
    171. @endfor -->
    172. </tbody>
    173. </table>
    174. </body>
    175. <script>
    176. layui.use(['layer', 'form'], function() {
    177. layer = layui.layer;
    178. form = layui.form;
    179. $ = layui.jquery;
    180. $('input[name="search_words"]').on('keyup', function(e) {
    181. // 按下回车
    182. if(e.keyCode == 13 && $.trim(e.target.value) != '') {
    183. var status = $('input[type="radio"]:checked').val();
    184. window.location.href = '?searchWords=' + $.trim(e.target.value) + '&status=' + status;
    185. }
    186. });
    187. // 调整固定顶部的列宽大小
    188. resizeThWidth();
    189. window.addEventListener("scroll", function(e) {
    190. /* console.log($('table:last-of-type')[0].offsetTop);
    191. console.log($('table:last-of-type')[0].scrollTop);
    192. console.log(document.documentElement.scrollTop);
    193. console.log('---'); */
    194. if(document.documentElement.scrollTop > $('table:last-of-type')[0].offsetTop) {
    195. console.log('show!');
    196. $('.head-tbl').css('display', 'table');
    197. // resizeThWidth();
    198. } else {
    199. console.log('hide!');
    200. $('.head-tbl').css('display', 'none');
    201. }
    202. }, false);
    203. $('td, th').css('text-align', 'center');
    204. });
    205. function edit(id) {
    206. layer.open({
    207. type: 2,
    208. title: '修改图书',
    209. shadeClose: false,
    210. shade: 0.8,
    211. area: ['1048px', '680px'],
    212. content: '/reviser/revision/edit?id=' + id,
    213. btn: ['保存'],
    214. yes: function(index, layero) {
    215. var body = layer.getChildFrame('body', index);
    216. // 得到iframe页的窗口对象
    217. var iframeWin = window[layero.find('iframe')[0]['name']];
    218. // 执行iframe页的方法: iframeWin.要调用的方法名();
    219. iframeWin.save();
    220. }
    221. });
    222. }
    223. function add() {
    224. layer.open({
    225. type: 2,
    226. title: '新增图书',
    227. shadeClose: false,
    228. shade: 0.8,
    229. area: ['1048px', '680px'],
    230. content: '/reviser/revision/add',
    231. btn: ['保存'],
    232. yes: function(index, layero) {
    233. var body = layer.getChildFrame('body', index);
    234. // 得到iframe页的窗口对象
    235. var iframeWin = window[layero.find('iframe')[0]['name']];
    236. // 执行iframe页的方法: iframeWin.要调用的方法名();
    237. iframeWin.save();
    238. }
    239. });
    240. }
    241. function del(id) {
    242. layer.confirm('确定要删除该图书吗?', {icon: 3, title:'提示'}, function(index){
    243. $.get(
    244. '/reviser/revision/del?id=' + id
    245. , function(res) {
    246. if(res.status != undefined && res.status == 0) {
    247. layer.msg(res.message, {icon: 1});
    248. setTimeout(() => {
    249. window.location.reload();
    250. }, 1000);
    251. } else if(res.status != undefined) {
    252. return layer.alert(res.message, {icon: 2});
    253. } else {
    254. return layer.alert('提交保存失败', {icon: 2});
    255. }
    256. }
    257. , 'json'
    258. );
    259. layer.close(index);
    260. });
    261. }
    262. function doQuery() {
    263. var status = $('input[type="radio"]:checked').val();
    264. var searchWords = $.trim($('#search_words').val());
    265. window.location.href = '?searchWords=' + searchWords + '&status=' + status;//+ $.trim(event.target.value + '&status=' + status);
    266. }
    267. /* 根据表格中的数据, 调整固定表头的列宽度 */
    268. function resizeThWidth() {
    269. $ = layui.jquery;
    270. // 表头表中的<tr>元素列表
    271. var thHead = $('table:first-of-type > thead > tr');
    272. // 数据表的内容区第一行的<td>列表, 因为本实例中是两层表头, 所以有两个<tr>元素
    273. var thData = $('table:last-of-type > tbody > tr:first-of-type > td');
    274. // 遍历数据表的内容区第一行的<td>列表
    275. for(var i = 0; i < thData.length; i++) {
    276. $(thData[i]).css('padding');
    277. // 前7个td宽度设置给表头表的第一个tr对应的th的宽度
    278. if(i < 7) {
    279. ths = thHead[0].querySelectorAll('th');
    280. // 30为padding-left和padding-right, 1是找平的, 不懂为啥会多处1
    281. ths[i].width = thData[i].offsetWidth - 30 - 1;
    282. } else if(i >=7 && i < 16) { // 生于的td宽度设置给表头表的第二个tr对应的th的宽度
    283. ths = thHead[1].querySelectorAll('th');
    284. // 30为padding-left和padding-right, 1是找平的, 不懂为啥会多处1
    285. ths[i - 7].width = thData[i].offsetWidth - 30 - 1;
    286. }
    287. }
    288. }
    289. /* 加载完成/窗口大小变化时, 调整表格的宽度 */
    290. function resizeWidth() {
    291. $ = layui.jquery;
    292. console.log('redizing');
    293. var width = document.body.clientWidth - 20 + "";
    294. $('table:first-of-type').css('width', width );
    295. // 调整固定表头列宽度
    296. resizeThWidth();
    297. }
    298. </script>
    299. </html>
    • 2- 只能输入数字的文本框(书号文本框)
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>新增图书</title>
  7. <link rel="stylesheet" href="/static/plugin/layui/css/layui.css">
  8. <script src="/static/plugin/layui/layui.js"></script>
  9. <style>
  10. body {
  11. padding: 10px;
  12. }
  13. </style>
  14. </head>
  15. <body>
  16. <div class="layui-form">
  17. @csrf
  18. <div class="layui-form-item">
  19. <label for="zhipinmingcheng" class="layui-form-label">图书名称:</label>
  20. <div class="layui-input-block">
  21. <input type="text" class="layui-input" name="zhipinmingcheng" id="zhipinmingcheng">
  22. </div>
  23. </div>
  24. <div class="layui-form-item">
  25. <label for="congshuming" class="layui-form-label">丛书名:</label>
  26. <div class="layui-input-block">
  27. <input type="text" class="layui-input" name="congshuming" id="congshuming">
  28. </div>
  29. </div>
  30. <div class="layui-form-item">
  31. <label for="zhipinshuhao" class="layui-form-label">书号:</label>
  32. <div class="layui-input-inline">
  33. <input type="text" class="layui-input" name="zhipinshuhao" id="zhipinshuhao" placeholder="4位书号" maxlength="4" style="ime-mode:disabled" onpaste="return false;" onkeyup="this.value = check(this.value)">
  34. </div>
  35. </div>
  36. <div class="layui-form-item">
  37. <label for="zhipinbanci" class="layui-form-label">版次:</label>
  38. <div class="layui-input-inline">
  39. <input type="number" class="layui-input" name="zhipinbanci" id="zhipinbanci" value="1" min="1">
  40. </div>
  41. </div>
  42. <div class="layui-form-item">
  43. <label for="zhipinyinci" class="layui-form-label">印次:</label>
  44. <div class="layui-input-inline">
  45. <input type="number" class="layui-input" name="zhipinyinci" id="zhipinyinci" value="1" min="1">
  46. </div>
  47. </div>
  48. <div class="layui-form-item">
  49. <label for="qianzishu" class="layui-form-label">千字数:</label>
  50. <div class="layui-input-inline">
  51. <input type="number" class="layui-input" name="qianzishu" id="qianzishu" min="0">
  52. </div>
  53. </div>
  54. <div class="layui-form-item">
  55. <label for="zerenjiaodui" class="layui-form-label">责任校对:</label>
  56. <div class="layui-input-inline">
  57. <select name="zerenjiaodui" id="zerenjiaodui" class="layui-input">
  58. <option value=""></option>
  59. @if(!empty($admins))
  60. @foreach($admins as $admin)
  61. <option value="{{$admin['id']}}">{{$admin['real_name']}}</option>
  62. @endforeach
  63. @endif
  64. </select>
  65. </div>
  66. </div>
  67. <hr/>
  68. <div class="layui-form-item">
  69. <div class="layui-inline">
  70. <label for="yijiaorenyuan" class="layui-form-label">一校人员</label>
  71. <div class="layui-input-inline">
  72. <select name="yijiaorenyuan" id="yijiaorenyuan" class="layui-input">
  73. <option value=""></option>
  74. @if(!empty($admins))
  75. @foreach($admins as $admin)
  76. <option value="{{$admin['id']}}">{{$admin['real_name']}}</option>
  77. @endforeach
  78. @endif
  79. </select>
  80. </div>
  81. </div>
  82. <div class="layui-inline">
  83. <label for="yijiaokaishishijian" class="layui-form-label" style="width: 100px;">一校开始时间</label>
  84. <div class="layui-input-inline">
  85. <input type="text" class="layui-input" name="yijiaokaishishijian" id="yijiaokaishishijian">
  86. </div>
  87. </div>
  88. <div class="layui-inline">
  89. <label for="yijiaowanchengshijian" class="layui-form-label" style="width: 100px;">一校完成时间</label>
  90. <div class="layui-input-inline">
  91. <input type="text" class="layui-input" name="yijiaowanchengshijian" id="yijiaowanchengshijian">
  92. </div>
  93. </div>
  94. </div>
  95. <div class="layui-form-item">
  96. <div class="layui-inline">
  97. <label for="erjiaorenyuan" class="layui-form-label">二校人员</label>
  98. <div class="layui-input-inline">
  99. <select name="erjiaorenyuan" id="erjiaorenyuan" class="layui-input">
  100. <option value=""></option>
  101. @if(!empty($admins))
  102. @foreach($admins as $admin)
  103. <option value="{{$admin['id']}}">{{$admin['real_name']}}</option>
  104. @endforeach
  105. @endif
  106. </select>
  107. </div>
  108. </div>
  109. <div class="layui-inline">
  110. <label for="erjiaokaishishijian" class="layui-form-label" style="width: 100px;">二校开始时间</label>
  111. <div class="layui-input-inline">
  112. <input type="text" class="layui-input" name="erjiaokaishishijian" id="erjiaokaishishijian">
  113. </div>
  114. </div>
  115. <div class="layui-inline">
  116. <label for="erjiaowanchengshijian" class="layui-form-label" style="width: 100px;">二校完成时间</label>
  117. <div class="layui-input-inline">
  118. <input type="text" class="layui-input" name="erjiaowanchengshijian" id="erjiaowanchengshijian">
  119. </div>
  120. </div>
  121. </div>
  122. <div class="layui-form-item">
  123. <div class="layui-inline">
  124. <label for="sanjiaorenyuan" class="layui-form-label">三校人员</label>
  125. <div class="layui-input-inline">
  126. <select name="sanjiaorenyuan" id="sanjiaorenyuan" class="layui-input">
  127. <option value=""></option>
  128. @if(!empty($admins))
  129. @foreach($admins as $admin)
  130. <option value="{{$admin['id']}}">{{$admin['real_name']}}</option>
  131. @endforeach
  132. @endif
  133. </select>
  134. </div>
  135. </div>
  136. <div class="layui-inline">
  137. <label for="sanjiaokaishishijian" class="layui-form-label" style="width: 100px;">三校开始时间</label>
  138. <div class="layui-input-inline">
  139. <input type="text" class="layui-input" name="sanjiaokaishishijian" id="sanjiaokaishishijian">
  140. </div>
  141. </div>
  142. <div class="layui-inline">
  143. <label for="sanjiaowanchengshijian" class="layui-form-label" style="width: 100px;">三校完成时间</label>
  144. <div class="layui-input-inline">
  145. <input type="text" class="layui-input" name="sanjiaowanchengshijian" id="sanjiaowanchengshijian">
  146. </div>
  147. </div>
  148. </div>
  149. </div>
  150. </body>
  151. <script>
  152. layui.use(['layer', 'form', 'laydate'], function() {
  153. layer = layui.layer;
  154. form = layui.form;
  155. $ = layui.jquery;
  156. var laydate = layui.laydate;
  157. //执行laydate实例
  158. var dateItem = ['#yijiaokaishishijian', '#erjiaokaishishijian', '#sanjiaokaishishijian', '#yijiaowanchengshijian', '#erjiaowanchengshijian', '#sanjiaowanchengshijian'];
  159. dateItem.forEach(function(item, index) {
  160. laydate.render({
  161. elem: item //指定元素
  162. });
  163. });
  164. // 判断按键的编码是不是数字,如果不是,则不返回这个按键值(对中文无效)
  165. $('#zhipinshuhao').on('keypress', function() {
  166. if(event.keyCode == 13) {
  167. layer.msg(event.keyCode);
  168. }
  169. var val = event.target.value.toString();
  170. if(event.keyCode < 48 || event.keyCode > 57) {
  171. event.returnValue = false;
  172. } else {
  173. event.returnValue = true;
  174. }
  175. });
  176. });
  177. // 只能输入整数的双保险, 不做这个check,则可以输入中文字符
  178. function check(str) {
  179. var temp=""
  180. for(var i=0;i<str.length;i++)
  181. if(str.charCodeAt(i)>=48&&str.charCodeAt(i)<=57)
  182. temp+=str.charAt(i)
  183. return temp;
  184. }
  185. function save() {
  186. var data = {};
  187. // token
  188. data._token = $('input[name="_token"]').val();
  189. // 制品名称
  190. data.zhipinmingcheng = $.trim($('#zhipinmingcheng').val());
  191. // 丛书名
  192. data.congshuming = $.trim($('#congshuming').val());
  193. // 书号
  194. data.zhipinshuhao = $.trim($('#zhipinshuhao').val());
  195. // 版次
  196. data.zhipinbanci = $.trim($('#zhipinbanci').val());
  197. // 印次
  198. data.zhipinyinci = $.trim($('#zhipinyinci').val());
  199. // 千字数
  200. data.qianzishu = $.trim($('#qianzishu').val());
  201. // 责任校对
  202. data.zerenjiaodui = $.trim($('#zerenjiaodui').val());
  203. // 一校人员
  204. data.yijiaorenyuan = $.trim($('#yijiaorenyuan').val());
  205. // 一校开始时间
  206. data.yijiaokaishishijian = $.trim($('#yijiaokaishishijian').val());
  207. // 一校完成时间
  208. data.yijiaowanchengshijian = $.trim($('#yijiaowanchengshijian').val());
  209. // 二校人员
  210. data.erjiaorenyuan = $.trim($('#erjiaorenyuan').val());
  211. // 二校开始时间
  212. data.erjiaokaishishijian = $.trim($('#erjiaokaishishijian').val());
  213. // 二校完成时间
  214. data.erjiaowanchengshijian = $.trim($('#erjiaowanchengshijian').val());
  215. // 三校人员
  216. data.sanjiaorenyuan = $.trim($('#sanjiaorenyuan').val());
  217. // 三校开始时间
  218. data.sanjiaokaishishijian = $.trim($('#sanjiaokaishishijian').val());
  219. // 三校完成时间
  220. data.sanjiaowanchengshijian = $.trim($('#sanjiaowanchengshijian').val());
  221. var checkRes = dataCheck(data);
  222. if(checkRes.status > 0) {
  223. return layer.alert(checkRes.message);
  224. }
  225. $.post(
  226. '/reviser/revision/save'
  227. , data
  228. , function(res) {
  229. if(res.status != undefined && res.status == 0) {
  230. layer.msg(res.message, {icon: 1});
  231. setTimeout(() => {
  232. parent.window.location.reload();
  233. }, 1000);
  234. } else if(res.status != undefined) {
  235. return layer.alert(res.message, {icon: 2});
  236. } else {
  237. return layer.alert('提交保存失败', {icon: 2});
  238. }
  239. }
  240. , 'json'
  241. );
  242. }
  243. function dataCheck(data) {
  244. var res = {
  245. status: 1
  246. };
  247. if(data.zhipinmingcheng == undefined || data.zhipinmingcheng == '') {
  248. res.message = '图书名称不能为空';
  249. return res;
  250. }
  251. if(data.zhipinshuhao == undefined || data.zhipinshuhao == '') {
  252. res.message = '书号不能为空';
  253. return res;
  254. }
  255. if(data.zhipinbanci == undefined || data.zhipinbanci == '') {
  256. res.message = '版次不能为空';
  257. return res;
  258. }
  259. if(data.zhipinbanci <= 0) {
  260. res.message = '版次不能小于1';
  261. return res;
  262. }
  263. if(data.zhipinyinci == undefined || data.zhipinyinci == '') {
  264. res.message = '印次不能为空';
  265. return res;
  266. }
  267. if(data.zhipinyinci <= 0) {
  268. res.message = '印次不能小于1';
  269. return res;
  270. }
  271. if(data.qianzishu == undefined || data.qianzishu == '') {
  272. res.message = '千字数不能为空';
  273. return res;
  274. }
  275. if(data.qianzishu <= 0) {
  276. res.message = '千字数必须大于0';
  277. return res;
  278. }
  279. if(data.zerenjiaodui == undefined || data.zerenjiaodui == '') {
  280. res.message = '责任校对不能为空';
  281. return res;
  282. }
  283. res.status = 0;
  284. return res;
  285. }
  286. </script>
  287. </html>
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议