zoukankan      html  css  js  c++  java
  • 快应用如何实现密码明文和密文切换显示

    很多应用提供了账号登录、注册功能,在输入密码时,开发者为了安全性,当用户输入密码时,一般都显示……的密文。但是,这个体验也给用户造成了不便,用户不知道当前输入的字符是否是自己期望的,也无法知道当前输入到哪个字符。针对这个问题,开发者进行了优化,在输入框旁边提供了小图标,点击可切换显示明文和密文。快应用开发也是可以实现上述功能的。

    解决方案

    1. 密码输入框使用input组件,input组件提供了多种type值,密文使用type类型为password,明文类型可使用text类型,type字段需要绑定动态变量。

    2. 在明文和密文切换时,需要显示设置光标位置在末尾,要不切换后光标会显示在开始位置。设置光标位置可以通过setSelectionRange()方法,方法中的start和end参数都设置成当前输入的文字长度。

    示例代码如下:

    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
    <template>
      <div class="container">
        <stack class="input-item"
          <input class="input-text" type="{{inputtype}}" id="inputpsdID" placeholder="please enter password" onchange="showChangePrompt"></input>
          <image src="../Common/lock.png"  class="lock" onclick="switchpassandshow"></image>
        </stack>
      </div>
    </template>
      
    <style>
      .container {
        flex: 1;
        padding: 20px;
        flex-direction: column;
        align-items: center;
      }
      
      .input-item {
        margin-bottom: 80px;
        margin-top: 10px;
        margin-left: 16px;
        margin-right: 16px;
         align-items: center;
         justify-content: flex-end; 
      }
      
      .lock{
          40px;
         height:40px;   
      }
      
      .input-text {
        height: 80px;
         100%;
        line-height: 80px;
        border-top- 1px;
        border-bottom- 1px;
        border-color: #999999;
        font-size: 30px;
        
        padding-right: 42px;
      }
      
      .input-text:focus {
        border-color: #f76160;
      }
    </style>
      
    <script>
      export default {
        data: {
          inputtype: 'password',
          lenth: 0
        },
        onInit() {
          this.$page.setTitleBar({ text: 'Switching between plaintext and ciphertext' });
        },
      
        showChangePrompt(e) {
          this.lenth = e.value.length;
          console.info("showChangePrompt   this.lenth= " + this.lenth);
      
        },
      
        switchpassandshow: function () {
          var com = this.$element('inputpsdID');
          if (this.inputtype === 'password') {
            this.inputtype = 'text';
          } else {
            this.inputtype = 'password';
          }
           com.setSelectionRange({ start: this.lenth, end: this.lenth});
        }
      }
    </script>

    上述代码实现了一个简易的密码明文和密文切换显示功能,点击右边的锁图标,可以切换显示明文和密文。效果如下图所示:

                        

           
     

    图1  密码明文显示

     
     

    图2 密码密文显示

     

    欲了解更多详情,请参见:

    快应用input组件开发指导:

    https://developer.huawei.com/consumer/cn/doc/development/quickApp-References/quickapp-component-input#h1-1575544278909

    原文链接:developer.huawei.com/consumer/cn…

    原作者:Mayism

  • 相关阅读:
    HDU5772 (最小割)
    HDU 4971 (最小割)
    暑期集训个人赛1
    HDU 5644 (费用流)
    HDU5619 (费用流)
    暑假集训热身赛
    构建之法阅读笔记05
    找小水王
    找水王
    Runner站立会议之个人会议(冲刺二)
  • 原文地址:https://www.cnblogs.com/developer-huawei/p/14977683.html
Copyright © 2011-2022 走看看