
jquery isotope 是一个强大的布局和过滤库,它通过 getsortdata 选项来定义元素的排序依据。通常,我们可以直接指定一个选择器(如 .name)来获取文本内容进行排序,或者使用 parseint 等类型转换函数来处理数字。然而,当涉及到日期排序时,情况会变得复杂,尤其是当日期字符串的格式不统一时,例如:
直接对这些混合格式的字符串进行排序会导致结果混乱,因为 Isotope 默认的字符串比较或简单的 parseInt 无法正确理解它们的实际时间顺序。为了解决这个问题,我们需要一个能够将所有这些不同日期格式统一转换为可比较的数值(例如 Unix 时间戳)的方法。Isotope 的 getSortData 允许我们传入一个回调函数,这正是解决此类问题的关键。
解决复杂日期格式排序的核心在于编写一个健壮的 JavaScript 函数,该函数能够识别并解析各种日期字符串,并返回一个统一的数值时间戳。以下是一个 parseDate 函数的实现,它尝试处理上述多种日期格式:
/**
* 尝试解析多种格式的日期字符串,并返回其时间戳。
* 如果解析失败,则返回 0 或其他默认值。
* @param {string} s - 待解析的日期字符串。
* @returns {number} - 日期对应的时间戳(毫秒),如果解析失败则为 0。
*/
let parseDate = function(s) {
let r = null; // 初始化结果
// 动态计算今天和昨天的日期字符串,用于替换相对日期描述
const today = new Date();
const yesterday = new Date();
yesterday.setDate(today.getDate() - 1); // 设置为昨天
// 获取标准格式的日期字符串,例如 "Thu Jun 20 2024"
const todayDateString = today.toDateString();
const yesterdayDateString = yesterday.toDateString();
// 尝试多种格式的字符串
// 1. 原始字符串
// 2. 将 "Yesterday at" 替换为昨天的日期字符串,并确保 "am/pm" 前有空格
// 3. 将 "Today at" 替换为今天的日期字符串,并确保 "am/pm" 前有空格
let tries = [
s,
s.replace(/^Yesterday at/, yesterdayDateString + ', ').replace(/([0-9])(am|pm)$/, '$1 $2'),
s.replace(/^Today at/, todayDateString + ', ').replace(/([0-9])(am|pm)$/, '$1 $2')
];
for (let i = 0; i < tries.length; i++) {
let s2 = tries[i];
// 尝试使用 Date.parse() 解析
r = Date.parse(s2);
if (!isNaN(r)) {
// 解析成功,跳出循环
break;
}
// 如果 Date.parse() 失败,尝试使用 new Date() 构造函数解析
const dt = new Date(s2);
if (dt instanceof Date && !isNaN(dt)) {
r = dt.getTime(); // 获取时间戳
if (r) {
// 解析成功,跳出循环
break;
}
}
}
// 如果所有尝试都失败,返回一个默认值。
// 返回 0 可以将无法解析的日期统一排在某个位置。
if (isNaN(r) || r === null) {
// 实际应用中可以根据需求选择返回 Number.MIN_SAFE_INTEGER 或 Number.MAX_SAFE_INTEGER
// 以确保无法解析的项排在最前或最后。这里返回 0 作为一个简单示例。
return 0;
}
return r; // 返回解析成功的时间戳
};现在,我们需要将这个自定义的 parseDate 函数应用到 Isotope 的 getSortData 配置中。假设您的 HTML 结构中,日期信息位于一个带有 lastposted 类的 <span> 元素中,或者存储在 data-id 属性中(虽然日期通常不建议存放在 data-id 中,但这里假设其内容是日期字符串)。
原始的 getSortData 配置可能如下:
getSortData: {
// ... 其他排序键
lastposted: '[data-id] parseInt', // 尝试解析 data-id 为整数,但对于日期不适用
// ...
},为了使用我们的 parseDate 函数,您需要将 lastposted 的值从选择器字符串更改为回调函数。这个回调函数会接收到当前 Isotope 项的 jQuery 对象作为参数,您可以在其中提取日期字符串并传递给 parseDate。
假设日期字符串位于 .lastposted 元素中:
<div class="ml-item" data-category="group-1" data-id="123">
<span class="lastposted">May 25, 2023</span>
<!-- ... 其他内容 ... -->
</div>
<div class="ml-item" data-category="group-2" data-id="456">
<span class="lastposted">Today at 11:22pm</span>
<!-- ... 其他内容 ... -->
</div>那么,Isotope 的 getSortData 配置应修改为:
// 初始化 Isotope
var $grid = $('.member-list').isotope({
itemSelector: '.ml-item',
layoutMode: 'fitRows',
fitRows: {
gutter: 5
},
getSortData: {
name: '.name',
faceclaim: '.faceclaim',
posts: '.posts parseInt',
group: '[data-category]',
// 将 lastposted 的值设置为我们的 parseDate 函数
// 该函数会接收到当前 Isotope 项的 jQuery 对象作为上下文
lastposted: function( itemElem ) {
// 从当前项中找到包含日期字符串的元素,并获取其文本内容
const dateString = $(itemElem).find('.lastposted').text();
return parseDate(dateString); // 调用自定义解析函数
},
alias: '.alias'
},
sortAscending: {
name: true,
posts: false,
lastposted: true, // true 表示升序(最早的日期在前)
group: true,
faceclaim: true,
alias: true
},
filter: function() {
// ... 过滤逻辑 ...
}
});重要提示: 如果您的日期字符串是存储在 data-id 属性中,那么 getSortData 的回调函数内部应相应地修改为:
lastposted: function( itemElem ) {
const dateString = $(itemElem).attr('data-id'); // 假设 data-id 存储日期字符串
return parseDate(dateString);
},请确保 data-id 属性确实包含可解析的日期字符串,否则这种做法可能不合适。通常,日期信息更适合放在独立的 data-date 属性或一个可见的 <span> 元素中。
通过上述方法,利用 Isotope getSortData 的回调函数能力,结合自定义的日期解析逻辑,您可以有效地解决 jQuery Isotope 在处理复杂且多样化日期格式时排序不准确的问题,从而为用户提供更准确、更友好的排序体验。
以上就是解决 jQuery Isotope 复杂日期格式排序不准确问题的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号