2013-03-18 124 views
1
我有執行多個成功事件中的成功功能的問題

,讓我告訴你的代碼:jQuery Mobile的數據庫成功事件不會觸發功能

$("#beneficiarios").one("pagebeforeshow", function(){ 

    db.transaction(function(tx){ queryDBAll(tx, "Beneficiarios", 0, 10) }, onError); //LOAD BENEFICIARIOS IN DB 

    $("#btn-add-ben").click(function(){ 
     var nombres = $('#b_nombres').val(); 
     var apellidos = $('#b_apellidos').val(); 
     var dia = $('#b_dia').val(); 
     var mes = $('#b_mes').val(); 
     var año = $('#b_año').val(); 
     var fecha_nac = año+"-"+mes+"-"+dia; 

     //ADD BENEFICIARIO TO DB 
     db.transaction(function(tx){ 
      tx.executeSql("INSERT INTO Beneficiarios (nombres, apellidos, fecha_nac) VALUES ('"+nombres+"','"+apellidos+"','"+fecha_nac+"')", 
      [], 
      function(tx, results){ 
       var benid = results.insertId; 
       $('#emptyBeneficiarios').remove(); 
       $('#ul-beneficiarios').append(
      '<li><a href="#" id="view_ben_'+benid+'">'+nombres+' '+apellidos+'</a><a href="#" id="del_ben_'+benid+'" data-position-to="window" data-icon="delete" class="itemDelete">Eliminar</a></li>').listview('refresh'); 
       $("#del_ben_"+benid).click(function(){ 
        //PENDING: CONFIRM DIALOG 
        db.transaction(function(tx){ 
        tx.executeSql("DELETE FROM Beneficiarios WHERE ID = "+benid), 
        [], 
        console.log(benid+" borrado con éxito!"), 
        onError 
        }); 
       }); 
       $("#view_ben_"+benid).click(function(){ 
        db.transaction(function(tx){ 
        tx.executeSql('SELECT * FROM Beneficiarios WHERE ID = '+benid), 
        [], 
        //SUCCESS ACTION! -- NOT WORKING 
        function(tx, results) { 
         $('#b_nombres').val(results.rows.item.nombres); 
         $('#b_apellidos').val(); 
         $('#b_dia').val(); 
         $('#b_mes').val(); 
         $('#b_año').val(); 
         console.log(benid+" shown successfully!") //IS NOT SHOWN AT ALL 
        } 
        console.log(benid+" mostrado shown successfully without function!") //SHOWN AS DESIRED 
        , 
        onError 
        }); 
       }); 
      }, 
      onError); 
     }, 
     onError); 
     }); 

    $("#ul-beneficiarios").delegate("li a", "click", function() { 
     $(this).parent("li").remove(); 
     var li_num = $('#ul-beneficiarios li').length; 
     if (li_num == 1) { 
      addEmptyBeneficiarios('#ul-beneficiarios'); 
     } 
     }); 
}); 

正如你可以想像我有李的UL那當單擊ADD按鈕時會被添加,一切正常,包括DB執行。

問題是,當我點擊$(「#view_ben _」+ benid)它正常運行,但它不能正確執行SELECT成功函數,雖然它確實顯示了console.log設置在成功函數之外。任何人有任何想法?

回答

0

好吧,我想通了: 在下面一行中,您直接關閉executeSql函數,忽略了函數體中未使用的其餘參數。換句話說:缺少一個支架;)。

tx.executeSql('SELECT * FROM Beneficiarios WHERE ID = '+benid), 

你的語法更改爲下面的例子:

db.transaction(function(tx){ 
    tx.executeSql(
     ("DELETE FROM Beneficiarios WHERE ID = "+benid), // SQL COMMAND 
     [],            // NO IDEA WHAT THAT IS FOR 
     console.log("success"),       // SUCCESS CALLBACK 
     onError           // ERROR CALLBACK 
    ); 
}); 

我想指出的是您正在惡補了過多的功能相互轉化。考慮將綁定,成功和錯誤功能外包到頂層,以防止像Matryoshka代碼這樣的Inception。