我正在从jQuery在FancyBox中加载内联注册表单。但是在提交表单后,该框立即关闭,同时有一些反馈,我想在FancyBox本身中显示用户。此反馈在服务器端生成,并打印在FancyBox中。
如果盒子只有在没有反馈的情况下才会关闭?我正在考虑使用ajax来刷新FancyBox本身而不是刷新后的整个页面。但我只是想不通这个ajax $ .ajax({type,cache,url,data,success});工作......似乎javascript中的'submit bind'没有任何反应。
我希望有人可以帮我解决这个问题。我在下面粘贴我的代码。如果有任何问题,请问..
提前谢谢!这是javascript:
<script type="text/javascript">
$(document).ready(function() {
$("#various1").fancybox({
'transitionIn' : 'none',
'transitionOut' : 'none',
'scrolling' : 'no',
'titleShow' : false,
'onClosed' : function() {
$("#registration_error").hide();
}
});
});
$("#registration_form").bind("submit", function() {
if ($("#registration_error").val() != "Registration succeeded!") {
$("#registration_error").show();
$.fancybox.resize();
return false;
}
$.fancybox.showActivity();
$.ajax({
type : "POST",
cache : false,
url : "/data/login.php",
data : $(this).serializeArray(),
success : function(data) {
$.fancybox(data);
}
});
return false;
});
这是我在FancyBox中显示的内联表单:
<div style="display: none;">
<div id="registration" style="width:227px;height:250px;overflow:auto;padding:7px;">
<?php echo "<p id=\"registration_error\">".$feed."</p>"; ?>
<form id="registration_form" action="<?php echo $_SERVER['PHP_SELF'] ?>" method="post">
<p>
<label for="username">Username: </label>
<input type="text" id="login_name" name="username" size="30" />
</p>
<p>
<label for="password">Password: </label>
<input type="password" id="pass" name="pw" size="30" />
</p>
<p>
<label for="repeat_password">Repeat password: </label>
<input type="password" id="rep_pass" name="rep_pw" size="30" />
</p>
<p>
<input type="submit" value="Register" name="register" id="reg" />
</p>
<p>
<em></em>
</p>
</form>
</div>
</div>
答案 0 :(得分:2)
我使用了fancybox的ajax部分..
$.ajax({
type : "POST",
cache : false,
url : "data/register.php",
data : $(this).serializeArray(),
success : function(data) {
data = $.parseJSON(data);
if (data.feedback == "Registration succeeded!") {
$.fancybox("Welcome, "+data.name+"! You can now log in.");
$.fancybox.resize();
}
else{
$("#registration_error").html(data.feedback);
}
}
});
在register.php文件中,我检查了数据是否正确并做了一些反馈。我把register.php中的反馈放在一个JSON对象中,我可以在主页的ajax的'success'选项中使用它(参见上文)。如果反馈是积极的,我就制作了fancybox,如果不是我在我的注册表单中将反馈放在div #registration_error中。
我的register.php文件的代码如下所示:
$feed = "";
// Put post vars in php vars
$username = $_POST[username];
$password = $_POST[pw];
$rep_password = $_POST[rep_pw];
// Check if php vars are not empty and check if the username doesn't exist in my user.class
if(!empty($username) && !empty($password) && !empty($rep_password))
{
$user = new User();
$user->Username = $username;
$user->Password = $password;
$user->Password2 = $rep_password;
try
{
$user->Save();
$feed .= "Registration succeeded!";
}
catch(Exception $e)
{
$feed = $e->getMessage();
}
}
else
{
$feed = "Please fill in all the fields!";
}
// Feedback for fancybox
$output = array();
$output['name'] = $username;
$output['feedback'] = $feed;
// Send JSON
$output = json_encode($output);
print $output;
希望这会对你有帮助!
GRtz!
答案 1 :(得分:2)
对于iframe打开的fancybox,这是提交后打印的代码:
<script type='text/javascript'>
$(document).ready(function(){
parent.document.location.reload();
parent.jQuery.fancybox.close();
});
</script>
答案 2 :(得分:0)
我做到了这一点。
如果设置了$ _POST ['xxx'],我基本上会触发一个打开表单的链接。
如果单击元素id = form,则第一个jquery函数会打开一个表单。 第二个函数将triger元素id = triger_form,它将打开相同的形式。
$(document).ready(function() {
$("a#form").fancybox({
'hideOnContentClick': false
});
$("a#triger_form").fancybox().trigger('click')({
'hideOnContentClick': false
});
});
if($_POST['refer_submit'] == TRUE) {
回声'';
}