1

少しライブにするために、いくつかのphpコードとjqueryを書いています。クリックしてdivを表示するセルテーブルがあります。html は次のようなものです。

<table>
 <tr id="line-157"><td id="cell1-157" class="edit"></td><td id="cell2-157"></td></tr>
 <tr><td id="w_157"></td><td id="p_157"></td></tr>
 <tr id="line-158"><td id="cell1-158" class="edit"></td><td id="cell2-158"></td></tr>
 <tr><td id="w_158"></td><td id="p_158"></td></tr>
 <tr id="line-159"><td id="cell1-159" class="edit"></td><td id="cell2-159"></td></tr>
 <tr><td id="w_159"></td><td id="p_159"></td></tr>
</table>

jquery:

$(document).ready(function() {
        $('.edit').bind('click', function() {
                var a = this.id.split('-') ;
                var name_id = a[1] ;
                $('#w_'+name_id).fadeIn();
                $.get('minirpc.php',{
                        subcontrol: 'select_id',
                        id: name_id
                },function(data){
                        $('#w_'+name_id).html(data);
                })
                $.get('minirpc.php',{
                        subcontrol: 'select_pay_id',
                        id: name_id
                },function(data){
                        $('#p_'+name_id).fadeIn();
                        $('#p_'+name_id).html(data);
                })
                return false;
        });
});

クリックごとに1回ではなく、複数回コールバックを取得します。1 回クリックすると OK、2 回クリックすると 4 回ループ、3 回クリックすると 16 回ループ、というように... 何かアイデアはありますか?

編集:

コメントを読むソフトウェアアーキテクチャの問題である可能性があると考えてdataいます.minirpc.phpはjsファイルを呼び出すclass_overbooking.phpを呼び出すため、出力にはjavascriptが含まれています。ファイルは次のとおりです。

  • minirpc.php
  • class_overbooking.php
  • js/init_overbooking.js
  • js/overbooking.js

minirpc.php 内:

<?
    include('class_overbooking.php');
    switch($subcontrol){
        case ...
        case quote_select:
        break;
        case quote_pay_id:
        break;
    }    
?>

class_overbooking.php 内:

<script type="text/javascript" src="http://www.google.com/jsapi"></script>
<script type="text/javascript" src="js/init_overbooking.js"></script>
<script type="text/javascript" src="js/overbooking.js"></script>
<?
        php class functions mixed jquery
?>

js/init_overbooking.js 内:

google.load("jquery", "1.7.1");
google.load("jqueryui", "1.8.13");
google.setOnLoadCallback(function() {
// ![CDATA[
            various sfuff
// ]]
});

js/overbooking.js 内:

$(document).ready(function() {

   (...)

     $('.edit').live('click', function() {
            var a = this.id.split('-') ;
        var name_id = a[2] ;
        var count = 0 ;
        var start = new Date().getTime();
            $('#w_'+name_id).fadeIn();
        var elapsed1 = new Date().getTime() - start;
                $('#jdebug1').html() ;
                $.get('minirpc.php',{
                        subcontrol: 'quote_select',
                        id: name_id
                },function(data){
                        $('#w_'+name_id).html(data);
                        var elapsed2 = new Date().getTime() - start;
                        $('#jdebug1').append('|('+name_id+')elapsed2:'+elapsed2+'ms ') ;
                });
                $.get('minirpc.php',{
                        subcontrol: 'quote_pay_id',
                        id: name_id
                },function(data){
                        $('#p_'+name_id).fadeIn();
                        $('#p_'+name_id).html(data);
                var elapsed3 = new Date().getTime() - start;
                        $('#jdebug1').append('|('+name_id+')elapsed3:'+elapsed3+'ms ') ;
                });
        return false;
    });

});

独自のセレクター クラスでも試してみましたが、名前「edit」を「edit-rev123」に変更する問題は同じです。

なにか提案を?

4

0 に答える 0