gpt4 book ai didi

javascript - 在 Bootstrap 中更改表单样式以进行验证

转载 作者:搜寻专家 更新时间:2023-10-31 08:52:11 25 4
gpt4 key购买 nike

我找到了一个代码片段,它正是我所需要的,只是稍作改动。 The sample code is here ,我尝试创建一个可以访问的示例表单 here .我唯一需要的调整是,我想在加载表单后为必填字段显示星号。但截至目前,它显示错误样式(页面打开时不需要)。如何更改表单?

脚本

    $(document).ready(function() {
$('.input-group input[required], .input-group textarea[required], .input-group select[required]').on('keyup change', function() {
var $form = $(this).closest('form'),
$group = $(this).closest('.input-group'),
$addon = $group.find('.input-group-addon'),
$icon = $addon.find('span'),
state = false;

if (!$group.data('validate')) {
state = $(this).val() ? true : false;
} else if ($group.data('validate') == "email") {
state = /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/.test($(this).val())
} else if ($group.data('validate') == 'phone') {
state = /^[(]{0,1}[0-9]{3}[)]{0,1}[-\s\.]{0,1}[0-9]{3}[-\s\.]{0,1}[0-9]{4}$/.test($(this).val())
} else if ($group.data('validate') == "length") {
state = $(this).val().length >= $group.data('length') ? true : false;
} else if ($group.data('validate') == "number") {
state = !isNaN(parseFloat($(this).val())) && isFinite($(this).val());
}

if (state) {
$addon.removeClass('danger');
$addon.addClass('success');
$icon.attr('class', 'glyphicon glyphicon-ok');
} else {
$addon.removeClass('success');
$addon.addClass('danger');
$icon.attr('class', 'glyphicon glyphicon-remove');
}

if ($form.find('.input-group-addon.danger').length == 0) {
$form.find('[type="submit"]').prop('disabled', false);
} else {
$form.find('[type="submit"]').prop('disabled', true);
}
});

$('.input-group input[required], .input-group textarea[required], .input-group select[required]').trigger('change');
});

HTML

 <div class="container">
<div class="row">
<h2>Input Validation + Colorful Input Groups</h2>
</div>
<div class="row">
<div class="col-sm-offset-4 col-sm-4">
<form method="post">
<div class="form-group">
<label for="validate-text">Validate Text</label>
<div class="input-group">
<input type="text" class="form-control" name="validate-text" id="validate-text" placeholder="Validate Text" required>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-optional">Optional</label>
<div class="input-group">
<input type="text" class="form-control" name="validate-optional" id="validate-optional" placeholder="Optional">
<span class="input-group-addon info"><span class="glyphicon glyphicon-asterisk"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-optional">Already Validated!</label>
<div class="input-group">
<input type="text" class="form-control" name="validate-text" id="validate-text" placeholder="Validate Text" value="Validated!" required>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-email">Validate Email</label>
<div class="input-group" data-validate="email">
<input type="text" class="form-control" name="validate-email" id="validate-email" placeholder="Validate Email" required>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-phone">Validate Phone</label>
<div class="input-group" data-validate="phone">
<input type="text" class="form-control" name="validate-phone" id="validate-phone" placeholder="(814) 555-1234" required>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-length">Minimum Length</label>
<div class="input-group" data-validate="length" data-length="5">
<textarea type="text" class="form-control" name="validate-length" id="validate-length" placeholder="Validate Length" required></textarea>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-select">Validate Select</label>
<div class="input-group">
<select class="form-control" name="validate-select" id="validate-select" placeholder="Validate Select" required>
<option value="">Select an item</option>
<option value="item_1">Item 1</option>
<option value="item_2">Item 2</option>
<option value="item_3">Item 3</option>
</select>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<div class="form-group">
<label for="validate-number">Validate Number</label>
<div class="input-group" data-validate="number">
<input type="text" class="form-control" name="validate-number" id="validate-number" placeholder="Validate Number" required>
<span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span>
</div>
</div>
<button type="submit" class="btn btn-primary col-xs-12" disabled>Submit</button>
</form>
</div>
</div>
</div>

最佳答案

您需要注释脚本中的以下行。

$('.input-group input[required], .input-group textarea[required], .input-group select[required]').trigger('change');

这是您的 document.ready 中的最后一行。这是负责在页面加载时触发更改事件并将星号更改为交叉的行。只需评论这一行,您就可以开始了。

编辑添加danger类而不是info类;默认情况下,这将以红色显示您的星号,并且在验证时它将获得带有复选标记的绿色背景。即修改您的星号表单组如下。 选修的

注意撤消我之前建议的脚本更改。

关于javascript - 在 Bootstrap 中更改表单样式以进行验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39324233/

25 4 0
文章推荐: javascript - 为什么我的表单脚本只适用于第二次提交
文章推荐: javascript - scrollTop() 并不总是有效
文章推荐: javascript - 清除搜索字段后,如何将
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com