gpt4 book ai didi

php - 提交按钮在 IE/Safari 中不起作用,在 Chrome 中有效,但表单信息未通过

转载 作者:行者123 更新时间:2023-11-30 10:44:50 30 4
gpt4 key购买 nike

我有一个表单设置,但出于某种原因,提交表单的 JS 在 Chrome 中有效,但在 IE9 或 Safari 中无效。有趣的是,在 Chrome 中,提交按钮确实有效,没有任何信息被传递。

这是我的提交按钮 -

<a href="javascript: validate(); return false;"><img type="submit" src="lib/send_feedback.jpg" border="0" class="feedback-submit-img" /></a>

这是它调用的JS

// Submit form to next page
function submitForm() {
// document.forms["feedbackform"].submit();
document.feedbackform.submit();
}
// Submit form and validate email using RFC 2822 standard
function validateEmail(email) {
// Modified version original from: http://stackoverflow.com/a/46181/11236
var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
return re.test(email);
}
// Return true if email field is left unchanged
function originalText(email){
var defaultMsg;
defaultMsg = "Enter your email address (optional)";
if(defaultMsg == email){
return true;
}
return false;
}
// Verify or decline with error message
function validate(){
$("#result").text("");
var email = $("#email").val();
if ((validateEmail(email)) || originalText(email)) {
submitForm();
} else {
$("#result").text(email + " is not a valid email.");
$("#result").css("color", "red");
}
return false;
}
$("form").bind("submit", validate);

我的问题的第二部分可能与 JS 问题有关,也可能无关 -

echo $POST['satisfaction'];
echo $POST['user_email'];
echo $POST['comments'];
if(isset($POST['user_email'])){
echo 'true';
} else {
echo 'false';
}

如果您想更好地查看我正在编辑的页面 here is a link to jsfiddle

编辑

根据 Marco 的要求,我删除了提交按钮周围的链接,并将 onClick 事件放在实际按钮本身上。这绝对解决了 IE 和 Safari 上的问题。现在我剩下的问题/担忧是为什么 POST 数据没有正确传递到下一页。

Here is the complete source with George requested. - index.php

Page source gets passed to - feedback-accept.php

此外,StackOverflow 将源代码发布到的首选网站是什么?

作为对 Brian 评论的回应,如果我不能在不破坏 POST 数据的情况下使用失败,那么什么是好的替代/解决方法?

最佳答案

试试这个代码:

jQuery:

$(document).ready(function()
{

$('.validate').bind('submit click',function()
{
//Validate!

//is email
if( /..../.test( $(this).find('input[name=email]').val() ) )
{
alert('Error!!!');
return false; //STOP PROPAGATION
}

//Its okay!
//send form!
$(this).parents('form').submit();

//click event stop propagation
return false;
});

});

HTML:

<a href="" class="validate">Submit</a>

<input type="submit" value="Submit" class="validate" />

<button class="validate" >Submit</button>

关于php - 提交按钮在 IE/Safari 中不起作用,在 Chrome 中有效,但表单信息未通过,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8991892/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com