index.wxml 2.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <wxs src="../wxs/utils.wxs" module="utils" />
  2. <van-cell
  3. icon="{{ leftIcon }}"
  4. title="{{ label }}"
  5. center="{{ center }}"
  6. border="{{ border }}"
  7. is-link="{{ isLink }}"
  8. required="{{ required }}"
  9. custom-style="{{ customStyle }}"
  10. title-width="{{ titleWidth }}"
  11. custom-class="van-field"
  12. size="{{ size }}"
  13. >
  14. <slot name="left-icon" slot="icon" />
  15. <slot name="label" slot="title" />
  16. <view class="van-field__body {{ type === 'textarea' ? 'van-field__body--textarea' : '' }}">
  17. <textarea
  18. wx:if="{{ type === 'textarea' }}"
  19. class="input-class {{ utils.bem('field__input', [inputAlign, { disabled, error }]) }}"
  20. fixed="{{ fixed }}"
  21. focus="{{ focus }}"
  22. value="{{ value }}"
  23. disabled="{{ disabled || readonly }}"
  24. maxlength="{{ maxlength }}"
  25. auto-height="{{ autosize }}"
  26. placeholder="{{ placeholder }}"
  27. placeholder-style="{{ placeholderStyle }}"
  28. placeholder-class="{{ error ? 'van-field__input--error' : 'van-field__placeholder' }}"
  29. cursor-spacing="{{ cursorSpacing }}"
  30. adjust-position="{{ adjustPosition }}"
  31. show-confirm-bar="{{ showConfirmBar }}"
  32. bindinput="onInput"
  33. bind:blur="onBlur"
  34. bind:focus="onFocus"
  35. bind:confirm="onConfirm"
  36. />
  37. <input
  38. wx:else
  39. class="input-class {{ utils.bem('field__input', [inputAlign, { disabled, error }]) }}"
  40. type="{{ type }}"
  41. focus="{{ focus }}"
  42. value="{{ value }}"
  43. disabled="{{ disabled || readonly }}"
  44. maxlength="{{ maxlength }}"
  45. placeholder="{{ placeholder }}"
  46. placeholder-style="{{ placeholderStyle }}"
  47. placeholder-class="{{ error ? 'van-field__input--error' : 'van-field__placeholder' }}"
  48. confirm-type="{{ confirmType }}"
  49. confirm-hold="{{ confirmHold }}"
  50. cursor-spacing="{{ cursorSpacing }}"
  51. adjust-position="{{ adjustPosition }}"
  52. bindinput="onInput"
  53. bind:blur="onBlur"
  54. bind:focus="onFocus"
  55. bind:confirm="onConfirm"
  56. />
  57. <van-icon
  58. wx:if="{{ showClear }}"
  59. size="16px"
  60. name="clear"
  61. class="van-field__clear-root"
  62. custom-class="van-field__clear"
  63. bind:touchstart="onClear"
  64. />
  65. <view class="van-field__icon-container" wx:if="{{ icon || useIconSlot }}" bind:tap="onClickIcon">
  66. <van-icon
  67. wx:if="{{ icon }}"
  68. size="16px"
  69. name="{{ icon }}"
  70. custom-class="van-field__icon {{ iconClass }}"
  71. />
  72. <slot wx:else name="icon" />
  73. </view>
  74. <view wx:if="{{ useButtonSlot }}" class="van-field__button">
  75. <slot name="button" />
  76. </view>
  77. </view>
  78. <view wx:if="{{ errorMessage }}" class="van-field__error-message">
  79. {{ errorMessage }}
  80. </view>
  81. </van-cell>