JS метод Global.parseFloat()
Загальний опис
parseFloat()
– це вбудований метод у JavaScript, що дозволяє конвертувати рядкове значення в число з плаваючою комою. Іноді, коли ми працюємо з даними, отриманими з зовнішніх джерел, числа можуть бути представлені у вигляді рядків. У таких випадках parseFloat()
стає незамінним інструментом для правильної обробки цих даних.
Необхідність цього методу полягає в тому, щоб визначити числові значення в рядках. Наприклад, ви отримали дані з API, де ціни товарів представлені як рядки, і вам потрібно порівняти ціни або обчислити загальну вартість замовлення. Якщо спробувати виконати арифметичні операції з рядками, результат буде неправильний. Тут на допомогу приходить parseFloat()
.
Основне застосування parseFloat()
– це конвертація рядків у числа. Але важливо розуміти, що він спробує конвертувати рядок тільки до того моменту, поки він зустрічає символ, який не є частиною числа. Наприклад:
let value = "123.45px";
let number = parseFloat(value); // 123.45
У вищезазначеному прикладі ми бачимо, що parseFloat()
успішно конвертував рядок до числа, але проігнорував "px" в кінці рядка.
Однак, якщо рядок починається з нечислового символу, метод поверне NaN:
let value = "px123.45";
let number = parseFloat(value); // NaN
Метод parseFloat()
може розпізнавати лише десяткову точку (не кому). Тому, якщо ви використовуєте інші символи для розділення, наприклад кому, то результат буде ігнорувати все, що йде після коми.
Також цікавою особливістю є те, що parseFloat()
завжди конвертує значення у 64-бітне число з плаваючою комою, незалежно від того, чи має воно дробову частину.
parseFloat()
має декілька важливих відмінностей від інших методів конвертації, таких як Number()
. Наприклад, він не розпізнає числові літерали у шістнадцятковій системі обчислення.
Нотатка: | Пам'ятайте, що |
Нотатка: | Для тих, хто працює з локалізованими числами: будьте уважні, що |
Порада: | Переконайтеся, що рядок, який ви передаєте на вхід в |
Порада: | Якщо вам потрібна більша гнучкість при розборі чисел з рядків, розгляньте можливість використання бібліотек типу BigNumber. |
Порада: | Важливо зауважити, що JavaScript не розрізняє числа з плаваючою комою та цілі числа на рівні мови, тому |
Синтаксис
parseFloat(string)
Параметри
- *
string
Значення, яке потрібно розібрати, приводиться до рядкового типу. Початкові пробільні символи в цьому аргументі ігноруються.
Return
float
Повертає число з плаваючою комою, розібране з заданого рядка, або
NaN
, якщо перший символ, що не є пробільним, не може бути конвертований у число.
Переглядачі
Переглядач | |||||
---|---|---|---|---|---|
1 |
1 |
1 |
3 |
12 |
Переглядач | ||||
---|---|---|---|---|
4.4 |
18 |
4 |
1 |
Переглядач | ||
---|---|---|
0.10.0 |
1.0 |
Приклади
У цьому прикладі ми створили просту форму для введення рядкового значення. Після того, як користувач вводить рядкове значення і натискає на кнопку "Конвертувати", JavaScript-функція convertToFloat()
викликається, щоб конвертувати введений рядок у число з плаваючою комою за допомогою parseFloat()
. Результат потім відображається у вказаному місці на сторінці.
Цей приклад демонструє, як можна використовувати parseFloat()
для вилучення числового значення з рядка, що містить і число, і текст. У нашому випадку ми маємо рядок price
, який представляє ціну товару з символами валюти "грн". Функція extractAmount()
вилучає числове значення, використовуючи parseFloat()
, і повертає його.
// Функція, яка приймає рядок з числом та валютою, та повертає лише число
function extractAmount(valueStr) {
return parseFloat(valueStr); // використання parseFloat() для отримання числового значення з рядка
}
var price = "120.50грн";
console.log(extractAmount(price)); // Виводимо 120.50
Цей приклад демонструє, як можна адаптувати parseFloat()
для роботи з числами, які використовують кому в якості десяткового роздільника (наприклад, у європейських стандартах). Ми використовуємо метод рядка replace()
для заміни коми на крапку, після чого використовуємо parseFloat()
для перетворення рядка на число. Таким чином, рядок europeanNumber
"45,67" стає числом 45.67.
// Функція, яка перетворює кому на крапку та повертає числове значення
function convertToNumber(euroValue) {
// Замінюємо кому на крапку перед parseFloat()
return parseFloat(euroValue.replace(',', '.'));
}
var europeanNumber = "45,67";
console.log(convertToNumber(europeanNumber)); // Виводимо 45.67