JQuery UI Dialog Ajax PHP无法进行第二次提交

时间:2013-02-28 05:19:11

标签: php jquery jquery-ui-dialog

我有一个标准设置。我有一个提供数据的php页面。数据中有一些编辑链接。我的问题是,在我编辑了一些数据后,第二次点击编辑链接时,我的JQuery-UI会打开传递给它的url而不是填充JQuery-UI.dialog。

基页Java(view.php)

   var editParyAddress = $('#edit_party_address').dialog({
      autoOpen: false,
      width:'auto',
      modal: true,
      buttons: {
        'Save': function(){
          $.ajax({
            url: '/party_address/save.php',
            type: 'POST',
            data: $('#edit_party_address_form').serialize(),
            success: function(data){
              $.get('helper.php?function=partyaddress&id=<?php echo $_GET['id'];?>',function(data){$('#partyaddress').html(data);});
              //$('#edit_party_address').dialog('close');
              $('#edit_party_address').dialog("destroy").remove();
            }
          });
        }
      }
    });

    $('.edit_party_address').click(function(e){
      e.preventDefault();
      $.ajax({
        url: $(this).attr('href'),
        type: 'POST',
        success: function(data){
          editParyAddress.html(data);
          editParyAddress.dialog('open');
          return false;
        }
      });
    });

将数据提供给JQuery-UI.dailog(edit.php)的PHP页面

$sql="SELECT dbo.format_full_name(p.first_name,p.middle_name,p.last_name) name, dp.party_id, pa.id partyaddressid, pa.address1,pa.address2,pa.city,pa.state,pa.zip_code,pa.address_indicator_id,pa.is_active
FROM [".DB1."].[DBO].[party_address] pa
INNER JOIN debt_party dp on dp.party_id=pa.party_id
INNER JOIN party p on p.id=pa.party_id
where pa.id=".$_GET['party_address_id'];
$HTML='';
$conn =db_connect();
$stmt = sqlsrv_query($conn, $sql,array(),array( "Scrollable" => 'keyset' ));
if( $stmt === false) { error($_SERVER['PHP_SELF'],__FUNCTION__,__LINE__);return;}

$HTML= '<form name="edit_party_address_form" id="edit_party_address_form" style="width:100%" action="">';
if ($stmt===false) {return;}
if (sqlsrv_has_rows( $stmt )=== false){return;}
$row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_ASSOC);
$HTML.='<fieldset>';
$HTML.='<ol>';
$HTML.='<li><label for="address_address1">Address 1:</label><input class="text-input" id="address1" name="address1" size="30" type="text" value="'.$row['address1'].'"></li>';
$HTML.='<li><label for="address_address2">Address 2:</label><input class="text-input" id="address2" name="address2" size="30" type="text" value="'.$row['address2'].'"></li>';
$HTML.='<li><label for="address_city">City:</label><input class="address" id="address_city" name="address_city" size="30" type="text" value="'.$row['city'].'"></li>';
$HTML.='<li><label for="address_state">State:</label><input class="state" id="address_state" name="address_state" maxlength="2" size="2" type="text" value="'.$row['state'].'"></li>';
$HTML.='<li><label for="address_zip_code">Zip Code:</label><input class="zip_code" id="address_zip_code" maxlength="10" name="address_zip_code" size="10" type="text" value="'.$row['zip_code'].'"></li>';
$HTML.='<li><label for="name">Indicator:</label>'.HTMLOptions(DB1,'dbo','address_indicator','id','name',$row['address_indicator_id']).'</li>';
$HTML.='<li><label for="is_active">Active:</label><input '.($row['is_active']==1? ' checked="checked"':'').' name="is_active" maxlength="2" size="2" type="checkbox" value="'.$row['is_active'].'"></li>';
$HTML.='<li><input id="party_address_id" name="party_address_id" type="hidden" value="'.$_GET['party_address_id'].'"></li>';
$HTML.='</ol>';

$HTML.='</fieldset>';
$HTML.='</form>';
sqlsrv_free_stmt( $stmt);
echo $HTML;

PHP保存页面(save.php)

$sql="UPDATE party_address SET address1='".$_POST['address1']."',address2='".$_POST['address2']."'  WHERE id=".$_POST['party_address_id'];   

    $conn =db_connect();
    $stmt = sqlsrv_query($conn, $sql,array(),array( "Scrollable" => 'keyset' ));
    if( $stmt === false) { error($_SERVER['PHP_SELF'],__FUNCTION__,__LINE__);return;}
    sqlsrv_free_stmt( $stmt);

当我点击看起来像这样的编辑链接时:/party_address/edit.php?party_address_id=1468941这一切都很完美。一旦我提交了已发布的表单更改,它就会更新数据库和view.php基页。提交更改后,第二次单击任何编辑链接时,链接将使用默认行为,并且浏览器地址将更改为编辑链接。这只显示了我的view.php页面的内部HTML。它应该在JQuery-UI.dialog <div id="edit_party_address" title="Edit Party Address"></div>

中打开

1 个答案:

答案 0 :(得分:0)

我改变了两行 基页Java(view.php) 为清楚起见,我只是留下他们在这里评论。现在它有效!!!

var editParyAddress = $('#edit_party_address').dialog({
  autoOpen: false,  width:'auto',  modal: true,
  buttons: {
    'Save': function(){
      $.ajax({
        url: '/party_address/save.php',
        type: 'POST',
        data: $('#edit_party_address_form').serialize(),

        success: function(data){
          alert(data);
          $.get('helper.php?function=partyaddress&id=<?php echo $_GET['id'];?>',function(data){$('#partyaddress').html(data);});
          $('#edit_party_address').dialog('close');
          //$('#edit_party_address').dialog("destroy").remove();
        }
      });
    }
  }
});
// $('.edit_party_address').click(function(e){
$(document).on('click', '.edit_party_address', function (e) {
    e.preventDefault();
    $.ajax({
    url: $(this).attr('href'),
    type: 'POST',
    success: function(data){
      editParyAddress.html(data);
      editParyAddress.dialog('open');
      return false;
    }
  });
});