日期处理
在抓取网页的时候,通常情况下网页会提供日期。这篇教程用于说明插件应当如何正确的处理相关情况
# 没有日期
在源没有提供日期的时候,请勿添加日期。pubDate
选项应当被留空。
# 规范
pubDate
必须是一个
- Date Object (opens new window)。
- 不推荐,用于兼容 可以被正确解析的字符串。因为其行为可能在不同环境下不一致,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)