web-dev-qa-db-ja.com

2つのボタンがあるフォームからボタンクリックでAjaxリクエストを送信するにはどうすればよいですか?

こんにちは。ここで少し一般的な質問をして申し訳ありません。私はAjaxを初めて使用し、2つのボタンがあるフォームから1つのページから別のページにリクエストを送信したいと考えています。

<form method="post">
  <button id="button_1" value="val_1" name="but1">button 1</button>
  <button id="button_2" value="val_2" name="but2">button 2</button>
  <input id="access_token" type="hidden" name="access_token" value="<?php echo $_SESSION['access_token']; ?>" />
</form>
$(document).ready(function() {
  $("#button_1").click(function(e) {
    e.preventDefault();
    $.ajax({
      type: "POST",
      url: "/pages/test/",
      data: {
        id: $("#button_1").val(),
        access_token: $("#access_token").val()
      },
      success: function(result) {
        alert('ok');
      },
      error: function(result) {
        alert('error');
      }
    });
  });

  $("#button_2").click(function(e) {
    e.preventDefault();
    $.ajax({
      type: "POST",
      url: "/pages/test/",
      data: {
        id: $("#button_2").val(),
        access_token: $("#access_token").val()
      },
      success: function(result) {
        alert('ok');
      },
      error: function(result) {
        alert('error');
      }
    });
  });
});

このコードを改善し、おそらくそれを1つの関数または何かにマージする方法を提案している人はいますか?

前もって感謝します! :)

20
Max Maxymenko

ハンドラ間の唯一の論理的な違いは、クリックされたボタンの値であるため、thisキーワードを使用して、イベントを発生させた要素を参照し、そこからval()を取得できます。これを試して:

$("button").click(function(e) {
    e.preventDefault();
    $.ajax({
        type: "POST",
        url: "/pages/test/",
        data: { 
            id: $(this).val(), // < note use of 'this' here
            access_token: $("#access_token").val() 
        },
        success: function(result) {
            alert('ok');
        },
        error: function(result) {
            alert('error');
        }
    });
});
31
Rory McCrossan

2つの関数の唯一の違いがトリガーされるボタンの値である場合は、 jQuery multiple-selector を使用します。

$("#button_1, #button_2").on("click", function(e) {
    e.preventDefault();
    $.ajax({type: "POST",
        url: "/pages/test/",
        data: { id: $(this).val(), access_token: $("#access_token").val() },
        success:function(result) {
          alert('ok');
        },
        error:function(result) {
          alert('error');
        }
    });
});
5
kolunar
function sendAjaxRequest(element,urlToSend) {
             var clickedButton = element;
              $.ajax({type: "POST",
                  url: urlToSend,
                  data: { id: clickedButton.val(), access_token: $("#access_token").val() },
                  success:function(result){
                    alert('ok');
                  },
                 error:function(result)
                  {
                  alert('error');
                 }
             });
     }

       $(document).ready(function(){
          $("#button_1").click(function(e){
              e.preventDefault();
              sendAjaxRequest($(this),'/pages/test/');
          });

          $("#button_2").click(function(e){
              e.preventDefault();
              sendAjaxRequest($(this),'/pages/test/');
          });
        });
  1. ajaxリクエストを送信するための個別の関数として作成されます。
  2. 将来的に別のURLにデータを送信するため、2番目のパラメーターをURLとして保持
4
Alankar More