<script>
window.onload = function(){ totalPrice = "<?=$_SESSION['total_price']?>"; }
var totalPrice = "<?=$_SESSION['total_price']?>";
Хранение данных в сессии никак не оправдывает substr(number_format($produc t['price'] * $quantity ,2), 0, 10), это глупость, ибо в контексте типа данных с которыми вы работаете, этого совсем не требуется, тем более htmlspecialchars и trim.
Об остальном тоже хорошо подумайте. Вы изначально поступаете непотребным способом, и ваш код грешит тем, что может огрести кучу мусора, и скушать его.
|