index.vue 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. <template>
  2. <div class="calendar">
  3. <table class="calendar-table calendar-table-hour">
  4. <thead class="calendar-head">
  5. <tr>
  6. <th rowspan="8" class="week-td">星期 / 时间</th>
  7. <th colspan="12">00:00 - 12:00</th>
  8. <th colspan="12">12:00 - 24:00</th>
  9. <th colspan="4" rowspan="2" class="week-td" style="display: none">小时</th>
  10. </tr>
  11. <tr>
  12. <th colspan="1" v-for="(_, i) in 24" :key="i">{{ i }}</th>
  13. </tr>
  14. </thead>
  15. <tbody class="calendar-body">
  16. <tr>
  17. <th class="td-normal">星期一</th>
  18. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  19. <span class=""></span>
  20. </td>
  21. <!-- <td colspan="2" class="td-normal" style="display: none">
  22. <span class="hover-link td-normal">ON</span>
  23. </td>
  24. <td colspan="2" class="td-normal" style="display: none">
  25. <span class="hover-link td-normal">OFF</span>
  26. </td> -->
  27. </tr>
  28. <tr>
  29. <th class="td-normal">星期二</th>
  30. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  31. <span class=""></span>
  32. </td>
  33. <!-- <td colspan="2" class="td-normal" style="display: none">
  34. <span class="hover-link td-normal">ON</span>
  35. </td>
  36. <td colspan="2" class="td-normal" style="display: none">
  37. <span class="hover-link td-normal">OFF</span>
  38. </td> -->
  39. </tr>
  40. <tr>
  41. <th class="td-normal">星期三</th>
  42. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  43. <span class=""></span>
  44. </td>
  45. <!-- <td colspan="2" class="td-normal" style="display: none">
  46. <span class="hover-link td-normal">ON</span>
  47. </td>
  48. <td colspan="2" class="td-normal" style="display: none">
  49. <span class="hover-link td-normal">OFF</span>
  50. </td> -->
  51. </tr>
  52. <tr>
  53. <th class="td-normal">星期四</th>
  54. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  55. <span class=""></span>
  56. </td>
  57. <!-- <td colspan="2" class="td-normal" style="display: none">
  58. <span class="hover-link td-normal">ON</span>
  59. </td>
  60. <td colspan="2" class="td-normal" style="display: none">
  61. <span class="hover-link td-normal">OFF</span>
  62. </td> -->
  63. </tr>
  64. <tr>
  65. <th class="td-normal">星期五</th>
  66. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  67. <span class=""></span>
  68. </td>
  69. <!-- <td colspan="2" class="td-normal" style="display: none">
  70. <span class="hover-link td-normal">ON</span>
  71. </td>
  72. <td colspan="2" class="td-normal" style="display: none">
  73. <span class="hover-link td-normal">OFF</span>
  74. </td> -->
  75. </tr>
  76. <tr>
  77. <th class="td-normal">星期六</th>
  78. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  79. <span class=""></span>
  80. </td>
  81. <!-- <td colspan="2" class="td-normal" style="display: none">
  82. <span class="hover-link td-normal">ON</span>
  83. </td>
  84. <td colspan="2" class="td-normal" style="display: none">
  85. <span class="hover-link td-normal">OFF</span>
  86. </td> -->
  87. </tr>
  88. <tr>
  89. <th class="td-normal">星期日</th>
  90. <td data-week="0" :data-time="i" class="un-selected" v-for="(_, i) in 24" :key="i">
  91. <span class=""></span>
  92. </td>
  93. <!-- <td colspan="2" class="td-normal" style="display: none">
  94. <span class="hover-link td-normal">ON</span>
  95. </td>
  96. <td colspan="2" class="td-normal" style="display: none">
  97. <span class="hover-link td-normal">OFF</span>
  98. </td> -->
  99. </tr>
  100. <tr>
  101. <th colspan="28" class="clear-bar td-normal">
  102. <span class="pull-left td-normal">可拖动鼠标选择时间段</span>
  103. <span class="hover-link fr td-normal">全部重置</span>
  104. </th>
  105. </tr>
  106. </tbody>
  107. </table>
  108. </div>
  109. </template>
  110. <script lang="ts" setup>
  111. import { ref } from 'vue'
  112. </script>
  113. <style lang="scss" scoped>
  114. .calendar {
  115. background-color: #fff;
  116. -webkit-user-select: none;
  117. position: relative;
  118. display: inline-block;
  119. .calendar-table {
  120. border-collapse: collapse;
  121. }
  122. .week-td {
  123. width: 90px;
  124. }
  125. }
  126. table {
  127. display: table;
  128. border-collapse: separate;
  129. box-sizing: border-box;
  130. text-indent: initial;
  131. border-spacing: 2px;
  132. border-color: gray;
  133. thead {
  134. display: table-header-group;
  135. vertical-align: middle;
  136. border-color: inherit;
  137. }
  138. tr {
  139. border: 1px solid #e0e5f4;
  140. font-size: 12px;
  141. text-align: center;
  142. line-height: 32px;
  143. color: rgba(0, 0, 0, 0.5);
  144. th {
  145. min-width: 40px;
  146. border: 1px solid #e0e5f4;
  147. font-size: 12px;
  148. text-align: center;
  149. line-height: 32px;
  150. background: #f7f8fa;
  151. }
  152. td {
  153. border: 1px solid #e0e5f4;
  154. font-size: 12px;
  155. text-align: center;
  156. line-height: 32px;
  157. min-width: 40px;
  158. cursor: pointer;
  159. &:hover {
  160. background: #ccdbff;
  161. }
  162. .active {
  163. background: #ccdbff;
  164. }
  165. }
  166. }
  167. }
  168. .clear-bar {
  169. line-height: 32px;
  170. padding: 0 12px;
  171. .hover-link {
  172. color: #1c6bde;
  173. cursor: pointer;
  174. font-size: 13px;
  175. }
  176. .fr {
  177. float: right;
  178. }
  179. }
  180. </style>