- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 jQM 项目中,我遇到了表单提交问题。我没有使用“action”URL来提交表单,而是使用JS在另一个js插件验证后提交表单,一旦验证,表单将由jQM $.post()提交。
我从 jQM 页面关注此内容:
Example: Send form data using ajax requests
$.post( "test.php", $( "#testform" ).serialize() );
一切正常,包括返回数据。但我的问题是,表单中的“操作”,如果我删除它,在表单提交后,应用程序将重定向到 jQM 第一页。 “#”也是如此。如果我输入“/”,它会显示“错误加载页面”一会儿然后消失。
我的问题,有什么办法可以摆脱“加载页面时出错”的情况吗?我也尝试过在表单标签中包含 [data-ajax="false"] 。也是同样的结果。
请多多指教,谢谢。
我的 JS 代码:使用此代码可以解决问题。但是,如果我取消注释行来执行我的实际任务,它会将我重定向到多页的第一页。就像忽略了 PreventDefault 一样。这里到底出了什么问题?请指教,谢谢。
$(document).on("click", "#registerButton", function (e) {
e.preventDefault();
var registerForm = $( "#registerForm" );
if (registerForm.valid() === true) {
document.getElementById("regDeviceName").value = intel.xdk.device.model;
document.getElementById("regDeviceOs").value = intel.xdk.device.platform;
$.post("http://domain.com/api/user/register",
$("#registerForm").serialize(),
function(data,status){
alert(data);
// if (data == "registered") {
// $.mobile.pageContainer.pagecontainer("change", "#regSuccess");
// }
// elseif (data == "unverified") {
// $.mobile.pageContainer.pagecontainer("change", "#unverified");
// }
// elseif (data === "duplicate") {
// $.mobile.pageContainer.pagecontainer("change", "#duplicate");
// }
// else {
// $.mobile.pageContainer.pagecontainer("change", "#suspended");
// };
// $.mobile.pageContainer.pagecontainer("change", "#regSuccess");
});
}
});
第二次尝试时的 JS 代码:
$("#registerButton").click(function (e) {
e.preventDefault();
var registerForm = $( "#registerForm" );
if (registerForm.valid() === true) {
document.getElementById("regDeviceName").value = intel.xdk.device.model;
document.getElementById("regDeviceOs").value = intel.xdk.device.platform;
$.post("http://domain.com/api/user/register",
$("#registerForm").serialize(),
function(data,status){
alert(data);
// if (data == "registered") {
// $.mobile.pageContainer.pagecontainer("change", "#regSuccess");
// }
// elseif (data == "unverified") {
// $.mobile.pageContainer.pagecontainer("change", "#unverified");
// }
// elseif (data === "duplicate") {
// $.mobile.pageContainer.pagecontainer("change", "#duplicate");
// }
// else {
// $.mobile.pageContainer.pagecontainer("change", "#suspended");
// };
// $.mobile.pageContainer.pagecontainer("change", "#regSuccess");
// $("#registerResult").html("Data: " + data + "<br>Status: " + status);
});
}
});
表单 HTML(jQM 多页结构):
<div data-role="page" id="register">
<div data-role="header"><h1>Register</h1></div>
<div data-role="content" class="pageWithHeader">
<div id="formContainer">
<form id="registerForm">
<label for="regFirstName">First Name</label>
<input class="registerVal" type="text" name="regFirstName" id="regFirstName" value="">
<label for="regLastName">Last Name</label>
<input class="registerVal" type="text" name="regLastName" id="regLastName" value="">
<label for="regEmail">Email</label>
<input class="registerVal" type="email" name="regEmail" id="regEmail" value="">
<label for="regPassword">Password</label>
<div id="regPassDiv">
<input class="registerVal" type="password" name="regPassword" id="regPassword" value="">
</div>
<input type="hidden" id="regDeviceName" name="regDeviceName" value="">
<input type="hidden" id="regDeviceOs" name="regDeviceOs" value="">
<div data-role="controlgroup" data-type="vertical">
<button id="registerButton" class="ui-btn ui-corner-all ui-icon-plus ui-btn-icon-left">Register</button>
<a href="#verifyRegister" class="ui-btn ui-corner-all ui-icon-check-square-o ui-btn-icon-left">Go to Account Verification</a>
</div>
</form>
</div>
<!-- <div id="registerResult"></div>-->
</div>
</div>
最佳答案
解决方案: 防止表单标记的默认操作,因为表单中的 action="url"在您提交时执行。试试这个
代码:
$("#formid").submit(function(e){
$.post( "test.php", $( "#testform" ).serialize() );
});
如果您使用 jquery 验证器,只需将此代码放入 successHandler 函数中即可。这里不需要阻止表单标签上的默认操作。
代码:
$('#myform').validate({
rules:{
firstname:"required",
lastname:"required",
username:"required" ,
employeeid:"required",
email:{
required:true,
email:true
},
password:{
required:true,
minlength:5
},
phoneno:{
minlength:9,
maxlength:10,
}
},
messages:{
username:"Please enter your username..!",
password:"Please enter your password..!"
},
submitHandler: function(form) {
$.post( "test.php", $( "#testform" ).serialize() );
}
});
关于javascript - jQM POST 表单通过 JS 显示 "Error Loading Page",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24569556/
我是 PHP 新手。我在 WordPress 中遇到了这种语法.该代码的最后一行是做什么的? $page = $_SERVER['REQUEST_URI']; $page = str_replace(
为了清楚起见 - 这是我在这个问题中谈论的盒子的图片: 背景:我为客户构建了一个相对复杂的 WP 网站,它更像是一个 CMS 而不是博客,并且依赖于正在构建的页面层次结构。 (嗯,它们实际上是设置了
GitHub Help显示了 GitHub Pages 的以下选项: gh-pages 分行 主分支 master 分支/docs 文件夹 那么我们可以使用名称不是 master 或 gh-pages
我正在使用 AngularJS 框架为我的前端开发一个 Web 应用程序。对于我的登录页面,我必须阻止用户浏览除登录页面和注册之外的其他页面。但是我现在所做的代码也阻止用户导航到注册页面。以下是我的代
如果不将/1 粘贴到 url 上,是否可以改变 Zend_Paginator 来处理 URL?当前用户转到/aaron/studio。然后用户应该点击页面并开始访问 URL,例如:/aaron/stu
目前,我创建了一个可以生成PDF的系统。 PDF 中的数据来自 MySQL 数据库。现在,我像这样显示数据 第一页:仅显示一条数据。 第二页文字:将显示数据(每页最多 3 个数据) 说得更清楚一点,比
我正在尝试构建我的 ASP.NET MVC 4.5 项目以使用搜索引擎友好的 URL。我正在使用以下路由映射。 routes.MapRoute( name: "Default", ur
我为打印按钮使用了以下代码: Data.str = null; //Data.str = textBox24.Text.ToString(); string s = "select * from te
我们有一个带有两个 View 的单页应用程序(本质上是一个项目列表和所选项目的详细信息页面)。两个 View 都在单独的 html 文件中,我们使用 sammy.js 在页面之间进行转换/导航。在我们
(如果有人需要更多信息或更好的描述,请告诉我) 您好,我从这里添加了 viewPagerLibrary:http://viewpagerindicator.com/#introduction今天在我的
我是网页的新手,刚刚开始学习它。在创建新的 Razor 网站后,当我点击添加新项目时,我会看到可以添加的项目的多个选项。它们是: Layout Page(Razor) 这些类似于Master Page
我正在尝试使用 activeadmin 和 awesome_nested_set 创建页面模型。我一直在试图弄清楚如何使用正确的尾随 slug(例如/page1/page1subpage/a-subp
我正在尝试将 DotNetOpenAuth 与 Razor/MVC3 一起使用。大多数 DotNetOpenAuth HTML 助手都接受 System.Web.UI.Page 作为参数之一,使用 W
在我们的应用程序中,当我们在某些页面之间导航时,我们会在进入下一页之前发出服务器请求。发生这种情况时,当前页面上会显示加载图形。奇怪的是,在等待服务器响应完成时,下一页的样式会应用到当前页面。这会导致
我正在使用 ASP.NET Core 3.1 MVC 和 Razor 页面构建 Web 应用程序。 我是 Razor 页面的新手。 我使用上面的方法创建了一个基本应用程序。我想在应用程序启动时加载登录
我遇到了一个我似乎无法解释的问题。我在 Umbraco 中设置了一个主模板和 2 个子模板,但出现以下错误: Content controls have to be top-level control
我正在创建一个网络应用程序,允许用户选择他们当前的部门、他们将临时借调到哪个部门、他们正在执行的任务以及在任务上花费的时间。我需要写一些声明,根据他们当前部门的选择来确定他们所在的团队(当前的或新的)
当我导航到一个页面时,我得到了404错误页面,该页面说,在我刷新浏览器之前,没有包含此URL的页面,然后该页面才会显示。。我尝试使用@REACH/ROUTER来导航,而不是使用REACT-ROUTER
我正在使用 Html2Pdf 将一些 HTML 文件转换为 PDF。我还需要添加分页符来划分文档的各个部分。为此,我使用 标签。 我有以下 HTML 片段: ...
我正在使用另一个静态网站生成器,我希望能够将源文件(以markdown格式)以及生成的网站 checkin 到我的username.github.com存储库中。因此,很像Jekyll,但我没有使用J
我是一名优秀的程序员,十分优秀!