日期处理

在抓取网页的时候,通常情况下网页会提供日期。这篇教程用于说明插件应当如何正确的处理相关情况

# 没有日期

在源没有提供日期的时候,请勿添加日期。pubDate选项应当被留空。

# 规范

pubDate必须是一个

  1. Date Object (opens new window)。
  2. 不推荐,用于兼容 可以被正确解析的字符串。因为其行为可能在不同环境下不一致,Date.parse() (opens new window),请尽量避免

同时,脚本传入的pubDate应当是对应服务器所使用的时区/时间。更多细节参阅下方工具类

# 使用工具类

目前,我们推荐使用dayjs (opens new window)进行日期的处理和时区调整。相关工具类有两个:

# Parse Date

这个是一个工具类用于使用dayjs (opens new window)。大部分情况下,应当可以直接使用他获取到正确的Date Object

具体解析参数请参考dayjs github说明

const { parseDate } = require('@/utils/parse-date');

const pubDate = parseDate('2020/12/30', 'YYYY/MM/DD');

如果你需要解析相对日期,请使用 parseRelativeDate。

const { parseRelativeDate } = require('@/utils/parse-date');

const pubDate = parseRelativeDate('2天前');
const pubDate = parseRelativeDate('前天 15:36');

# Timezone

部分网站并不会依据访问者来源进行时区转换,此时获取到的时间是网站本地时间,不一定适合所有RSS订阅者。此时,应当手动指定获取的时间时区:

注意

此时,时间将会被转换到服务器时间,方便后续中间件处理。这个是正常流程!

const timezone = require('@/utils/timezone');

const pubDate = timezone(new Date(), +8)