3352707edf4286a5ee1d640a1545e93ff6b2083e.svn-base 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <template>
  2. <div class="tennis">
  3. <div v-if="tennis.length == 0" class="no-message">暂无数据</div>
  4. <div v-for="(item, index) of tennis" :key="index">
  5. <el-table :data="item.match_data">
  6. <el-table-column type="expand" style="border: none">
  7. <template slot-scope="props">
  8. <div v-if="props.row.play_data.length > 2">
  9. <el-table style="width:700px;margin:0 auto"
  10. :data="[].concat(props.row.play_data[props.row.play_data.length-1])
  11. .concat(props.row.play_data[props.row.play_data.length-2])">
  12. <el-table-column label="队员" prop="team_name" width="140"></el-table-column>
  13. <el-table-column label="第一盘" prop="sc_1th"></el-table-column>
  14. <el-table-column label="第二盘" prop="sc_2th"></el-table-column>
  15. <el-table-column label="第三盘" prop="sc_3th"></el-table-column>
  16. <el-table-column label="第四盘" prop="sc_4th"></el-table-column>
  17. <el-table-column label="第五盘" prop="sc_5th"></el-table-column>
  18. <el-table-column label="局" prop="game_num"></el-table-column>
  19. <el-table-column label="盘" prop="disc_num"></el-table-column>
  20. </el-table>
  21. <div style="padding: 8px 8px;margin: 0 auto">
  22. <div style="font-weight:bold;">结果:</div>
  23. <div style="margin-left: 40px;line-height: 28px;" v-for="(res, index) of props.row.play_data" :key="index">
  24. <div v-if="index < props.row.play_data.length -2">{{res.play_name}}:{{res.play_result}}</div>
  25. </div>
  26. </div>
  27. </div>
  28. <div v-else style="text-align:center">暂无数据</div>
  29. </template>
  30. </el-table-column>
  31. <el-table-column :label="item.league_name" width="400" align="center" style="border-left:none">
  32. <template slot-scope="scope">
  33. {{scope.row.match_time}}
  34. <span style="width: 400px;font-weight:bold">
  35. {{scope.row.home_team}}
  36. <span style="color: #ff9200">VS</span>
  37. {{scope.row.guest_team}}
  38. </span>
  39. </template>
  40. </el-table-column>
  41. <el-table-column label="赛果" align="center" prop="score_result"></el-table-column>
  42. </el-table>
  43. </div>
  44. </div>
  45. </template>
  46. <script>
  47. export default {
  48. name: 'tennis',
  49. props: {
  50. tennisData: {
  51. type: Array,
  52. default: ()=>[]
  53. },
  54. loading: {
  55. type: Boolean,
  56. default: false
  57. }
  58. },
  59. data() {
  60. return {
  61. tennis: [],
  62. tsLoading: false,
  63. show: true,
  64. test: '1'
  65. }
  66. },
  67. watch: {
  68. tennisData: {
  69. handler(val) {
  70. if(val) {
  71. this.tennis = JSON.parse(JSON.stringify(val))
  72. }
  73. },
  74. deep: true
  75. },
  76. loading(val) {
  77. this.BtLoading = val
  78. }
  79. },
  80. methods: {
  81. // 默认展开
  82. initShow() {
  83. for(let item of this.tennis) {
  84. item.show = !item.show;
  85. }
  86. },
  87. setShow(val, index) {
  88. val.show = !val.show
  89. },
  90. }
  91. }
  92. </script>
  93. <style>
  94. .tennis .el-table {
  95. border-top: none;
  96. }
  97. .tennis .el-table th {
  98. padding: 8px 0;
  99. background-color: #373737;
  100. color: #ffffff;
  101. font-size: 14px;
  102. font-weight: 700;
  103. }
  104. .tennis .sec-table .el-table th {
  105. padding: 4px 0;
  106. background-color: #e3e3e3;
  107. color: #ffffff;
  108. font-size: 14px;
  109. font-weight: 500;
  110. }
  111. .tennis .el-table td {
  112. padding: 6px 0;
  113. }
  114. .tennis .el-table--border th {
  115. border: none;
  116. }
  117. </style>
  118. <style scoped>
  119. .no-message {
  120. text-align: center;
  121. margin-top: 50px;
  122. padding-right: 100px;
  123. font-size: 16px;
  124. font-weight: 700;
  125. }
  126. </style>