Data-dismiss 完全删除该元素。请改用 jQuery 的 .hide() 方法。
快速修复方法:
使用内联 javascript 隐藏元素 onclick,如下所示:
<div class="alert" style="display: none">
<a class="close" onclick="$('.alert').hide()">×</a>
<strong>Warning!</strong> Best check yo self, you're not looking too good.
</div>
<a href="#" onclick="$('alert').show()">show</a>
http://jsfiddle.net/cQNFL/
然而,这应该只在你懒惰的情况下使用(如果你想要一个可维护的应用程序,这不是一件好事)。
做对的方法:
创建用于隐藏元素的新数据属性。
Javascript:
$(function(){
$("[data-hide]").on("click", function(){
$("." + $(this).attr("data-hide")).hide()
// -or-, see below
// $(this).closest("." + $(this).attr("data-hide")).hide()
})
})
然后在标记中将 data-dismiss 更改为 data-hide。jsfiddle 的示例。
$("." + $(this).attr("data-hide")).hide()
这将隐藏具有在 data-hide 中指定的类的所有元素,即:data-hide="alert"
将隐藏具有警报类的所有元素。
Xeon06提供了另一种解决方案:
$(this).closest("." + $(this).attr("data-hide")).hide()
这只会隐藏最近的父元素。如果您不想给每个警报一个唯一的类,这将非常有用。但是请注意,您需要在警报中放置关闭按钮。
.closest 来自jquery doc的定义:
对于集合中的每个元素,通过测试元素本身并向上遍历其在 DOM 树中的祖先来获取与选择器匹配的第一个元素。