rate.nvue 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <template>
  2. <view class="container">
  3. <uni-card is-full :is-shadow="false">
  4. <text class="uni-h6">评分组件多用于商品评价打分、服务态度评价、用户满意度等场景。</text>
  5. </uni-card>
  6. <uni-section title="基本用法" type="line" padding>
  7. <uni-rate v-model="rateValue" @change="onChange" />
  8. </uni-section>
  9. <uni-section title="不支持滑动手势选择评分" subTitle="设置 touchable 属性控制是否开启手势选择" type="line" padding>
  10. <uni-rate :touchable="false" :value="5" @change="onChange" />
  11. </uni-section>
  12. <uni-section title="设置尺寸大小" subTitle="设置 size 属性控制组件大小" type="line" padding>
  13. <uni-rate size="18" :value="5" />
  14. </uni-section>
  15. <uni-section title="设置评分数" subTitle="设置 max 属性控制组件最大星星数量" type="line" padding>
  16. <uni-rate :max="10" :value="5" />
  17. </uni-section>
  18. <uni-section title="设置星星间隔" subTitle="设置 margin 属性控制星星间隔" type="line" padding>
  19. <uni-rate :value="4" margin="20" />
  20. </uni-section>
  21. <uni-section title="设置颜色" subTitle="使用 color 属性设置星星颜色" type="line" padding>
  22. <uni-rate :value="3" color="#bbb" active-color="red" />
  23. </uni-section>
  24. <uni-section title="半星" subTitle="使用 allow-half 属性设置是否显示半星" type="line" padding>
  25. <uni-rate allow-half :value="3.5" />
  26. </uni-section>
  27. <uni-section title="只读状态" subTitle="使用 readonly 属性设置组件只读" type="line" padding>
  28. <uni-rate :readonly="true" :value="2" />
  29. </uni-section>
  30. <uni-section title="禁用状态" subTitle="使用 disabled 属性设置组件禁用" type="line" padding>
  31. <uni-rate :disabled="true" disabledColor="#ccc" :value="3" />
  32. </uni-section>
  33. <uni-section title="未选中的星星为镂空状态" subTitle="使用 is-fill 属性设置星星镂空" type="line" padding>
  34. <uni-rate :value="3" :is-fill="false" />
  35. </uni-section>
  36. </view>
  37. </template>
  38. <script>
  39. export default {
  40. components: {},
  41. data() {
  42. return {
  43. rateValue: 0
  44. }
  45. },
  46. onLoad() {
  47. // 模拟动态赋值
  48. setTimeout(() => {
  49. this.rateValue = 3
  50. }, 1000)
  51. },
  52. methods: {
  53. onChange(e) {
  54. console.log('rate发生改变:' + JSON.stringify(e))
  55. // console.log(this.rateValue);
  56. }
  57. }
  58. }
  59. </script>
  60. <style lang="scss">
  61. </style>