管灌系统农户端微信小程序(嘉峪关应用)
zuoxiao
2024-02-26 3f7ec892d68f71e996489d14d9918dc332281b1e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<import src="../common/template/icon.wxml" />
<wxs src="../common/utils.wxs" module="_" />
<wxs src="./input.wxs" module="this" />
 
<view
  style="{{_._style([style, customStyle])}}"
  class="{{_.cls(classPrefix, [['border', !borderless]])}} {{classPrefix}}--layout-{{layout}} class {{prefix}}-class"
  aria-describedby
>
  <!-- aria-describedby用于关联该行设置了aria-hidden的元素最近的焦点,解决触发焦点过度上下偏移的问题 -->
  <view class="{{classPrefix}}__wrap--prefix">
    <view class="{{classPrefix}}__icon--prefix">
      <slot name="prefix-icon" />
      <template
        wx:if="{{_prefixIcon}}"
        is="icon"
        data="{{tClass: prefix + '-class-prefix-icon', ariaHidden: true, ..._prefixIcon}}"
      />
    </view>
    <view class="{{classPrefix}}__label {{prefix}}-class-label" aria-hidden>
      <slot name="label" />
      <block wx:if="{{label}}">{{label}}</block>
    </view>
  </view>
 
  <view class="{{classPrefix}}__wrap">
    <view class="{{classPrefix}}__content {{classPrefix}}--{{status}}">
      <input
        maxlength="{{maxlength}}"
        disabled="{{disabled}}"
        placeholder="{{placeholder}}"
        placeholder-style="{{placeholderStyle}}"
        placeholder-class="{{classPrefix}}__placeholder {{placeholderClass}}"
        value="{{value}}"
        bindinput="onInput"
        bindfocus="onFocus"
        bindblur="onBlur"
        bindconfirm="onConfirm"
        bindkeyboardheightchange="onKeyboardHeightChange"
        bindnicknamereview="onNickNameReview"
        password="{{type === 'password'}}"
        type="{{type === 'password' ? 'text' : type}}"
        focus="{{focus}}"
        confirm-type="{{confirmType}}"
        confirm-hold="{{confirmHold}}"
        cursor="{{cursor}}"
        cursor-spacing="{{cursorSpacing}}"
        adjust-position="{{adjustPosition}}"
        auto-focus="{{autoFocus}}"
        always-embed="{{alwaysEmbed}}"
        selection-start="{{selectionStart}}"
        selection-end="{{selectionEnd}}"
        hold-keyboard="{{holdKeyboard}}"
        safe-password-cert-path="{{safePasswordCertPath}}"
        safe-password-length="{{safePasswordLength}}"
        safe-password-time-stamp="{{safePasswordTimeStamp}}"
        safe-password-nonce="{{safePasswordNonce}}"
        safe-password-salt="{{safePasswordSalt}}"
        safe-password-custom-hash="{{safePasswordCustomHash}}"
        class="{{this.getInputClass(classPrefix, suffix, align, disabled)}} {{prefix}}-class-input"
        aria-role="textbox"
        aria-label="{{label}}"
        aria-roledescription="{{label}}"
      />
      <!--
          这里aria-role="textbox"和aria-label组合使用实现ios的聚合焦点播报效果。
          ios会播报aria-label,不会重复播报aria-roledescription的内容;
          安卓不会播报aria-label,会播报aria-roledescription的内容
        -->
      <view
        wx:if="{{_clearIcon && value.length > 0 && showClearIcon}}"
        class="{{classPrefix}}__wrap--clearable-icon"
        bind:touchstart="clearInput"
      >
        <template
          is="icon"
          data="{{tClass: prefix + '-class-clearable', ariaRole: 'button', ariaLabel: '清除', ..._clearIcon }}"
        />
      </view>
      <view class="{{classPrefix}}__wrap--suffix {{prefix}}-class-suffix" bind:tap="onSuffixClick">
        <text wx:if="{{suffix}}">{{suffix}}</text>
        <slot name="suffix" />
      </view>
      <view class="{{classPrefix}}__wrap--suffix-icon" bind:tap="onSuffixIconClick">
        <slot name="suffix-icon" />
        <template
          wx:if="{{_suffixIcon}}"
          is="icon"
          data="{{tClass: prefix + '-class-suffix-icon', ariaRole: 'button', ..._suffixIcon }}"
        />
      </view>
    </view>
    <view
      wx:if="{{tips && tips.length > 0}}"
      class="{{classPrefix}}__tips {{classPrefix}}--{{align}} {{prefix}}-class-tips"
      >{{tips}}
    </view>
    <slot name="tips" />
  </view>
</view>