health_tip.vue 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <template>
  2. <view v-if="health_tip" class="content">
  3. <view>
  4. <text class="title">健康小知识</text>
  5. </view>
  6. <uv-gap height="50"></uv-gap>
  7. <view class="tip center">
  8. <div class="long-text center" v-html="health_tip"></div>
  9. </view>
  10. <view @click="change_favor" class="flex justify-end relative" style="top: -55vw;">
  11. <text v-if="favor" class="favor cuIcon-favorfill text-red"></text>
  12. <text v-else class="favor cuIcon-favor"></text>
  13. </view>
  14. <uv-gap height="50"></uv-gap>
  15. <view class="flex justify-between">
  16. <button @click="get_health_tip(index - 1)" class="button-all">上一条</button>
  17. <button @click="get_health_tip(index + 1)" class="button-all">下一条</button>
  18. </view>
  19. </view>
  20. <view v-else class="no_data"></view>
  21. </template>
  22. <script>
  23. import health_tips from '@/static/health_tip.js'
  24. export default {
  25. onShow() {
  26. this.get_random_health_tip();
  27. },
  28. data() {
  29. return {
  30. health_tip: null,
  31. index: null,
  32. favor: false
  33. }
  34. },
  35. methods: {
  36. change_favor(){
  37. let favor_health_list = uni.getStorageSync('favor_health_list');
  38. if(favor_health_list){
  39. if(favor_health_list.includes(this.index))
  40. favor_health_list.splice(favor_health_list.indexOf(this.index), 1);
  41. else favor_health_list.unshift(this.index);
  42. }
  43. else favor_health_list = [this.index];
  44. uni.setStorageSync('favor_health_list',favor_health_list);
  45. this.favor = !this.favor;
  46. },
  47. get_health_tip(index){
  48. if(index < 0 || index >= health_tips.length){
  49. uni.showToast({duration:1000,icon:'none',title: '到顶了'});
  50. return ;
  51. }
  52. const health_tip = health_tips[index];
  53. // 输出随机选取的元素
  54. console.log(health_tip);
  55. this.favor = false;
  56. let favor_health_list = uni.getStorageSync('favor_health_list');
  57. if(favor_health_list){
  58. if(favor_health_list.includes(index)) this.favor = true;
  59. }
  60. this.index = index;
  61. this.health_tip = formatHealthTip(health_tip);
  62. function formatHealthTip(health_tip) {
  63. const totalLength = health_tip.length;
  64. const numRows = Math.ceil(totalLength / 10); // 计算总行数
  65. const charsPerRow = Math.ceil(totalLength / numRows); // 计算每行字符数
  66. let formattedTip = '';
  67. for (let i = 0; i < totalLength; i += charsPerRow) {
  68. formattedTip += health_tip.slice(i, i + charsPerRow) + '<br>';
  69. }
  70. // 去掉最后一行多余的 <br>
  71. formattedTip = formattedTip.slice(0, -4);
  72. return formattedTip;
  73. }
  74. },
  75. get_random_health_tip(){
  76. // 获取数组的长度
  77. const length = health_tips.length;
  78. // 使用 Math.random() 生成一个 [0, length) 范围内的随机索引值
  79. const randomIndex = Math.floor(Math.random() * length);
  80. this.get_health_tip(randomIndex);
  81. }
  82. }
  83. }
  84. </script>
  85. <style>
  86. page{
  87. background-color: #fff;
  88. }
  89. button{
  90. background-color: aliceblue;
  91. }
  92. .content{
  93. padding: 20px;
  94. }
  95. .tip{
  96. height: 55vw;
  97. background-color: #f1f3f2;
  98. border: none;
  99. border-radius: 30px;
  100. padding: 20px;
  101. letter-spacing: 2px;
  102. margin-bottom: 20px;
  103. font-weight: 1000;
  104. color: #666;
  105. font-size: 27px;
  106. }
  107. .title{
  108. color: #777;
  109. font-size: 20px;
  110. font-weight: 600;
  111. }
  112. .favor{
  113. font-size: 24px;
  114. margin-right: 5vw;
  115. }
  116. .long-text{
  117. width: 100vw;
  118. overflow: scroll;
  119. height: calc(55vw - 40px);
  120. overflow-wrap: break-word;
  121. text-align: center;
  122. }
  123. </style>