1

HTML5/JqueryMobileは初めてです。私はこの関数を持っていますが、奇妙な理由で、Onclick()によって2回目に呼び出したときに結果が得られます。これが私のコードです:

function ListDBValues() {
  if (!window.openDatabase) { 
    alert('Databases are not supported in this browser.'); 
    return; 
 }
$('#lbUsers').html(''); 
db.transaction(function(transaction) { 
   transaction.executeSql('SELECT * FROM productos order by titulo;', [], 
   function(transaction, result) { 
      if (result != null && result.rows != null) { 
        for (var i = 0; i < result.rows.length; i++) { 
          var row = result.rows.item(i); 
          $('#lbUsers').append('<div id="producto"><img id="imgprod" width="100" src="images/' + row.foto +'">' + row.recid + '.' + row.titulo + '<br>$' + row.precio + ' MXP<br><input class="cuadro" type="button" id="cb.row" name="item"  value="ORDENAR" onclick=AddValueToOrders(' + row.recid + ');></div>');

        } 
      } 
     },errorHandler); 
 },errorHandler,nullHandler);
 return; 
}

これは2番目の関数です:

 function AddValueToOrders(item) {  
    if (!window.openDatabase) { 
      alert('Databases are not supported in this browser.'); 
      return; 
    } 
    msga = "El item es: "+ item ;
    alert(msga);
    db.transaction(function(tx) { 
        /// veo si ya existe /////

        tx.executeSql('SELECT count(*) AS c FROM orders where prodid = '+ item +'  ', [], 
        function (tx, result) { 
               totprod = result.rows.item(0).c;
               //totprod = results.rows.item(0)['c'];

        });
    });

    var themessage = "Total producto: ";
    themessage = themessage + totprod ;
    alert(themessage);                 

} 

問題は、製品がOrdersテーブルにすでに存在するかどうかを知りたいので、同じコードの別の製品を挿入せずに更新できます。

4

1 に答える 1

0

実際には答えではありませんが、コードをリファクタリングしてコメントを追加しました。質問に対する元のコメントも確認する必要があります。

function ListDBValues() {
    if (!window.openDatabase) { 
        alert('Databases are not supported in this browser.'); 
        return; 
    }
    $('#lbUsers').html(''); 
    db.transaction(function(transaction) { 
        transaction.executeSql('SELECT * FROM productos order by titulo;', [], 
        function(transaction, result) { 
            if (result != null && result.rows != null) { 
                for (var i = 0; i < result.rows.length; i++) { 
                    var row = result.rows.item(i);
                    // changed the append logic
                    // created new dom object w/jQuery
                    // bind tap event
                    // execute function on tap
                    // append to dom
                    $('<div id="producto"><img id="imgprod" width="100" src="images/' + row.foto +'">' + row.recid + '.' + row.titulo + '<br>$' + row.precio + ' MXP<br><input class="cuadro" type="button" id="cb.row" name="item"  value="ORDENAR"></div>').data( 'recid', row.recid ).bind('tap', function(){
                        AddValueToOrders( $(this).data('recid') );
                    }).appendTo('#lbUsers');
                } 
            } 
        }, errorHandler); 
    }, errorHandler, nullHandler);
    return; 
}
function AddValueToOrders(item) {  
    if (!window.openDatabase) { 
        alert('Databases are not supported in this browser.'); 
        return; 
    } 
    msga = "El item es: "+ item ;
    alert(msga);
    db.transaction(function(tx) { 
        /// veo si ya existe /////
        tx.executeSql('SELECT count(*) AS c FROM orders where prodid = '+ item +'  ', [], 
        function (tx, result) { 
            totprod = result.rows.item(0).c;
            //totprod = results.rows.item(0)['c'];
            alert("Total producto: " + totprod);
            // you can do your insert here depending on 
            // the value you got back from this checkpoint
        });
    });
}

これでうまくいくかどうか教えてください。

更新: また、forループで作成している要素でIDを使用しています。これにより、IDが一意であることが意図されているため、競合が発生することを知っておく必要があります。IDをクラスに変更したくない場合があります。

于 2012-05-29T20:05:42.337 に答える