[Aktualisieren]
Die ursprüngliche Antwort wurde vor jQuery 1.3 geschrieben, und die zu diesem Zeitpunkt vorhandenen Funktionen waren für sich genommen nicht ausreichend, um die gesamte Breite zu berechnen.
Wie JP korrekt angibt, verfügt jQuery nun über die Funktionen OuterWidth und OuterHeight, die standardmäßig das borderund enthalten padding, sowie das marginif-Argument, wenn das erste Argument der Funktion lautettrue
[Ursprüngliche Antwort]
Die widthMethode benötigt das dimensionsPlugin nicht mehr , da es dem hinzugefügt wurdejQuery Core
Was Sie tun müssen, ist, die Werte für Auffüllen, Rand und Randbreite dieses bestimmten Div abzurufen und sie zum Ergebnis der widthMethode hinzuzufügen
Etwas wie das:
var theDiv = $("#theDiv");
var totalWidth = theDiv.width();
totalWidth += parseInt(theDiv.css("padding-left"), 10) + parseInt(theDiv.css("padding-right"), 10); //Total Padding Width
totalWidth += parseInt(theDiv.css("margin-left"), 10) + parseInt(theDiv.css("margin-right"), 10); //Total Margin Width
totalWidth += parseInt(theDiv.css("borderLeftWidth"), 10) + parseInt(theDiv.css("borderRightWidth"), 10); //Total Border Width
In mehrere Zeilen aufteilen, um die Lesbarkeit zu verbessern
Auf diese Weise erhalten Sie immer den richtigen berechneten Wert, auch wenn Sie die Auffüll- oder Randwerte aus dem CSS ändern