- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 jQuery 向列表项添加属性。我稍后在代码中尝试通过搜索我刚刚添加的属性来访问这些列表项,但我得到“未定义不是函数”。
编辑:
这是我的代码的较大部分,因此您可以看到到底发生了什么:
var listItems = $('#list li');
area = '';
subarea = '';
for (var i in areas) {
if (areas.hasOwnProperty(i)) {
area = areas[i].area;
listItems.find(".area:containsi('" + area + "')").each(function(e)
{
for (var j = areas[i].subareas.length - 1; j >= 0; j--)
{
subarea = areas[i].subareas[j];
$(this).closest("li").attr("data-area", $(this).closest("li").attr("data-area") + subarea + ' ');
}
console.log($(this).closest("li").attr("data-area"));
});
}
}
$('#search-input-field').on( {
focus: function()
{
$(this).data('placeholder',$(this).attr('placeholder'));
$(this).attr('placeholder','');
},
blur: function()
{
$(this).attr('placeholder',$(this).data('placeholder'));
},
keyup: function()
{
var searchTerm = $(this).val();
var searchSplit = searchTerm.replace(/ /g, "'):containsi('");
listItems.attr("data-area").not(":containsi('" + searchSplit + "')").each(function(e)
{
$(this).addClass('hidden');
});
所以基本上我正在搜索列表项内的类中包含的内容,并向列表项数据添加属性。后来我搜索包含特定数据的列表项。
for循环中使用的变量区域是一个包含子区域信息的数组,如下所示:
areas = array(ID:{区域, array(子区域)})
“containsi”只是“contains”的扩展版本,它工作得很好,所以这不是问题。
我注意到我添加的数据属性没有显示在源代码中,让我相信 jQuery 以其他方式保存这些属性。我想这就是我收到错误的原因(因为 DOM 中不存在搜索的属性)。
有什么想法吗?
/奥洛夫
最佳答案
我想这对你会有帮助
首先,我编写 .each() 函数,在该函数内我检查属性是否存在。
示例代码
listItems.find(".area").each(function()
{
var attr = $(this).attr("attributeNameHere");
if (typeof attr !== 'undefined' && attr !== false) {
for (var j = areas[i].subareas.length - 1; j >= 0; j--)
{
subarea = areas[i].subareas[j];
$(this).closest("li").attr("data-area", $(this).closest("li").attr("data-area") + subarea + ' ');
}
console.log($(this).closest("li").attr("data-area"));
}
});
关于jquery - 找到一个刚刚由 jQuery 添加的数据属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24282335/
实现信息技术的自主可控,可以说是金融行业最紧迫、最重要的推进战略了。 人民银行、银保监会等主管部门密集出台文件,指导金融行业核心领域自主可控技术应用。 拿数据库来说,自主可控这事儿业内也
在methods中创建方法showtime,传入要跟当前时间要对比的时间 ?
其实这个没什么技术含量,当然就直接贴代码,不废话了, 但是在其实开发中还是蛮有用的,譬如论坛帖子,围脖等都有相关应用 复制代码代码如下: function tranTim
今天,杭州人的朋友圈都被这场晚会刷屏了 分散在全球的阿里人都回到杭州,为阿里巴巴送上20周岁的生日祝福。 阿里巴巴20周年年会,被称作“有史以来杭州规模最大的年会”,没有
在很多场合为了显示出信息的及时性,一般会将时间显示成“刚刚”,“5分钟前”,“3小时前”等,而不是直接将时间打印出来。比如微博,SNS类应用就最长用到这个功能。而一般存储在数据库中的时间格式为 Un
我是一名优秀的程序员,十分优秀!