久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

  • <tfoot id='rf62s'></tfoot>

    <small id='rf62s'></small><noframes id='rf62s'>

    <i id='rf62s'><tr id='rf62s'><dt id='rf62s'><q id='rf62s'><span id='rf62s'><b id='rf62s'><form id='rf62s'><ins id='rf62s'></ins><ul id='rf62s'></ul><sub id='rf62s'></sub></form><legend id='rf62s'></legend><bdo id='rf62s'><pre id='rf62s'><center id='rf62s'></center></pre></bdo></b><th id='rf62s'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='rf62s'><tfoot id='rf62s'></tfoot><dl id='rf62s'><fieldset id='rf62s'></fieldset></dl></div>

    • <bdo id='rf62s'></bdo><ul id='rf62s'></ul>

      1. <legend id='rf62s'><style id='rf62s'><dir id='rf62s'><q id='rf62s'></q></dir></style></legend>

        使用純 JavaScript 將電話號碼格式化為用戶類型

        Format a phone number as a user types using pure JavaScript(使用純 JavaScript 將電話號碼格式化為用戶類型)
          <bdo id='a6lUi'></bdo><ul id='a6lUi'></ul>

          <small id='a6lUi'></small><noframes id='a6lUi'>

          1. <tfoot id='a6lUi'></tfoot>

              • <legend id='a6lUi'><style id='a6lUi'><dir id='a6lUi'><q id='a6lUi'></q></dir></style></legend>

                    <tbody id='a6lUi'></tbody>
                  <i id='a6lUi'><tr id='a6lUi'><dt id='a6lUi'><q id='a6lUi'><span id='a6lUi'><b id='a6lUi'><form id='a6lUi'><ins id='a6lUi'></ins><ul id='a6lUi'></ul><sub id='a6lUi'></sub></form><legend id='a6lUi'></legend><bdo id='a6lUi'><pre id='a6lUi'><center id='a6lUi'></center></pre></bdo></b><th id='a6lUi'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='a6lUi'><tfoot id='a6lUi'></tfoot><dl id='a6lUi'><fieldset id='a6lUi'></fieldset></dl></div>
                  本文介紹了使用純 JavaScript 將電話號碼格式化為用戶類型的處理方法,對大家解決問題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!

                  問題描述

                  限時送ChatGPT賬號..

                  我的文檔正文中有一個輸入字段,我需要在用戶鍵入時對其進(jìn)行格式化.它應(yīng)該在區(qū)號周圍加上括號,然后在三到四位數(shù)字之間加上一個破折號.

                  I've got an input field in the body of my document, and I need to format it as the user types. It should have parenthesis around the area code and a dash between the three and four digits after that.

                  例如:(123) 456 - 7890

                  當(dāng)用戶鍵入時,它應(yīng)該類似于:

                  As the user types it should look something like:

                  (12
                  (123)
                  (123) 456
                  (123) 456 - 78
                  (123) 456 - 7890

                  推薦答案

                  新的 ES6 答案

                  您仍然可以使用一些簡單的 JavaScript 來做到這一點(diǎn).

                  HTML

                  New ES6 Answer

                  You can still do this using some simple JavaScript.

                  HTML

                  <input id="phoneNumber" maxlength="16" />
                  

                  JavaScript (ES6)

                  const isNumericInput = (event) => {
                      const key = event.keyCode;
                      return ((key >= 48 && key <= 57) || // Allow number line
                          (key >= 96 && key <= 105) // Allow number pad
                      );
                  };
                  
                  const isModifierKey = (event) => {
                      const key = event.keyCode;
                      return (event.shiftKey === true || key === 35 || key === 36) || // Allow Shift, Home, End
                          (key === 8 || key === 9 || key === 13 || key === 46) || // Allow Backspace, Tab, Enter, Delete
                          (key > 36 && key < 41) || // Allow left, up, right, down
                          (
                              // Allow Ctrl/Command + A,C,V,X,Z
                              (event.ctrlKey === true || event.metaKey === true) &&
                              (key === 65 || key === 67 || key === 86 || key === 88 || key === 90)
                          )
                  };
                  
                  const enforceFormat = (event) => {
                      // Input must be of a valid number format or a modifier key, and not longer than ten digits
                      if(!isNumericInput(event) && !isModifierKey(event)){
                          event.preventDefault();
                      }
                  };
                  
                  const formatToPhone = (event) => {
                      if(isModifierKey(event)) {return;}
                  
                      const input = event.target.value.replace(/D/g,'').substring(0,10); // First ten digits of input only
                      const areaCode = input.substring(0,3);
                      const middle = input.substring(3,6);
                      const last = input.substring(6,10);
                  
                      if(input.length > 6){event.target.value = `(${areaCode}) ${middle} - ${last}`;}
                      else if(input.length > 3){event.target.value = `(${areaCode}) ${middle}`;}
                      else if(input.length > 0){event.target.value = `(${areaCode}`;}
                  };
                  
                  const inputElement = document.getElementById('phoneNumber');
                  inputElement.addEventListener('keydown',enforceFormat);
                  inputElement.addEventListener('keyup',formatToPhone);
                  

                  如果你想擺弄它:
                  https://jsfiddle.net/rafj3md0/

                  免責(zé)聲明:
                  值得注意的是,如果您嘗試修改數(shù)字的中間,這會有點(diǎn)奇怪,因?yàn)闉g覽器在設(shè)置元素值后處理插入符號位置的方式.解決這個問題是可行的,但需要比我現(xiàn)在更多的時間,而且有一些圖書館可以處理這樣的事情.

                  Disclaimer:
                  It's worth noting this gets a little weird if you attempt to modify the middle of the number because of the way browsers handle caret placement after you set an element's value. Solving that problem is doable, but would require more time than I have right now, and there are libraries out there that handle things like that.

                  如果您的 HTML 看起來像:
                  <輸入類型=文本"id="phoneNumber"/>

                  If your HTML looks like:
                  <input type="text" id="phoneNumber"/>

                  您的 JavaScript 函數(shù)可以是:

                  Your JavaScript function can simply be:

                  // A function to format text to look like a phone number
                  function phoneFormat(input){
                          // Strip all characters from the input except digits
                          input = input.replace(/D/g,'');
                          
                          // Trim the remaining input to ten characters, to preserve phone number format
                          input = input.substring(0,10);
                  
                          // Based upon the length of the string, we add formatting as necessary
                          var size = input.length;
                          if(size == 0){
                                  input = input;
                          }else if(size < 4){
                                  input = '('+input;
                          }else if(size < 7){
                                  input = '('+input.substring(0,3)+') '+input.substring(3,6);
                          }else{
                                  input = '('+input.substring(0,3)+') '+input.substring(3,6)+' - '+input.substring(6,10);
                          }
                          return input; 
                  }
                  

                  當(dāng)然,您需要一個事件監(jiān)聽器:

                  Of course, you'll need an event listener:

                  document.getElementById('phoneNumber').addEventListener('keyup',function(evt){
                          var phoneNumber = document.getElementById('phoneNumber');
                          var charCode = (evt.which) ? evt.which : evt.keyCode;
                          phoneNumber.value = phoneFormat(phoneNumber.value);
                  });
                  

                  除非您可以將電話號碼存儲為格式化字符串(我不推薦這樣做),否則您需要在提交值之前清除非數(shù)字字符:
                  document.getElementById('phoneNumber').value.replace(/D/g,'');

                  And unless you're okay storing phone numbers as formatted strings (I don't recommend this), you'll want to purge the non-numeric characters before submitting the value with something like:
                  document.getElementById('phoneNumber').value.replace(/D/g,'');

                  如果您想通過獎勵輸入過濾查看此操作,請查看此小提琴:
                  http://jsfiddle.net/rm9vg16m/

                  If you'd like to see this in action with bonus input filtering, check out this fiddle:
                  http://jsfiddle.net/rm9vg16m/

                  // Format the phone number as the user types it
                  document.getElementById('phoneNumber').addEventListener('keyup', function(evt) {
                    var phoneNumber = document.getElementById('phoneNumber');
                    var charCode = (evt.which) ? evt.which : evt.keyCode;
                    phoneNumber.value = phoneFormat(phoneNumber.value);
                  });
                  
                  // We need to manually format the phone number on page load
                  document.getElementById('phoneNumber').value = phoneFormat(document.getElementById('phoneNumber').value);
                  
                  // A function to determine if the pressed key is an integer
                  function numberPressed(evt) {
                    var charCode = (evt.which) ? evt.which : evt.keyCode;
                    if (charCode > 31 && (charCode < 48 || charCode > 57) && (charCode < 36 || charCode > 40)) {
                      return false;
                    }
                    return true;
                  }
                  
                  // A function to format text to look like a phone number
                  function phoneFormat(input) {
                    // Strip all characters from the input except digits
                    input = input.replace(/D/g, '');
                  
                    // Trim the remaining input to ten characters, to preserve phone number format
                    input = input.substring(0, 10);
                  
                    // Based upon the length of the string, we add formatting as necessary
                    var size = input.length;
                    if (size == 0) {
                      input = input;
                    } else if (size < 4) {
                      input = '(' + input;
                    } else if (size < 7) {
                      input = '(' + input.substring(0, 3) + ') ' + input.substring(3, 6);
                    } else {
                      input = '(' + input.substring(0, 3) + ') ' + input.substring(3, 6) + ' - ' + input.substring(6, 10);
                    }
                    return input;
                  }

                  Enter a phone number here: <input type="text" id="phoneNumber" onkeypress="return numberPressed(event);" />

                  這篇關(guān)于使用純 JavaScript 將電話號碼格式化為用戶類型的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

                  【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!

                  相關(guān)文檔推薦

                  Browserify, Babel 6, Gulp - Unexpected token on spread operator(Browserify,Babel 6,Gulp - 傳播運(yùn)算符上的意外令牌)
                  Is it possible to pass a flag to Gulp to have it run tasks in different ways?(是否可以將標(biāo)志傳遞給 Gulp 以使其以不同的方式運(yùn)行任務(wù)?)
                  Why do we need to install gulp globally and locally?(為什么我們需要在全局和本地安裝 gulp?)
                  How to run Gulp tasks sequentially one after the other(如何一個接一個地依次運(yùn)行 Gulp 任務(wù))
                  Visual Studio 2015 crashes when opening Javascript files(打開 Javascript 文件時 Visual Studio 2015 崩潰)
                  Detect FLASH plugin crashes(檢測 FLASH 插件崩潰)

                • <tfoot id='7aeES'></tfoot>

                    <tbody id='7aeES'></tbody>
                • <small id='7aeES'></small><noframes id='7aeES'>

                      <legend id='7aeES'><style id='7aeES'><dir id='7aeES'><q id='7aeES'></q></dir></style></legend>

                        <i id='7aeES'><tr id='7aeES'><dt id='7aeES'><q id='7aeES'><span id='7aeES'><b id='7aeES'><form id='7aeES'><ins id='7aeES'></ins><ul id='7aeES'></ul><sub id='7aeES'></sub></form><legend id='7aeES'></legend><bdo id='7aeES'><pre id='7aeES'><center id='7aeES'></center></pre></bdo></b><th id='7aeES'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='7aeES'><tfoot id='7aeES'></tfoot><dl id='7aeES'><fieldset id='7aeES'></fieldset></dl></div>
                          • <bdo id='7aeES'></bdo><ul id='7aeES'></ul>
                            主站蜘蛛池模板: 久久精品国产一区二区电影 | 日韩欧美久久 | 中文字幕精品一区 | 欧美日韩综合精品 | 美女天天干 | 免费国产视频在线观看 | 超碰免费在线 | 久久在线| 亚洲午夜在线 | 亚洲一区视频在线 | av免费观看网站 | 国产精品一区二区不卡 | 国产在线观看一区 | 国产1区2区在线观看 | 九九福利| 成人免费视频 | 免费成人高清在线视频 | 国内av在线 | 国产日韩欧美电影 | 亚洲精品不卡 | 国产美女在线观看 | 精品国产一区二区三区久久久四川 | 亚洲 欧美 日韩 精品 | 日日人人 | 成人av网站在线观看 | 欧美v免费 | www.久久 | 成人免费一区二区三区视频网站 | 国产片淫级awww | 国产成人高清成人av片在线看 | 免费一级淫片aaa片毛片a级 | 久久久精品 | 日本羞羞影院 | 国产免费麻豆视频 | 精品久久一| 色综合天天天天做夜夜夜夜做 | 亚洲国产成人精品女人久久久 | 成人一区在线观看 | a视频在线 | 久久久国产精品入口麻豆 | 亚洲综合色视频在线观看 |