index.ux 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <import name="x-book" src="../../components/book/book.ux"></import>
  2. <template>
  3. <div class="leaderboard-wrap">
  4. <div class="type-bar">
  5. <block for="type in typeList">
  6. <div class="type-item" @click="typeChange(type.index)">
  7. <text class="{{type.index === current ? 'cur' : ''}}">{{type.name}}</text>
  8. <text class="choose-bar" show="{{type.index === current}}"></text>
  9. </div>
  10. </block>
  11. </div>
  12. <list>
  13. <list-item type="multi" class="book-list__wrap book-list__wrap--multi">
  14. <div class="book-list__multi">
  15. <block for="book in list">
  16. <div class="book-item">
  17. <div style="width:60px;margin-right:15px">
  18. <image if="$idx<3" src="{{img[$idx]}}" class="book-index"></image>
  19. <div else class="book-index_follow">
  20. <text>{{$idx+1}}</text>
  21. </div>
  22. </div>
  23. <x-book multi="{{true}}" width="{{150}}" book="{{book}}">
  24. <div class="book-info__multi">
  25. <text class="name">{{book.book_name}}</text>
  26. <text class="intro">{{book.book_summary}}</text>
  27. </div>
  28. </x-book>
  29. </div>
  30. </block>
  31. </div>
  32. </list-item>
  33. </list>
  34. </div>
  35. </template>
  36. <script>
  37. import { getRank } from "../../api";
  38. export default {
  39. data() {
  40. return {
  41. typeList: [
  42. {
  43. name: "女生",
  44. index: 0
  45. },
  46. {
  47. name: "男生",
  48. index: 1
  49. },
  50. ],
  51. list: [],
  52. current: 0,
  53. img: ['../../assets/imgs/rank_1.png', '../../assets/imgs/rank_2.png', '../../assets/imgs/rank_3.png']
  54. }
  55. },
  56. async onInit() {
  57. await this.getCityListByTabChange();
  58. this.$watch('current', 'getCityListByTabChange')
  59. },
  60. onShow() { },
  61. typeChange(index) {
  62. this.current = index;
  63. },
  64. async getCityListByTabChange(index = 0) {
  65. let sex = index ? "1" : "2";
  66. let ret = await getRank(sex);
  67. this.list = ret;
  68. }
  69. }
  70. </script>
  71. <style lang="less">
  72. @import "../../assets/less/leaderboard.less";
  73. </style>