javascript - 用 attr 查找 div 并更改其样式
问题描述
我想找到一个具有属性 data-date 的 div,如果它等于今天的日期,请更改其样式。
这就是我形成该元素的方式(我必须在 JS 中完成):
for (let i = 0; i < datesArray.length; i++) {
const someDate = new Date(datesArray[i]);
const date = document.createElement('div');
date.setAttribute('id', '' + new Date(datesArray[i]).getTime());
date.setAttribute('class', 'date');
date.setAttribute('data-date', new Date(datesArray[i]).toDateString());
date.innerText = '' + formatDate(someDate);
daysRowFragment.appendChild(
const formattedDate = date.innerText;
const className = formattedDate.substring(0, formattedDate.indexOf(' ')).toLowerCase() === 'sat' ||
formattedDate.substring(0, formattedDate.indexOf(' ')).toLowerCase() === 'sun' ? 'day weekend' : 'day';
$(".calendar-row").append(`
<div id="` + new Date(datesArray[i]).getDate() + '-' + i + `" data-date="` + new Date(datesArray[i]).toDateString() + `" class="` + className + `">
</div>
`);
}
daysRow.appendChild(daysRowFragment);
我已经尝试过了,但它不起作用(日期格式不一样):
$('.date').each(function (index, dateCell) {
console.log($(dateCell).attr('data-date'));
console.log(new Date());
if ($(dateCell).attr('data-date') == new Date()) {
$(dateCell).css('background-color', 'red');
}
});
解决方案
在这里,我尝试为您制定解决方案。
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script>
$(function() {
$( "[data-date='todaydate']" ).each(function(){
$(this).css('color','red');
});
});
</script>
</head>
<body>
<span id="term1" data-date='todaydate'>Lorem ipsum dolor sit amet 1</span>
<span id="term2" data-date='nottoday'>Lorem ipsum dolor sit amet 2</span>
<span id="term3" data-date='nottoday'>Lorem ipsum dolor sit amet 3</span>
<span id="term4" data-date='nottoday'>Lorem ipsum dolor sit amet 4</span>
<span id="term5" data-date='todaydate'>Lorem ipsum dolor sit amet 5</span>
<span id="term6" data-date='nottoday'>Lorem ipsum dolor sit amet 6</span>
</body>
</html>
推荐阅读
- css - CSS - 如何指定 calc() 的单位?
- google-apps-script - 用户在 Google 表格中输入后如何舍入单元格?
- python-3.x - 如何从 Web Scrap 添加到索引
- typescript - 更改文本编辑器时如何修复 VScode 装订线指示器工件?
- javascript - 在生产中部署 React JS 应用程序后,最新的更改不会出现在浏览器上
- odbc - 向 odbc 添加额外的转义序列
- php - WordPress,我正在做排名功能,但是如果帖子没有吸引眼球,它会被计算两次
- android - 想要从存储库返回列表到 viewmodel MVVM
- python - 为什么我不能针对单个变量检查多个值,而是必须分别针对每个值检查变量?
- python - 加载retinanet模型时的tensorflow keras导入问题