Як відформатувати номер телефону за допомогою jQuery


93

Зараз я відображаю такі номери телефонів, як 2124771000. Тим НЕ менше, мені потрібно число , щоб бути відформатований в більш зрозумілій формі, наприклад: 212-477-1000. Ось мій струм HTML:

<p class="phone">2124771000</p>

1
Занадто пізно відповідь, але тільки для допомоги тим , хто посадки на цій сторінці URL: igorescobar.github.io/jQuery-Mask-Plugin
Senthil

5
Не впевнений, що я розумію статус закритості щодо цього. Неконструктивне не здається правильним ... Я вважаю цю інформацію надзвичайно корисною і безпосередньо пов’язаною з проблемою, яка мене привела сюди. Я не заперечую того факту, що він закритий, але вказана причина закриття
Бретт Вебер

Можливо, питання було відредаговано і раніше було менш описовим ... мені здається цілком дійсним ТАК питанням і відповіддю на мене, і безліччю голосів.
Кевін Нельсон,

1
Бібліотека Googles github.com/googlei18n/libphonenumber не вимагає jQuery.
nu everest

Відповіді:


217

Простий: http://jsfiddle.net/Xxk3F/3/

$('.phone').text(function(i, text) {
    return text.replace(/(\d{3})(\d{3})(\d{4})/, '$1-$2-$3');
});

Або: http://jsfiddle.net/Xxk3F/1/

$('.phone').text(function(i, text) {
    return text.replace(/(\d\d\d)(\d\d\d)(\d\d\d\d)/, '$1-$2-$3');
});

Примітка: Метод .text () не можна використовувати для елементів введення. Для тексту поля введення використовуйте метод .val ().


4
Я змінив це, щоб підтримувати події "зміни" в полях введення. jsfiddle.net/gUsUK
Zach Shallbetter

3
Трохи надійніший регулярний вираз (хоча для цього потрібна спеціальна функція заміни) був би /(\d{3})?(\d{3})(\d{4})$/у випадку, якщо відсутній код регіону
RevanProdigalKnight

Чи дійсно це для номерів телефонів у всьому світі?
RamPrasadBismil

Якщо на сторінці є кілька телефонних номерів, розгляньте можливість використання функції $ (селектор) .each (), щоб легко застосувати цю маску до всіх номерів.
Даніель Зіберт,

