- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
抱歉,我确信这是一个简单的解决方案。但是,社区过去一直很友善,所以我想看看是否有人可以指出正确的方向。
我们使用一个外部软件来管理我们的数据库和托管我们的数据捕获表单。该解决方案限制我们在构建表单时调用字段 yield。
所以我的多步骤表单 HTML 可能看起来像这样:
<form id="form-1">
<fieldset id="step1">
<h3> Are you Male or Female?</h3>
<field-yield data-field="F_901_ONLINE_GENDER"></field-yield>
</fieldset>
<fieldset id="step2" style="display:none">
<h3 style="font-family:poppins;"> Please tell us about you?</h3>
<field-yield data-field="F_3_FIRSTNAME"></field-yield>
<field-yield data-field="F_4_LASTNAME"></field-yield>
</fieldset>
<fieldset id="step3" style="display:none;">
<h3> Please find your Address</h3>
<div data-option="UK_ADDRESS_LOOKUP">
<label data-db-localized-content="UK_ADDRESS_LOOKUP_LABEL"></label>
<div class="input">
<input class="PCODE" name="UK_ADDRESS_LOOKUP_POSTCODE" type="text" placeholder="" data-db-localized-placeholder="UK_ADDRESS_LOOKUP_PLACEHOLDER" value=""required><br>
<button class="mbbutton" type="button" data-db-localized-content="UK_ADDRESS_LOOKUP_LOOKUP_BUTTON"></button> <br>
<select class="form-control" name="UK_ADDRESS_LOOKUP_ADDRESS" type="text" placeholder="" required>
<option is-placeholder data-db-localized-content="UK_ADDRESS_LOOKUP_ADDRESS_PLACEHOLDER"></option>
</select>
</div> <br><br>
</div><field-yield data-field="F_9_TOWNCITY"></field-yield><field-yield data-field="F_6_ADDRESS1"></field-yield><field-yield data-field="F_11_POSTCODE"></field-yield>
<input type="submit"style="display:none;" data-db-localized-value="FORM_SUBMIT">
</fieldset>
<div class="col-12">
<br>
<button type="button" id="next">Start Quote!</button>
<p style="height: 40px;text-align:left;padding-left: 10px;padding-bottom: 0px;margin-bottom: -25px;"><button class="customBackBtn previous shadow" style="display:none;font-size:15px!important" id="previous" type="button"> <i class="fas fa-arrow-circle-left"></i> <strong>Back</strong></button></p><br>
</form>
系统有内置的检查,使该字段产生“必填”但是,看起来这些只在“提交按钮”上运行,所以如果用户跳到最后,缺少在第 1 步提交的表单,则表单不会提交,它也不显示编码到字段 yields 中的错误消息。
如您所想,这是垃圾用户体验,因此我们丢失了很多表单完成。
我想要实现的是代码,在进入下一步之前验证每个步骤中的所有字段都已填充,防止用户进入无法正常工作的提交按钮。
当前的 JS 是:
$(function () {
var currentPage = 1;
var maxPage = 3; //if additional fieldset steps add the max page here i.e., if 7 pages maxPage = 7
$("#next").click(function () {
if (currentPage < maxPage) {
var nextPage = currentPage + 1;
} else {
return; //if already at max page
}
trackProgress(100 * ((nextPage - 1) / maxPage).toFixed(1) + '%'); //get rid of decimal points (make a whole number)
$("#step" + currentPage).hide();
$("#step" + nextPage).show();
$("#previous").show();
currentPage = nextPage;
if (currentPage === maxPage) {
$('#next').hide()
$('input[type="submit"]').delay(2000).show(0);
$('#thanks').delay(2000).show(0);
// Show submit button & thank you paragraph
}
});
$("#previous").click(function () {
if (currentPage !== 1) {
$('#spinner').removeClass('hidden')
var prevPage = currentPage - 1;
} else {
return;
}
trackProgress(100 * ((prevPage - 1) / maxPage).toFixed(1) + '%');
$("#step" + currentPage).hide();
$("#step" + prevPage).show();
$('input[type="submit"]').hide();
$('#thanks').hide();
$("#next").show();
currentPage = prevPage;
if (currentPage === 1) {
$('#previous').hide()
}
})
});
这允许进度条、用于遍历表单的后退按钮以及每个步骤的显示/隐藏。我想在下面添加类似下面的内容来验证字段完成。
if ($('input[name="F_901_ONLINE_GENDER"]').val() == '' && $('input[name="F_3_FIRSTNAME"]').val() == '' && $('input[name="F_4_LASTNAME"]').val() == ''){
alert('Please complete all questions');
但是这不起作用,我不知道接下来要尝试什么。
提前感谢您的帮助!
最佳答案
不知道你们的系统是怎么替换<field-yield>
的标签,但我想会有典型的表单字段。所以你需要写一些通用的验证函数,它会在步骤中验证所有字段,如果验证通过则允许用户继续下一步。
验证步骤中所有输入字段的函数:
function validateStep(step) {
var stepWrapper = $('fieldset#step'+step);
var emptyFields = 0;
$('input[type="text"], select, textarea', stepWrapper).each(function(i, el) {
if ($(el).val() == '') {
emptyFields++;
return false;
}
});
//check radio buttons
var radioGroups = {};
//group radio buttons by name
$(':radio', stepWrapper).each(function() {
radioGroups[this.name] = true;
});
//count "checked" radio buttons in groups
for (var radioName in radioGroups) {
var checked = !!$(':radio[name="'+radioName+'"]:checked', stepWrapper).length;
if (!checked) {
emptyFields++;
}
}
return emptyFields;
}
现在您已经进行了步骤验证,您唯一需要做的就是在步骤更改之前调用此函数:
$("#next").click(function () {
//validate before move
if (validateStep(currentPage)) {
alert("Please fill all fields before move to next step!");
return false;
}
if (currentPage < maxPage) {
var nextPage = currentPage + 1;
} else {
return; //if already at max page
}
//... rest of your code
}
希望对你有帮助。
更新:这是您的页面表单的工作示例:https://codepen.io/zur4ik/pen/LYYqjgM我在每个循环中都犯了一个错误。
关于javascript - 在以多阶段形式进入下一步之前,我如何验证 field-yield 是否已填充?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58877050/
这是贪吃蛇游戏的部分代码。我想做的是制作关卡(大约3个),如果分数达到一定的分数(100或200),关卡就会改变。 在这段代码中,我尝试让分数达到 100 时进入第 2 阶段。但正如我编码的那样,它只
我是移相器新手。我开始看 youtube 系列,我首先有问题。我的背景图片无法加载。我有这个js代码 /* global Phaser */ var game = new Phaser.Game(12
我有一个包含 2 个阶段的应用程序,我不希望用户关闭第二个阶段,只需将其图标化即可。 目前我正在使用 oncloseRequest 处理程序来最小化窗口 - secondaryStage.setOnC
现在,我有一台运行服务器的基本LAMP配置。生产服务器是slicehost。但是我想知道将代码/数据库实例推送到阶段dev> stage> production的最佳方法是什么。它与您创建阶段的方式有
我在舞台上有一个场景。场景的宽度为 337.0 像素。但是,当我将它添加到舞台时,舞台的大小为 337.6 像素,由于 0.6 像素的差异,在屏幕的右边缘留下了一个白色间隙。 我尝试使用 stage.
我有这个未修饰的窗口: public static void initStartPage(final Stage primaryStage) { final Stage startPa
有什么方法可以在 Maven 构建中执行特定阶段。例如,如果我只想运行那些在预集成阶段执行的插件,Maven 是否提供了一种方法来做到这一点? e.g. mvn pre-integration-pha
仅在构建特定分支时如何运行构建步骤/阶段? 例如,仅当分支名为 deployment 时才运行部署步骤,其他所有内容保持不变。 最佳答案 在声明性管道语法中执行相同的操作,下面是一些示例: stage
我有一个简单的查询,试图在Hive 0.14中运行: select sum(tb.field1), sum(tb.field2), tb.month from dbwork.mytable tb gr
在 Mercurial 中,我经常使用 secret 变更集来跟踪我对尚未准备好推送的内容的工作。然后,如果我需要对某些文件进行紧急更改,我可以更新到公共(public)修订版,进行更改并推送它,而不
我一直在为 Heroku 的新附加组件工作,目前它是 alpha 阶段。因此,目前,我无法在我创建的应用程序上添加该附加组件,因为没有按钮可供我添加它。有人可以向我指出一些可以帮助我解决问题的资源吗?
我有 2 个线程正在运行,一个正在监听 soket 等待命令,另一个启动 javafx 应用程序 public class GraphicInterface extends Application i
在我的 Java Fx 应用程序中,我创建了两个阶段。第一阶段是主 Controller 类 HomeController 中的默认阶段。第二个 AddNewEmailController 是通过调用
我正在编写一个简单的 JavaFX 应用程序,它具有三个阶段:登录、注册 (Anmeldung) 和欢迎 (Anwendung)。 抱歉采用德语命名! 我已经在 App 类中创建了每个舞台及其场景,在
问题是我正在使用 jQuery("form")[0].reset(); 在需要时重置表单。此方法正在将形式重置到初始阶段。这里初始阶段的意思是“表单第一次加载到页面时带有一些值的阶段”。 但我需要的是
我有一个带有 pre-integration-test 和 post-integration-test 阶段的 Maven POM,如下所示。 start-server pre-in
我遇到一个错误,我已经为网络制作了一个 UIPageController,但我似乎无法找到它的问题,只有一个错误,请帮忙。代码如下 - 更多代码点播。 @interface ContentViewCo
考虑在其中放置一些文本的大型 (2000x1000) 舞台。舞台缩小到 1000x500,使文本不可读。然后我们尝试通过放大来放大文本。 预期:文本应该在某个时候再次变得可读。 实际:无论我们放大多少
试图在网页中居中 KineticJS 阶段。 尝试过: 但它集中在舞台的左侧,而不是舞台的中间。我错过了什么? 最佳答案 margin:auto 可以对齐这个div中心 关于htm
我正在 jboss 中部署一个简单的 Web 应用程序,其中包含一个 servlet、一个 jsp 文件和一个 easy EJB。这是 servlet 的代码: package webejb; imp
我是一名优秀的程序员,十分优秀!