1

入力画像をクリックするか、他の方法で、入力(画像)IDとして保存されている変数をフォームに渡すプラグインを作成したい

================================================== =======================================

<?php
echo $_POST['id'];
?>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Kunfu Panda</title>
<link href="css/main.css" rel="stylesheet" type="text/css" media="projection,screen" />
</head>
<body>
    <div class="wrapper" >
        <form action="panda.php" method="post" class="openid_provider" />
             <input type="image" src="images/google_button.png" id="google" /> 
         </form>    
  </div>
<script type="text/javascript" src="js/test.js"></script>
<script type="text/javascript" src="js/jquery-ui-1.8.19.custom.min.js"></script>
<script type="text/javascript">  
$(document).ready(function(){
    $('form').openid(); 
})
</script>
</body>
</html>

================================================== =============================

私のプラグインはopenid(test、js)です

(function($){
    $.fn.openid = function() {
        $('input').click(function(){
        var provider = $(this).attr('name');
        $(this).submit(provider);   
        })
        }
})(jQuery);

これで、IDが「google」の入力であるGoogle画像をクリックするとフォームが送信されますが、同じページのフォームアクションは$_POST['provider']変数を認識できません。

私を助けてください。

4

1 に答える 1

0

これを試して:

<?php
  var_dump($_POST);
?>

<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>Kunfu Panda</title>
  <link href="css/main.css" rel="stylesheet" type="text/css" media="projection,screen" />
  <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.js"></script>
  <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.18/jquery-ui.js"></script>
  <script type="text/javascript" src="js/test.js"></script>
</head>
<body>
  <div class="wrapper" >
    <form action="panda.php" method="post" class="openid_provider" />
      <input type="image" src="images/google_button.png" id="google"/> 
    </form>
  </div>
</body>
<script type="text/javascript">  
  $(document).ready(function(){
    $('form').openid(); 
  })
</script>

js:

(function($){
  $.fn.openid = function() {
    $('input').click(function(e){
      var provider = $(this).attr('id');  //get id
      var myinput = $('<input type="hidden" name="provider"/>').val(provider);
      $('form').append(myinput);
      $('form').submit();
    })
  }
})(jQuery);
于 2012-04-30T04:14:16.143 に答える