1

テーブル行を生成する php コードがあります。

    <table id="listOfProducts" name="listOfProducts" width="100%">
    <tr>
    <th>Item</th>
    <th>Product</th>
    <th>Description</th>
    <th>Unit Price</th>
    <th>Select</th>
    <th>Qty</th>
    <th>Amount</th>
    </tr>
    Products on List: 2
    <tr class="row1" id="tr1">
    <td id="pid1">1</td>
    <td id="pname1">Paint Brush</td>
    <td id="pdesc1">Premium Brand </td>
    <td id="pprice1">24</td>
    <td><input type="checkbox" id="chk1" checked></td>
    <td><input type="text" style="width:50px;" onkeyup="getall('tr1','ttp1')" id="1"/></td>
    <td><input type="text" id="ttp1" name="ttp1" value="00"/></td>
    </tr>
    <tr class="row1" id="tr2">
    <td id="pid2">2</td>
    <td id="pname2">Iron Nails</td>
    <td id="pdesc2">Stainless</td>
    <td id="pprice2">50</td>
    <td><input type="checkbox" id="chk2" checked></td>
    <td><input type="text" style="width:50px;" onkeyup="getall('tr2','ttp2')" id="2"/></td>
    <td><input type="text" id="ttp2" name="ttp2" value="00"/></td>
    </tr>
    </table>

これにより、テーブルに値が正常にロードされ、onkeyup 関数が呼び出されると、javascript getall が呼び出されます。

ここにJavaScriptコードがあります

    function getall( strId, prdno){
var tmpObj = document.getElementById(strId);
var myobj = $("#listOfProducts").find("tr#" + strId);
     alert("reported id for testing: " + tmpObj.getAttribute("id"));
 //alert (prdno);
    var prdid= myobj.find('td:eq(0)').text();
    var prdname= myobj.find('td:eq(1)').text();
    var prddesc= myobj.find('td:eq(2)').text();
var prduprice = parseFloat(myobj.find('td:eq(3)').text());
var quan = myobj.find('td:eq(5) input').val();
var ans=prduprice * quan;
document.getElementById(prdno).value=ans;       
    }

何が本当の問題なのかわからない。含まれているテキストボックスのIDが正常に渡されたかどうかを確認しました...

4

2 に答える 2

0

コードをコピーして貼り付け、上部に jquery インクルード (v1.7.2) を追加しただけで、Opera、FF、Chrome で完全に動作します

于 2013-07-31T17:03:25.467 に答える