- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有一个 ul
复选框,我希望允许用户单击 li
元素上的任意位置来选中/取消选中相应的复选框,然后将更改应用到通过 JavaScript 的页面。请注意,所有复选框一开始都是选中的。这是布局,不包括一些 li
元素。
<ul class="dropdown-menu">
<li class="cat-header">
<strong>Category</strong>
</li>
<li>
<a class="filter-link"> Red
<input checked="true" class="cat-check" data-filter="red" data-type="color" type="Checkbox">
</a>
</li>
然后,我尝试使用 javascript 根据复选框的 checked
属性更改页面。但是,根据我选择元素的方式,我得到了不同的值。我的函数看起来像这样
setFilter = function(checkbox) {
console.log(checkbox);
if ($(checkbox).attr('data-type') === "color") {
if (!$(checkbox).prop('checked')) {
$(checkbox).prop('checked', false);
colorFilter = colorFilter.replace($(checkbox).attr('data-filter') + " ", "");
} else {
$(checkbox).prop('checked', true);
colorFilter = colorFilter + $(checkbox).attr('data-filter') + " ";
}
} else if ($(checkbox).attr('data-type') === "shape") {
if (!$(checkbox).prop('checked')) {
$(checkbox).prop('checked', false);
shapeFilter = shapeFilter + $(checkbox).attr('data-filter') + " ";
} else {
$(checkbox).prop('checked', true);
shapeFilter = shapeFilter.replace($(checkbox).attr('data-filter') + " ", "");
}
}
};
一些注释。首先,颜色是包容性的(即,如果它具有该颜色,则显示它),而形状是排他性的(即,如果它具有该形状,则不显示它),因此逻辑略有不同。其次, .prop()
函数返回与我预期相反的值,因此 if (!$(checkbox).prop('checked'))
当我这样调用它时,它会打印出 true
$('.filter-link').click(function(e) {
setFilter($(this).children("input")[0]);
});
但是当我这样调用它时,它打印出 false
$('.cat-check').click(function(e) {
setFilter($(this)[0]);
});
我尝试在 JSFiddle ( https://jsfiddle.net/eg9c4vkv/6/ ) 中重现该效果,但无法复制该效果。我还认为它可能与 console.log ( How can I change the default behavior of console.log? (*Error console in safari, no add-on*) ) 有关,但理论上只要输入相同,该函数的行为就应该相同。有人有什么想法吗?
最佳答案
我发现了一些小问题,但没有什么明显的问题。
首先是您访问 data
的方式属性。其次是如何绑定(bind)处理程序(您确定每次单击该复选框时都不会触发 .cat-check
和 .filter-link
的事件,这可能会导致意外的行为)..无论哪种方式,我都重做了功能以防万一有帮助。
通过包含 data-
属性上的前缀,您告诉 jQuery 在准备好时自动缓存该值。
Refer to jQuery data docs for more info
<a href="" data-filter="hello">Hello</a>
相当于
$('a').data('filter', 'hello');
要访问数据,您只需使用 key ,在本例中为 filter
或type
。值得注意的是,您可以像现在一样直接访问该属性,但使用其中之一(最好是 .data
)。
例如带标记..
<a href="" data-filter="hello">Hello</a>
$('a').on('click', function(e) {
var $this = $(this);
$this.data('filter', 'I changed');
//what will the value be? It's going to be 'Hello', because we're accessing the attribute in the DOM
alert($this.attr('data-filter'));
//what will the value be? It's going to be 'I changed', because we're accessing the data cache
alert($this.data('filter'));
});
尝试一下,我想我明白你想要做什么(下面的代码片段应该适合你)
var colorFilter = 'red green yellow ';
$('.dropdown-menu')
.on('click', 'li', function(e) {
//check the source of the event, if the checkbox was already clicked then let it continue
if (e.target.type != "checkbox") {
$(this).find(".cat-check").click();
}
})
.on('click', '.cat-check', function() {
console.log(this);
var $checkbox = $(this),
type = $checkbox.data('type'),
filter = $checkbox.data('filter'),
isChecked = $checkbox.prop('checked');
console.log(isChecked);
if (type === "color") {
if (isChecked) {
if (colorFilter.indexOf(filter) < 0) {
colorFilter = colorFilter + filter + " ";
}
} else {
colorFilter = colorFilter.replace(filter + " ", "");
}
$('#filter').text(colorFilter);
} else if (type === "shape") {
if (isChecked) {
if (colorFilter.indexOf(filter) < 0) {
shapeFilter = shapeFilter + filter + " ";
}
} else {
shapeFilter = shapeFilter.replace(filter + " ", "");
}
console.log(shapeFilter);
}
});
li {
cursor: pointer;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div id='filter'>
red green yellow
</div>
<ul class="dropdown-menu">
<li class="cat-header">
<strong>Category</strong>
</li>
<li>
<a class="filter-link"> Red
<input checked="true" class="cat-check" data-filter="red" data-type="color" type="Checkbox">
</a>
</li>
<li>
<a class="filter-link"> Green
<input checked="true" class="cat-check" data-filter="green" data-type="color" type="Checkbox">
</a>
</li>
<li>
<a class="filter-link"> Yellow
<input checked="true" class="cat-check" data-filter="yellow" data-type="color" type="Checkbox">
</a>
</li>
</ul>
关于javascript - DOM 元素的属性根据选择器的不同而不同 - jQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36438237/
你能比较一下属性吗 我想禁用文本框“txtName”。有两种方式 使用javascript,txtName.disabled = true 使用 ASP.NET, 哪种方法更好,为什么? 最佳答案 我
Count 属性 返回一个集合或 Dictionary 对象包含的项目数。只读。 object.Count object 可以是“应用于”列表中列出的任何集合或对
CompareMode 属性 设置并返回在 Dictionary 对象中比较字符串关键字的比较模式。 object.CompareMode[ = compare] 参数
Column 属性 只读属性,返回 TextStream 文件中当前字符位置的列号。 object.Column object 通常是 TextStream 对象的名称。
AvailableSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。 object.AvailableSpace object 应为 Drive 
Attributes 属性 设置或返回文件或文件夹的属性。可读写或只读(与属性有关)。 object.Attributes [= newattributes] 参数 object
AtEndOfStream 属性 如果文件指针位于 TextStream 文件末,则返回 True;否则如果不为只读则返回 False。 object.A
AtEndOfLine 属性 TextStream 文件中,如果文件指针指向行末标记,就返回 True;否则如果不是只读则返回 False。 object.AtEn
RootFolder 属性 返回一个 Folder 对象,表示指定驱动器的根文件夹。只读。 object.RootFolder object 应为 Dr
Path 属性 返回指定文件、文件夹或驱动器的路径。 object.Path object 应为 File、Folder 或 Drive 对象的名称。 说明 对于驱动器,路径不包含根目录。
ParentFolder 属性 返回指定文件或文件夹的父文件夹。只读。 object.ParentFolder object 应为 File 或 Folder 对象的名称。 说明 以下代码
Name 属性 设置或返回指定的文件或文件夹的名称。可读写。 object.Name [= newname] 参数 object 必选项。应为 File 或&
Line 属性 只读属性,返回 TextStream 文件中的当前行号。 object.Line object 通常是 TextStream 对象的名称。 说明 文件刚
Key 属性 在 Dictionary 对象中设置 key。 object.Key(key) = newkey 参数 object 必选项。通常是 Dictionary 
Item 属性 设置或返回 Dictionary 对象中指定的 key 对应的 item,或返回集合中基于指定的 key 的&
IsRootFolder 属性 如果指定的文件夹是根文件夹,返回 True;否则返回 False。 object.IsRootFolder object 应为&n
IsReady 属性 如果指定的驱动器就绪,返回 True;否则返回 False。 object.IsReady object 应为 Drive&nbs
FreeSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。只读。 object.FreeSpace object 应为 Drive 对象的名称。
FileSystem 属性 返回指定的驱动器使用的文件系统的类型。 object.FileSystem object 应为 Drive 对象的名称。 说明 可
Files 属性 返回由指定文件夹中所有 File 对象(包括隐藏文件和系统文件)组成的 Files 集合。 object.Files object&n
我是一名优秀的程序员,十分优秀!