使用javascript提交php弹出窗体

时间:2012-12-13 00:23:21

标签: php javascript

我在php中弹出一个由javascript打开的表单。我希望在点击提交时将其发送到我的数据库。没有javascript的PHP表单工作正常,但添加后它不起作用。你知道如何解决这个问题吗?

 </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'] )); }

1 个答案:

答案 0 :(得分:0)

显然我还不能发布图片,所以这里是我在下面的答案中谈到的那个链接。 http://i.stack.imgur.com/xgExo.png

我执行了你的代码,抓住了必要的脚本src标签,我认为你在实际代码中有这些标签,并且发现你遇到了同样的问题。在查看firechaug控制台后,就像jchapa建议的那样,我找到了你在上面的图片中看到的内容。

你正在使用的jquery ui以这样一种方式重写你的内容,它不仅会给它带来那些起泡的图形,而且还会过早地终止你的表单标签,就像我在下面加上“”文本一样。

你如何解决这个问题,我不知道,但这就是你的问题所在。您可以考虑在线查看如何在此jquery ui中设置表单,或者您可以从对话框中构建自己的表单。不可否认,图形不会那么光滑。