如何设置输入的图案或格式

时间:2019-04-08 10:31:22

标签: javascript jquery yii2-advanced-app

我有两个输入字段 我想设置我的第一个输入字段格式,例如ASED0000A

如果我输入值AAAA或输入其他字符(如A到Z),则其他键将被禁用

输入应采用以下格式: 1st 4应该是字母 接下来的四个应该是数字 最后一个应该是aaphabet

我的第二个输入字段格式是AAA / AA / 000/0 1st 3输入是字符,然后是斜杠(/)

另外2个输入是字符,然后是斜杠(/)

接下来的3是数字,再是一个斜杠和la 一位数字。

 <?= $form->field($model, 'pan_number')->textInput(['placeholder'=>'AAAAOOOOA','style'=>"text-transform:uppercase"])->label('PAN') ?>
<?= $form->field($model, 'tds_ao')->textInput(['placeholder'=>'AAA/AA/OOO/O'])->label('TDS circle/AO code') ?>
<script>

      $('#companytexinfo-pan_number').keypress(function(e){
            var inputval = $('#companytexinfo-pan_number').val().length;
            console.log(inputval);
            let allow_char = [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,97,98,99,100,101,102,103,104,
                            105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122];
            if(inputval >=4){
                if(allow_char.indexOf(e.which) == -1 ){
                //do something
                }
                else{
                return false;
                }
            }
            let allow_number = [48,49,50,51,52,53,54,55,56,57];
            if((inputval >=5) && (inputval =8)){
                if(allow_number.indexOf(e.which) == -1 ){
                //do something
                }
                else{
                return false;
                }
            }
            let allow_alst_char = [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,97,98,99,100,101,102,103,104,
                                105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122];
            if(inputval ==9){
                if(allow_alst_char.indexOf(e.which) == -1 ){
                    //do something
                }
                else{
                    return false;
                }
            }
      })

</script>

这是我的脚本,但无法正常工作 请帮忙 谢谢

1 个答案:

答案 0 :(得分:1)

使用formatter.js实现这一目标。 添加插件后,按如下所示修改您的输入。

    <input type="text" name="pan_number" id="pan_number"/>

    <script>

      $('#pan_number').formatter({
          'pattern': '{{aaaa}}{{9999}}{{a}}',
          'persistent': true
     });

    </script>