checkbox.vue 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. <template>
  2. <view>
  3. <page-head :title="title"></page-head>
  4. <view class="uni-padding-wrap uni-common-mt">
  5. <view class="uni-title uni-common-mt">默认样式</view>
  6. <view>
  7. <checkbox-group>
  8. <label>
  9. <checkbox value="cb1" checked="true" />选中
  10. </label>
  11. <label>
  12. <checkbox value="cb" />未选中
  13. </label>
  14. </checkbox-group>
  15. </view>
  16. <view class="uni-title uni-common-mt">不同颜色和尺寸的checkbox</view>
  17. <view>
  18. <checkbox-group>
  19. <label>
  20. <checkbox value="cb1" checked="true" color="#FFCC33" style="transform:scale(0.7)" />选中
  21. </label>
  22. <label>
  23. <checkbox value="cb" color="#FFCC33" style="transform:scale(0.7)" />未选中
  24. </label>
  25. </checkbox-group>
  26. </view>
  27. </view>
  28. <view class="uni-padding-wrap">
  29. <view class="uni-title uni-common-mt">
  30. 推荐展示样式
  31. <text>\n使用 uni-list 布局</text>
  32. </view>
  33. </view>
  34. <view class="uni-list">
  35. <checkbox-group @change="checkboxChange">
  36. <label class="uni-list-cell uni-list-cell-pd" v-for="item in items" :key="item.value">
  37. <view>
  38. <checkbox :value="item.value" :checked="item.checked" />
  39. </view>
  40. <view>{{item.name}}</view>
  41. </label>
  42. </checkbox-group>
  43. </view>
  44. </view>
  45. </template>
  46. <script>
  47. export default {
  48. data() {
  49. return {
  50. title: 'checkbox 复选框',
  51. items: [{
  52. value: 'USA',
  53. name: '美国'
  54. },
  55. {
  56. value: 'CHN',
  57. name: '中国',
  58. checked: 'true'
  59. },
  60. {
  61. value: 'BRA',
  62. name: '巴西'
  63. },
  64. {
  65. value: 'JPN',
  66. name: '日本'
  67. },
  68. {
  69. value: 'ENG',
  70. name: '英国'
  71. },
  72. {
  73. value: 'FRA',
  74. name: '法国'
  75. }
  76. ]
  77. }
  78. },
  79. methods: {
  80. checkboxChange: function (e) {
  81. var items = this.items,
  82. values = e.detail.value;
  83. for (var i = 0, lenI = items.length; i < lenI; ++i) {
  84. const item = items[i]
  85. if(values.indexOf(item.value) >= 0){
  86. this.$set(item,'checked',true)
  87. }else{
  88. this.$set(item,'checked',false)
  89. }
  90. }
  91. }
  92. }
  93. }
  94. </script>
  95. <style>
  96. .uni-list-cell {
  97. justify-content: flex-start
  98. }
  99. </style>