Zahlen formatieren
Die folgende Funktion formatiert Zahlen.
Erläuterung
Die Funktion ist eine prototypische Erweiterung des Number Objekts, d.h. sie kann als Methode auf alle Zahlen angewendet werden. Der Aufruf zahl.format()
erwartet bis zu zwei Parameter mit folgender Bedeutung:
number
(optional)
Die Anzahl der Nachkommastellen, auf die die Zahl gerundet werden soll (default: 0)bool
(optional)
Dieser Parameter bestimmt, ob die formatierte Zahl eine feste Anzahl von Nachkommastellen haben soll. Ist der Werttrue
, dann werden evtl. fehlende Stellen mit einer Null aufgeüllt.
Beispiel
ähnliche Artikel
- 28. November 2024 -- Animierte Tabellen Sortierung (10)
Aufgrund einer Frage bei meinem alten Tabellensortierer-Skript...
- 6. August 2019 -- CAS Nummer validieren (0)
Wieder ein kleines Skript aus dem Bereich Chemie. Um...
- 27. Oktober 2012 -- Tween Beispiele (0)
Das Tween Objekt Ich vertiefe hier noch einmal die...
Comments (33)
26279 mal gelesen.
26279 mal gelesen.
33 Kommentare
direkt zum Formular »
Seiten:
27. September 2005: 11:10
Hallo Struppi,
vielen Dank für deine Funktion hat sofort tadellos funktioniert.
Daniel
27. September 2006: 11:20
Hallo,
die Funktion hat noch einen Fehler, wenn man Ganzzahlen eingibt und Nachkommastellen haben will (z. B. „1“) – dann wird aus der 1 eine 1000 (bei 2 Nachkommastellen)!
….
27. September 2006: 11:21
Das Problem tritt auf, wenn die Zahl als Zahl übergeben wird, nicht als String. ;-)
27. September 2006: 16:04
Danke ich hab’s geändert.
10. Oktober 2006: 17:03
Hi,
die Funktion scheint Schwierigkeiten mit negativen Zahlen zu haben.
Beispiel mit 2 Nachkommastellen:
-1 -> -0,99
-5 -> -4,99
Beispiel mit 0 Nachkommastellen:
-1 -> 0
-2 -> -1
Gruß, Hubbe
10. Oktober 2006: 19:15
Ja hatte sie, danke für den Hinweis.
9. November 2006: 16:10
Super, funktioniert einwandfrei, danke!
12. Februar 2007: 17:28
Ein klasse Skript, genau sowas hab ich gesucht.
8. Februar 2008: 12:14
jo, danke auch von meiner seite für die funtion! klappt alles bestens!
weiter so! gruß
10. Mai 2008: 11:47
Hallo
Wäre toFixed() nicht einfacher?
http://de.selfhtml.org/javascript/objekte/number.htm#to_fixed
11. Mai 2008: 12:25
Ja würe es, wenn es richtig Runden würde und wenn es auch die tausender Stellen formatieren würde. Probier mal z.b. 1202.955 mit toFixed() aus (zumindest FF und OP rundet das falsch [1202.95]).
23. Juli 2008: 11:10
hi struppi,
danke für deine funktion, nur gibt es noch einen fehler:
aus 1.234,00 oder auch 0,00 wird NaN,00
vg mormel
23. Juli 2008: 11:20
Das ist kein Fehler, du musst natürlich eine Zahl eingeben 1.234,00 ist ein String, das Komma ist in JS (und allen anderen Programmiersprachen) ein Punkt
23. Juli 2008: 11:37
hmm, natürlich, aber:
ich gebe in ein Formularfeld 1234 ein, dann wird deine Funktion per onblur aufgerfufen und es wird daraus 1.234,00. Gehe ich im Formular zurück und komme wieder in dieses Feld wird beim nächten onblur daraus NaN,00 und das ist nicht so gewollt, oder?
vg mormel
23. Juli 2008: 12:36
Dann musst du dies in deinem Skript entsprechend umwandeln. Es ist klar, dass der Rückgabewert der Funktion ein String ist, mit dem du nicht rechnen kannst (und auch nicht diese Funktion aufrufen).
13. September 2008: 17:00
Ich habe deine Funktion mal so umgeschrieben, dass sie gleich mit der PHP-Funktion number_format ist. Dürfte für alle PHP-Entwickler interessant sein.
function number_format(numeral, decimals, dec_point, thousands_sep) {
var neu = '';
// Runden
var f = Math.pow(10, decimals);
numeral = '' + parseInt(numeral * f + (.5 * (numeral > 0 ? 1: -1))) / f;
// Komma ermittlen
var idx = numeral.indexOf('.');
// fehlende Nullen einfügen
if(idx != -1) {
numeral += (idx == -1 ? '.': '') + f.toString().substring(1);
}
// Nachkommastellen ermittlen
idx = numeral.indexOf('.');
if(idx == -1) idx = numeral.length;
else neu = dec_point + numeral.substr(idx + 1, decimals);
// Tausendertrennzeichen
while(idx > 0) {
if(idx - 3 > 0)
neu = thousands_sep + numeral.substring(idx - 3, idx) + neu;
else
neu = numeral.substring(0, idx) + neu;
idx -= 3;
}
return neu;
}
3. Januar 2009: 17:43
Besten Dank fuer diese Funktion. Ich setzte sie ein um Zahlen aus FileMaker Web Companion zu formatieren.
Ich habe das Script noch so korrigiert, dass auch Nachnullen bei Zahlen ohne Dezimalstellen angezeigt werden. Auch das Einfuegen der Tausendermarkierung bei negativen Werten wird jetzt korrekt ausgefuehrt.
function number_format(numeral, decimals, dec_point, thousands_sep) {
var neu = “;
// Korrektur bei negativer Zahl, Teil 1
var negativ = “;
if(numeral 0 ? 1: -1))) / f;
// Komma ermittlen
var idx = numeral.indexOf(‚.‘);
// fehlende Nullen einfügen
if(idx != -1) {
numeral += (idx == -1 ? ‚.‘: “) + f.toString().substring(1);
}
// Nachkommastellen ermittlen
idx = numeral.indexOf(‚.‘);
if(idx == -1) {
idx = numeral.length;
neu = ‚.00‘;
}
else neu = dec_point + numeral.substr(idx + 1, decimals);
// Tausendertrennzeichen
while(idx > 0) {
if(idx – 3 > 0)
neu = thousands_sep + numeral.substring(idx – 3, idx) + neu;
else
neu = numeral.substring(0, idx) + neu;
idx -= 3;
}
// Korrektur bei negativer Zahl, Teil 2
neu =negativ + neu;
return neu;
}
6. April 2009: 20:28
Das Script ist toll, aber könntest du bitte dein js-script bitte mir der Korrigierten PHP Version abbleichen bezüglich Tausendertrennzeichen bei negativen Zahlen.
Würde es ja gerne selbst machen, brings aber irgendwie nicht hin.
7. April 2009: 8:36
ist drin.
6. Oktober 2010: 9:16
Hi Struppi,
selten, dass Javascript so me-nothing-you-nothing funktioniert. Deine Funktion aber läudt SOFORT und arbeitet klasse.
Danke !
1. April 2011: 0:17
Ohm mann, ja das Runden ist immer so ein Problem. Man, ich hatte da auch ziemliche Probleme…
11. August 2011: 1:18
Ich bin ABSOLUTER JavaScript Anfänger (seit 2 Tagen :)) und selbst bei mir funktioniert die Funktion auf Anhieb! – PERFEKT … vielen Dank.
Gruß
Thom
15. November 2011: 16:58
Cooles Skript, aber auch hier wird ein zweiter Durchlauf mit einer Kommazahl mit „NaN“ quittiert. Wie kann ich dem Skript denn beibringen, als Dezimaltrenner das Komma zu akzeptieren?
Wenn ich richtig verstehe, wird die Zeile
‚var dec_point = ‚,‘;‘
ja nur beim Zusammenbauen des Strings für die Ausgabe genutzt…
Beim Eingang der Funktion müßte man doch nur prüfen, ob der Eingabewert (als String) ein Komma enthält, dieses dann durch einen Punkt ersetzen, die Funktion rechnen (runden) lassen und das Ergebnis wieder von Punkt auf Komma umformatieren. „Nur“. :)
Wenn ich’s könnte, würde ichs tun, JavaScript liegt mir aber nicht.
15. November 2011: 17:41
Interessanter und begründeter Einwurf. Ich guck mal, ob ich eine Lokalisierung konsequenter einbaue.
Du kannst dir aber vorläufig damit behelfen:
Aus progammiertechnischer Sicht ist das aber fragwürdig. Im Prinzip sollten Zahlen immer Zahlen sein und Formatierung nur bei der Ausgabe angewandt werdenn.
18. Juni 2012: 13:18
569.925 wird bei zwei Nachkommastellen auf 569.92 gerundet.
Sollte es nicht 569.93 sein?
20. Juni 2012: 13:21
Ja sollte es, tut es jetzt auch.
Da war vorher die die float <=> integer Konvertierung von JS im Weg. Der Fehler tritt sogar bei der JS Methode toFixed() auf.
alert((569.925).toFixed(2));
gibt ebenfalls 569.92 aus.
22. November 2013: 14:24
Vielen Dank für die Funktion – mit folgender Modifikation klappt diese bei uns perfekt :-)
Komplette Formatierung mit Aufruf im Input Feld:
Aufruf (php – deshalb “ statt „):
Funktion:
function format_zahl(numeral, decimals, id)
{
var neu = “;
var dec_point = ‚,‘;
var thousands_sep = ‚.‘;
numeral = numeral.replace(‚.‘, “);
numeral = numeral.replace(‚,‘, ‚.‘);
numeral = numeral.replace(/[^0-9\.]+/g, “);
// Runden
var f = Math.pow(10, decimals);
numeral = “ + parseInt(numeral * f + (.5 * (numeral > 0 ? 1: -1))) / f;
// Komma ermittlen
var idx = numeral.indexOf(‚.‘);
// fehlende Nullen einfügen
if(idx != -1)
{
numeral+=(idx == -1 ? ‚.‘: “)+f.toString().substring(1);
}
// Nachkommastellen ermittlen
idx = numeral.indexOf(‚.‘);
if(idx == -1) idx = numeral.length;
else neu = dec_point + numeral.substr(idx + 1, decimals);
// Tausendertrennzeichen
while(idx > 0)
{
if(idx – 3 > 0)
neu = thousands_sep+numeral.substring(idx – 3, idx)+neu;
else
neu = numeral.substring(0,idx)+neu;
idx -= 3;
}
document.getElementById(id).value = neu;
//alert (‚Test:’+numeral+decimals+dec_point+thousands_sep+‘ – ‚+neu+id);
}
29. Januar 2014: 10:07
Hallo,
klasse Script.
aber bei -100 kommt -.100,00
Wenn das noch geht, ist es perfekt.
Gruss Fogger
30. Januar 2014: 14:53
Doh – du hast recht!
Ich hab’s geändert, jetzt sollte es hoffentlich funktionieren.
Danke!
4. Februar 2014: 16:24
Man man man, da probiere ich eine Stunde über jQuery und dessen Plugin (welches seinerseits eine weitere .js-Datei benötigt) erfolglos Eingaben entsprechend zu formatieren, und dann finde ich diese schöne Funktion und… es klappt SOFORT! Vielen vielen Dank!!
9. März 2014: 14:39
Meistens gehts doch darum, einen Betrag mit zwei Nachkommastellen zu formatieren. Dann am kuerzesten:
function formatPreis( value ) {
value = Math.round( value * 100 );
var valText = “ + value;
var length = valText.length;
return valText.substr( 0, length – 2 ) + ‚,‘ + valText.substr( length – 2 );
}
9. März 2014: 14:49
Manches ist doch komplizierter, als es zuerst aussieht. Anbei meine Korrektur meiner vorherigen Funktion die fuer Werten kleiner 1 falsch formatiert hat:
function formatPreis( value ) {
value = Math.round( value * 100 );
var vorzeichen = value < 0 ? '-' : '';
value = Math.abs( value );
var valText = '' + value;
var length = valText.length;
if ( length < 3 ) {
valText = ( '000' ).substr( 0, 3 – length ) + valText;
length = valText.length;
}
return vorzeichen + valText.substr( 0, length – 2 ) + ',' + valText.substr( length – 2 );
}
10. März 2014: 9:12
Oder noch einfacher: value = value.toFixed(2);
Die im Artikel vorgestellte Funktion macht aber mehr.