繁体   English   中英

Jquery附加div并删除div

[英]Jquery to append a div and to remove a div

这是我的问题,

我有一个选择框,我需要验证val()是否变为0,然后在一个带有类错误的范围内附加一个文本,说明“请选择一个值”。 否则需要删除该div。 单击提交按钮时会发生这些情况。 这是我的代码,

if ($('.combo option:selected[value==0]')) {
    var error_span = $("div.info-cont ul.map-list li span.right")
        .append("<br>Please select an appropriate value")
        .addClass('error');
} else {

}

现在问题是,如果在选择框中选择了一个值,我的附加范围应该被删除。 任何帮助。 提前致谢...

 if($('.combo option:selected[value==0]')){ $("div.info-cont ul.map-list li span.right").append("<br>Please select an appropriate value").addClass('error'); } else { $("div.info-cont ul.map-list li span.right").html(""); $("div.info-cont ul.map-list li span.right").removeClass('error'); } 

我只想解释一下:

if ($('.combo option:selected[value==0]'))

要检查下拉列表中所选项目的值是否为0,您可以使用以下内容:

if ($('.combo').val() == '0') // simpler and more readable :-)

然后,如果您已将错误消息放在文档中的某处,则会更简单。 您需要做的就是显示/隐藏它。 例如:

<select id="dropdown-1" class="combo">
  <option value="0">-</option>
  <option value="1">Lorem</option>
  <option value="2">Ipsum</option>
</select>

<span id="error-dropdown-1" class="error" style="display: none">Please select a value!</span> <!-- hidden by default. can also use CSS instead of style="display: none" -->

<input type="button" id="demo-button" value="Demo" />

和javascript(+ jquery):

$('#demo-button').click(function() {
  if ($('.combo').val() == '0') {
    $('#error-dropdown-1').show();
  } else {
    $('#error-dropdown-1').hide();
  }
});

这是另一个例子。 如果你避免使用ID(也许你有动态生成的dorpdowns),这很有用:

<script type="text/javascript">
$(function() {
    $('#demo-button').click(function() {
        $('.combo').each(function() {
            var div = $(this).parents('div').get(0); // get the wrapper
            if ($(this).val() == '0') {
                $(div).find('.error').show(); // show <span class=".error"> inside the wrapper
            } else {
                $(div).find('.error').hide(); // hide <span class=".error"> inside the wrapper
            }
        });
    });
});
</script>

<div> <!-- wrapper for 1st combo + 1st error message -->
    <select class="combo">
        <option value="0">-</option>
        <option value="1">Lorem</option>
        <option value="2">Ipsum</option>
    </select>
    <span class="error" style="display: none">Please select a value!</span>
</div>

<div> <!-- wrapper for 2nd combo + 2nd error message -->
    <select class="combo">
        <option value="0">-</option>
        <option value="1">Dolor</option>
        <option value="2">Sit</option>
        <option value="3">Amet</option>
    </select>
    <span class="error" style="display: none">Please select a value!</span>
</div>

<div> <!-- wrapper for 3rd combo + 3rd error message -->
    <select class="combo">
        <option value="0">-</option>
        <option value="1">Consectetuer</option>
        <option value="2">Adipiscing</option>
        <option value="3">Elit</option>
    </select>
    <span class="error" style="display: none">Please select a value!</span>
</div>

<input type="button" id="demo-button" value="Demo" />

看看jquery验证器 ,它会为您完成所有这些

如果您的span(span.right)包含其他任何错误消息(我认为它基于br-tag的使用),此方法将把该内容保留在原来的位置。

var $select = $(".combo"),
    $span = $("div.info-cont ul.map-list li span.right");

if ($select.val() === 0) {
    $span.append(
        $("<span/>")
            .addClass("error")
            .html("Please select an appropriate value")
    );
} else {
    $span.children("error").remove();
}

我没有测试过这段代码,但类似的东西应该可以解决。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM