zSelect.vue 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <template>
  2. <div class="zSelect">
  3. <div>
  4. <div class="z-cell"><span class="van-f-red">*</span>下拉选择</div>
  5. </div>
  6. <div class="checkbox">
  7. <van-field
  8. readonly
  9. clickable
  10. name="picker"
  11. :value="zSelectValuec"
  12. placeholder="点击选择"
  13. @click="zSelect = true"
  14. >
  15. </van-field>
  16. </div>
  17. <van-popup v-model="zSelect" position="bottom">
  18. <van-picker
  19. show-toolbar
  20. :columns="zSelectcolumns"
  21. @confirm="onConfirm"
  22. @cancel="zSelect = false"
  23. />
  24. </van-popup>
  25. </div>
  26. </template>
  27. <script>
  28. export default {
  29. name: "zSelect",
  30. props: {
  31. zSelectcolumns: [],
  32. zSelectValue: "",
  33. textc: "",
  34. rules: false,
  35. },
  36. data() {
  37. return {
  38. zSelect: false,
  39. zSelectValuec: this.zSelectValue
  40. }
  41. },
  42. // computed: {
  43. // zSelectValuefn:{
  44. // get() {
  45. // return this.zSelectValuec=this.zSelectValuec;
  46. // },
  47. // set(newValue) {
  48. // return newValue;
  49. // }
  50. // }
  51. // },
  52. methods: {
  53. onConfirm(value) {
  54. let datalist = {
  55. type: this.textc,
  56. value: value
  57. }
  58. this.zSelectValuec = value
  59. this.$emit('zSelectVal', datalist)
  60. this.zSelect = false
  61. }
  62. }
  63. }
  64. </script>
  65. <style scoped>
  66. .van-f-red {
  67. color: red;
  68. width: 4px;
  69. display: inline-block;
  70. padding-right: 4px;
  71. }
  72. .zSelect .z-cell {
  73. padding: 10px 16px 0 16px;
  74. font-size: 16px;
  75. }
  76. .checkbox {
  77. padding: 10px 16px 0 16px;
  78. background-color: white;
  79. }
  80. .checkbox .van-checkbox {
  81. padding-bottom: 10px
  82. }
  83. </style>
  84. <style>
  85. </style>