Відповіді:
Так - parseFloat
.
parseFloat(document.getElementById(amtid4).innerHTML);
Для форматування чисел використовуйте toFixed
:
var num = parseFloat(document.getElementById(amtid4).innerHTML).toFixed(2);
num
тепер рядок із числом, відформатованим з двома знаками після коми.
parseFloat('22w')
є 22
і parseFloat('w22')
єNaN
Ви також можете скористатися Number
конструктором / функцією (немає необхідності в radix і може бути використаний як для цілих чисел, так і для плавців):
Number('09'); /=> 9
Number('09.0987'); /=> 9.0987
Крім того, як сказав Енді Е в коментарях, які ви можете використовувати +
для конверсії
+'09'; /=> 9
+'09.0987'; /=> 9.0987
Number
var formatter = new Intl.NumberFormat("ru", {
style: "currency",
currency: "GBP"
});
alert( formatter.format(1234.5) ); // 1 234,5 £
https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat
Intl.NumberFormat
цвяхи це.
Простим коротким способом буде використання + x. Він зберігає знак недоторканим, а також десяткові числа. Інша альтернатива - використовувати parseFloat (x). Різниця між parseFloat (x) і + x є для порожнього рядка + x повертає 0, де як parseFloat (x) повертає NaN.
Я зробив невелику функцію помічника, щоб зробити це і зафіксувати всі неправильно сформовані дані
function convertToPounds(str) {
var n = Number.parseFloat(str);
if(!str || isNaN(n) || n < 0) return 0;
return n.toFixed(2);
}
Демо тут