我在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'] )); }
答案 0 :(得分:0)
显然我还不能发布图片,所以这里是我在下面的答案中谈到的那个链接。 http://i.stack.imgur.com/xgExo.png
我执行了你的代码,抓住了必要的脚本src标签,我认为你在实际代码中有这些标签,并且发现你遇到了同样的问题。在查看firechaug控制台后,就像jchapa建议的那样,我找到了你在上面的图片中看到的内容。
你正在使用的jquery ui以这样一种方式重写你的内容,它不仅会给它带来那些起泡的图形,而且还会过早地终止你的表单标签,就像我在下面加上“”文本一样。
你如何解决这个问题,我不知道,但这就是你的问题所在。您可以考虑在线查看如何在此jquery ui中设置表单,或者您可以从对话框中构建自己的表单。不可否认,图形不会那么光滑。