为什么我的页面在表单提交时重新加载
Why is my page reloading on form submission?
http://thecoxband.com/index1.html
表单是有效的,但是我不知道发生了什么以及ajax为什么不起作用。
我从这里的几个地方得到了代码,我相信有人会把我链接到……但老实说,我对JQuery或脚本还很陌生,所以如果有人能告诉我我做错了什么,我将永远欠你的债。
Samuel对您收到的JavaScript错误是正确的,但您离提交表单还有很长的路要走。在下面的脚本中,您使用"email"answers"name"的名称引用变量,但这些变量并不存在。
$(document).ready(function(){
$('submit').click(function(){
$.ajax({
type:'POST',
url: email_form.php,
data:{
name: name,
email: email,
},
success: function(msg){
alert('Email Sent');
}
});
});
});
您需要引用表单值。要做到这一点,您应该分别使用$('input[name="email"]'(.val((和$('input[name="name"]'(.val((,这样代码看起来就像
$(document).ready(function(){
$('#submit').click(function(){
$.ajax({
type:'POST',
url: 'email_form.php',
data:{
name: $('input[name="name"]').val(),
email: $('input[name="email"]').val()
},
success: function(msg){
alert('Email Sent');
}
});
});
});
最后,我注意到最后一件事,提交按钮的类型应该是"button",而不是"submit",因为后者会导致页面刷新,从而中断正在运行的JavaScript。
注意,我在结果函数中添加了Juan注意到的选择器错误。
第93行:您正在全局窗口中声明一个对象属性。
afterLoad: function(anchorLink, index){
更改为:
var afterLoad = function(anchorLink, index){
我看到你有这样的代码:
$('submit').click(function(){
$.ajax({
type:'POST',
url: email_form.php,
data:{
name: name,
email: email,
},
success: function(msg){
alert('Email Sent');
}
});
});
该选择器错误,请将其更改为:
$('#submit').click(function(){
//...
而且,你不仅想在点击按钮时触发,而且你有两个选项,所以表单不会提交:
1( 监听提交事件并阻止其提交
$('#yourformid').submit(function(e){
e.preventDefault(); //... })
2( 将按钮更改为具有样式的<a>
标记,而不是提交输入。这样,您就可以在不触发提交的情况下侦听单击事件。
相关文章:
- 创建新数据和加载现有数据需要单独的视图吗
- 钛 - HTTPClient:打开新的控制器加载
- 保持 JavaScript 在浏览器控制台中运行,即使在新的页面加载之后也是如此
- 路由到新页面时加载不起作用
- 如何在新窗口完成加载后执行某些内容
- 使用新标题重新加载 html 页面
- Primefaces在打开新页面时加载数据消息
- Wordpress音频播放器和平滑状态.在新页面重新加载播放器时调用什么回调函数
- 用新数据重新加载renderer3d
- 文本不被渲染后,新的页面加载- JQuery移动
- 需要在新标签中加载pdf/doc文件,而不是下载,只是想在浏览器中阅读
- 用新参数重新加载页面
- Js和CSS不检测新页面何时加载
- 在新页面上加载一个flash视频,它在上一页上的位置
- 在新窗口中加载代码编写器视图
- 在控制台中使用新脚本重新加载页面
- 如何在加载新页面后加载AJAX数据
- 如何使用jQuery在新窗口中加载页面,然后关闭它们
- Jquery没有看到新的HTML加载到对话框中
- 无法用新值重新加载JGrid