0

javascriptで開くphpのポップアップフォームがあります。[送信]をクリックしたときに、これをデータベースに送信したいと思います。phpフォームはjavascriptがなくても正常に機能しますが、追加すると機能しません。これを解決する方法を教えてください。

 </style>
 <script type='text/javascript'>
 $(document).ready(function() {
  $('#box_form').dialog({
    autoOpen: false,
    height: 375,
    width: 350,
    modal: true,
    buttons: [
        {
        text: "Cancel",
        click: function() {
            $(this).dialog("close");
        }},
    {
        text: "Submit",
        click: function() {
            $('#former').submit();
        }}
    ]
});
$('#clicky').button().click(function(e){
    $('#box_form').dialog('open');
});
  });
    </script>
    </head>
   <body>
   <form id="former" method="post" action="film_post.php" name="former">
  <div id="box_form">
   <select id="option" name="option">
                    <option value="film">film</option>
                    <option value="livre">livre</option>
                    <option value="musique">musique</option>            
            </select></p>
    <p>
    <select id="star" name="star">
                    <option value="1">1</option>
                    <option value="2">2</option>
                    <option value="3">3</option> 

            </select></p>
    <label for="nom">nom</label> :  <input type="text" name="nom" id="nom" /><br />

 </div>
 </form>
 <input type="button" id="clicky" value="Show Form">

そしてfilm_post.phpファイルは次のとおりです。

  try
  {
$bdd = new PDO('mysql:host=localhost;dbname=website', 'root', 'root');
   }
  catch(Exception $e)
 {
    die('Erreur : '.$e->getMessage());
   }

    $option = $_POST['option'];
      $star = $_POST['star'];

    if ($option == film AND $star = 1) {
   $req = $bdd->prepare('INSERT INTO film (film, star) VALUES(?,?)');
     $req->execute(array($_POST['nom'],$_POST['star'] )); }

     elseif ($option == film AND $star = 2) {
    $req = $bdd->prepare('INSERT INTO film (film, star) VALUES(?,?)');
    $req->execute(array($_POST['nom'],$_POST['star'] )); }

     elseif ($option == film AND $star = 3) {
   req = $bdd->prepare('INSERT INTO film (film, star) VALUES(?,?)');
   $req->execute(array($_POST['nom'],$_POST['star'] )); }
4

1 に答える 1

0

どうやらまだ画像を投稿できないようです。そのため、以下の回答で話している画像へのリンクを次に示します。http://i.stack.imgur.com/xgExo.png

実際のコードにあると思われる必要なスクリプト src タグを取得してコードを実行したところ、同じ問題が見つかりました。jchapa が提案したように、firebug コンソールを見た後、上の画像に表示されているものを見つけました。

あなたが使用しているjquery uiは、「」テキストに下線を引いたところに見られるように、それらの陽気なグラフィックスを提供するだけでなく、フォームタグを途中で終了させるような方法でfromを書き換えます。

これをどのように修正するかはわかりませんが、そこに問題があります。この jquery ui でフォームを設定する方法をオンラインで調べるか、ダイアログから独自のフォームを作成することを検討してください。確かに、グラフィックはそれほど滑らかではありません。

于 2012-12-13T01:15:17.550 に答える