|
data:image/s3,"s3://crabby-images/9df89/9df89c83e8c1e31438585f2c965544b2676fc113" alt="" |
|
ปัญหา การ คำนวณ totalprice ของสินค้าคำนวณ สินค้าที่มี 1 Recordไม่ได้ แต่คำนวณที่มีมากกว่า 1 Record ได้ ขอทราบวิธีแก้ทีคับ |
|
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
ปัญหาคือ ถ้าเราเลือก บริษัทคู่ค้าจาก list ที่มี ข้อมูลมากกว่า 1recordคือ 2ขึ้นไป ก็จะคำนวณ ยอดรวมต่างๆได้ แต่ถ้าเลือก แล้วมีข้อมูลแค่ 1record ก็จะคำนวณไม่ได้
Code (JavaScript)
function calcTotals()
{
var grandTotal = 0;
var row = 0;
while (document.forms['form1'].elements['numpro[]'][row])
{
priceObj = document.forms['form1'].elements['numpro[]'][row];
qtyObj = document.forms['form1'].elements['numper[]'][row];
totalObj = document.forms['form1'].elements['total[]'][row];
if (isNaN(priceObj.value))
{
priceObj = '';
}
if (isNaN(qtyObj.value))
{
qtyObj = '';
}
if (priceObj.value && qtyObj.value)
{
totalObj.value = (parseFloat(priceObj.value) * parseFloat(qtyObj.value));
grandTotal = grandTotal + parseFloat(totalObj.value);
}
else
{
totalObj.value = '';
}
row++;
}
document.getElementById('grand_total').value = grandTotal;
return;
}
<form name="form1" action="<?php echo htmlentities($_SERVER['PHP_SELF']); ?>" method="POST" >
<label>รหัสใบเสนอ</label> <input type="text" size="15px" name="quoteid" readonly="readonly" value = "<?php echo $result1 ?>"/ >
<label>เสนอโดย</label> <input type="text" size="15px" name="empid" value = "<?php echo $result2['EMP_NAME']?> <?php echo $result2['EMP_LNAME'] ?>" readonly="readonly">
<label>วันที่</label> <input type = "text" size="15px" name="date" value = "<?php echo date("d-m-Y"); ?>" readonly="readonly"></br>
<label>บริษัทคู่ค้า</label> <select name="company" onchange="loadData(this.options[this.selectedIndex].value)">
<option value="-2">Select Company</option>
<option value="-1">Select All</option>
<?php
$sql = "SELECT * FROM company order by COM_NAME asc";
$obj->query($sql);
while($objResult = $obj->fetch_array()){
?>
<option value="<?php echo $objResult['COM_ID']?>" ><?php echo $objResult['COM_NAME']?></option>
<?php
}
?>
</select>
<div id="txtHint"></div></br>
<div>ราคารวมทั้งหมด<input type="text" id="grand_total"readonly="readonly" value="0"></div>
<input type="submit" name ="submit" value ="เพิ่มรายการเสนอ"/>
<button type="button" onClick="location.href='main_page.php'" >ยกเลิก</button></br>
</form>
Code (PHP)
<?php
require('Core.php');
$obj = new Core;
if(!isset($_POST['loadId']) )
{
echo "<script language='javascript'> alert('No Data');</script>";
}
$loadId = $_POST['loadId'];
if(isset($_POST['loadId']))
{
if($_POST['loadId'] != -1)
{
$sql = "SELECT * FROM product,product_color,model,brand,product_type,color WHERE product.COM_ID = '".$loadId."' and product.PRO_ID = product_color.PRO_ID and
product.MODEL_ID = model.MODEL_ID and product.BRAND_ID = brand.BRAND_ID and product.PRO_TYPE_ID = product_type.PRO_TYPE_ID and product_color.COLOR_ID = color.COLOR_ID";
$tmp = $obj->query($sql);
$check = $obj->num_rows();
}
else
$sql = "SELECT * FROM product,product_color,model,brand,product_type,color WHERE product.PRO_ID = product_color.PRO_ID and
product.MODEL_ID = model.MODEL_ID and product.BRAND_ID = brand.BRAND_ID and product.PRO_TYPE_ID = product_type.PRO_TYPE_ID and product_color.COLOR_ID = color.COLOR_ID";
$tmp = $obj->query($sql);
$check = $obj->num_rows();
}
else
echo "<script language='javascript'>alert('Error ');window.location='quote.php';</script>";
if($check > 0)
{
$HTML="";
echo "<table width='75%'' border='1' cellspacing='2' cellpadding='0'>
<tr>
<th>รหัสสินค้า</th>
<th>ประเภท</th>
<th>ยี่ห้อ</th>
<th>รุ่น</th>
<th>สี</th>
<th>จำนวนที่เสนอ</th>
<th>ราคา/หน่วย</th>
<th>ราคารวม</th>
</tr>";
while($row = $obj->fetch_array()){
$pro = $row['PRO_ID'];
echo "<tr>";
echo "<td align='center' >" .$row['PRO_ID'] . "</td>";
echo "<td align='center'>" . $row['PRO_TYPE_NAME'] . "</td>";
echo "<td align='center'>" . $row['BRAND_NAME'] . "</td>";
echo "<td align='center'>" . $row['MODEL_NAME'] . "</td>";
echo "<td align='center'>" . $row['COLOR_NAME'] . "</td>";
echo "<td align='center'>" .'<input type="number" name="numpro[]" onchange="calcTotals()" >' . "</td>";
echo "<td align='center'>" .'<input type="number" name="numper[]" onchange="calcTotals()" >' . "</td>";
echo "<td align='center'>" .'<input type="number" name="total[]" id="total" readonly="readonly">' . "</td>";
echo "<td>" .'<input type="checkbox" name="select[]" id="select" ' .'onclick="checkAll(this)" value ="'. $pro .'" >'. "</td>";
}
echo "</table>";
echo $HTML;
}
?>
Code
Tag : PHP, HTML/CSS, JavaScript, Ajax
data:image/s3,"s3://crabby-images/f1944/f19447657087fec8fe853572ff7e2abde431999d" alt=""
|
ประวัติการแก้ไข 2014-12-01 21:55:47
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2014-12-01 21:51:47 |
By :
top113457 |
View :
805 |
Reply :
1 |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
อ่านโค๊ดแล้วงงครับ
numpro[] numper[] total[] อยู่ใน form1 ตรงไหนครับ
ถึงได้เขียนอ้างอิง docuement.forms[form1].elements[..] ได้ครับ
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2014-12-02 09:18:42 |
By :
Chaidhanan |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/f3b89/f3b89ccde25850c65b928bee7cddda844ab028bb" alt=""
|
Load balance : Server 03
|