Я хочу реалізувати це за допомогою натискання клавіші та розмиття події. Це не форматування телефонного номера, коли цифри менше 10. Приклад коду: $('#x_phone').on('keypress blur',function() { var ph = $(this).val(); var temp = ph.replace(/(\d{3})(\d{3})(\d{4})/, '$1-$2-$3'); $(this).val(temp); //alert(temp); });
Musaddiq Khan

54
var phone = '2124771000',
    formatted = phone.substr(0, 3) + '-' + phone.substr(3, 3) + '-' + phone.substr(6,4)

7
@AndreasAL: Оскільки механізм регулярних виразів має великі накладні витрати, особливо для того, де формат введення відомий, а прості операції з рядками набагато ефективніші. І звичайно, існує правило, згідно з яким використання регулярного виразу для проблеми просто має дві проблеми.
Marc B

4
Це рішення також правильно форматує телефонні номери з літерами, наприклад "212555IDEA".
Джейсон Уайтхорн,

1
це добре працює в середовищі Windows, але не працює на пристрої iOS. чи існує якась альтернатива, яка працює на обох платформах
Пурушотам Шарма

12

Не забудьте переконатися, що ви працюєте з суто цілими числами.

var separator = '-';
$( ".phone" ).text( function( i, DATA ) {
    DATA
        .replace( /[^\d]/g, '' )
        .replace( /(\d{3})(\d{3})(\d{4})/, '$1' + separator + '$2' + separator + '$3' );
    return DATA;
});

8

Ось комбінація деяких з цих відповідей. Це можна використовувати для полів введення. Діє з номерами телефонів, які мають 7 та 10 цифр.

// Used to format phone number
function phoneFormatter() {
  $('.phone').on('input', function() {
    var number = $(this).val().replace(/[^\d]/g, '')
    if (number.length == 7) {
      number = number.replace(/(\d{3})(\d{4})/, "$1-$2");
    } else if (number.length == 10) {
      number = number.replace(/(\d{3})(\d{3})(\d{4})/, "($1) $2-$3");
    }
    $(this).val(number)
  });
}

Живий приклад: JSFiddle

Я знаю, що це безпосередньо не відповідає на питання, але коли я шукав відповіді, це була одна з перших сторінок, яку я знайшов. Отже, ця відповідь для тих, хто шукає щось подібне до того, що я шукав.


5

Використовуйте бібліотеку для обробки номера телефону. Libphonenumber від Google - це найкращий вибір.

// Require `PhoneNumberFormat`.
var PNF = require('google-libphonenumber').PhoneNumberFormat;

// Get an instance of `PhoneNumberUtil`.
var phoneUtil = require('google-libphonenumber').PhoneNumberUtil.getInstance();

// Parse number with country code.
var phoneNumber = phoneUtil.parse('202-456-1414', 'US');

// Print number in the international format.
console.log(phoneUtil.format(phoneNumber, PNF.INTERNATIONAL));
// => +1 202-456-1414

Я рекомендую використовувати цей пакет від seegno.


4

Я надав jsfiddle посилання для форматування телефонних номерів у США як (XXX) XXX-XXX

 $('.class-name').on('keypress', function(e) {
  var key = e.charCode || e.keyCode || 0;
  var phone = $(this);
  if (phone.val().length === 0) {
    phone.val(phone.val() + '(');
  }
  // Auto-format- do not expose the mask as the user begins to type
  if (key !== 8 && key !== 9) {
    if (phone.val().length === 4) {
      phone.val(phone.val() + ')');
    }
    if (phone.val().length === 5) {
      phone.val(phone.val() + ' ');
    }
    if (phone.val().length === 9) {
      phone.val(phone.val() + '-');
    }
    if (phone.val().length >= 14) {
      phone.val(phone.val().slice(0, 13));
    }
  }

  // Allow numeric (and tab, backspace, delete) keys only
  return (key == 8 ||
    key == 9 ||
    key == 46 ||
    (key >= 48 && key <= 57) ||
    (key >= 96 && key <= 105));
})

.on('focus', function() {
  phone = $(this);

  if (phone.val().length === 0) {
    phone.val('(');
  } else {
    var val = phone.val();
    phone.val('').val(val); // Ensure cursor remains at the end
  }
})

.on('blur', function() {
  $phone = $(this);

  if ($phone.val() === '(') {
    $phone.val('');
  }
});

Живий приклад: JSFiddle


Як я можу змінити цей шаблон, щоб показати номер зліва направо, наприклад ==> (021) 88888888
Мостафа

3

спробуйте щось подібне ..

jQuery.validator.addMethod("phoneValidate", function(number, element) {
    number = number.replace(/\s+/g, ""); 
    return this.optional(element) || number.length > 9 &&
        number.match(/^(1-?)?(\([2-9]\d{2}\)|[2-9]\d{2})-?[2-9]\d{2}-?\d{4}$/);
}, "Please specify a valid phone number");

$("#myform").validate({
  rules: {
    field: {
      required: true,
      phoneValidate: true
    }
  }
});

2

Розглянемо libphonenumber-js ( https://github.com/halt-hammerzeit/libphonenumber-js ), який є меншою версією повного та відомого libphonenumber.

Швидкий і брудний приклад:

$(".phone-format").keyup(function() {
// Don't reformat backspace/delete so correcting mistakes is easier
if (event.keyCode != 46 && event.keyCode != 8) {
    var val_old = $(this).val();
    var newString = new libphonenumber.asYouType('US').input(val_old);
    $(this).focus().val('').val(newString);
}
});

(Якщо ви використовуєте регулярний вираз, щоб уникнути завантаження бібліотеки, уникайте переформатування на зворотному просторі / видалення полегшить виправлення помилок.)


2

Альтернативне рішення:

function numberWithSpaces(value, pattern) {
  var i = 0,
    phone = value.toString();
  return pattern.replace(/#/g, _ => phone[i++]);
}

console.log(numberWithSpaces('2124771000', '###-###-####'));


1

Я знайшов це запитання, шукаючи спосіб автоматичного форматування телефонних номерів за допомогою плагіна jQuery. Прийнята відповідь не була ідеальною для моїх потреб, і за 6 років з моменту її публікації багато чого сталося. Зрештою я знайшов рішення і документую його тут для нащадків.

Проблема

Я хотів би, щоб поле введення номера мого телефону html автоматично форматувало (маскувало) значення за типом користувача.

Рішення

Перевірте Cleave.js . Це дуже потужний / гнучкий та простий спосіб вирішити цю проблему та багато інших проблем маскування даних.

Форматування телефонного номера так само просто, як:

var cleave = new Cleave('.input-element', {
    phone: true,
    phoneRegionCode: 'US'
});

1

Вхід:

4546644645

Код:

PhoneNumber = Input.replace(/(\d\d\d)(\d\d\d)(\d\d\d\d)/, "($1)$2-$3");

Вихід:

(454)664-4645

0
 $(".phoneString").text(function(i, text) {
            text = text.replace(/(\d{3})(\d{3})(\d{4})/, "($1) $2-$3");
            return text;
        });

Вихід :-( 123) 657-8963


-2

можливо це допоможе

var countryCode = +91;
var phone=1234567890;
phone=phone.split('').reverse().join('');//0987654321
var formatPhone=phone.substring(0,4)+'-';//0987-
phone=phone.replace(phone.substring(0,4),'');//654321
while(phone.length>0){
formatPhone=formatPhone+phone.substring(0,3)+'-';
phone=phone.replace(phone.substring(0,3),'');
}
formatPhone=countryCode+formatPhone.split('').reverse().join('');

ви отримаєте + 91-123-456-7890

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.