我正在制作一个显示日期和时间列表(Timezone EST)的小提琴。
1 août 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
2 août 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
ût 03:45 /* When timezone is eastern standard time */
ût 05:00 /* When timezone is eastern standard time */
上面的小提琴的工作方式是当值与前一行相同时隐藏日期,这意味着不在日期与前一行相同的行上显示日期,以便按日期显示视觉中断。
问题陈述:
上面的小提琴工作得很好。我遇到的唯一问题是当月份是法语时,它不会隐藏一些法语字符或之后的任何内容。在上面的 o/p 中,ût 仍然可见,但不应该。
// we have to iterate backwards...
$($('.schedule-show').get().reverse()).each(function(i, div){
let time = $(div).find('[data-timezone="et"]')
let nextTime = $(div).find('+ .schedule-show [data-timezone="et"]')
if(nextTime[0]){
// check if they dates match
if(nextTime.text().match(/\d+ \w+/)[0] === time.text().match(/\d+ \w+/)[0]){
// "white out" the dates that match
nextTime.html(nextTime.text().replace(/(\d+ \w+)/, "<font color=\"white\">$1</font>"))
}
}
})
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="schedule-wrapper" id="js-schedule" data-timezone="et"> /* The value of data-timezone attribute changes on button click from the Screenshot below */
<!-- List of button start -->
<div class="schedule-action-bar">
<div class="schedule-timezone-filter">
Select your timezone:
<ul id="js-timezone-picker">
<li>
<button id="js-time-et" class="" data-timezone="et">ET</button>
</li>
</ul>
</div>
</div>
<!-- List of button end -->
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 01-08-2019" data-timezone="et">1 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 01-08-2019" data-timezone="et">1 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 01-08-2019" data-timezone="et">1 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 01-08-2019" data-timezone="et">1 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 01-08-2019" data-timezone="et">1 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<!-- .schedule-show -->
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 02-08-2019" data-timezone="et">2 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 02-08-2019" data-timezone="et">2 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 02-08-2019" data-timezone="et">2 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="03:45 02-08-2019" data-timezone="et">2 août 03:45</time> /* When timezone is eastern standard time */
</div>
</div>
<!-- .schedule-show -->
<div class="schedule-show">
<div class="schedule-show-time">
<time datetime="05:00 02-08-2019" data-timezone="et">2 août 05:00</time> /* When timezone is eastern standard time */
</div>
</div>
<!-- .schedule-show -->
</div>