(Laravel) 检查今天是否在基于开始日期的两个日期之间

(Laravel) check if today is between two dates based on a starting date

我有一个付款 table 用于跟踪某些付款。假设我有一个开始日期,可以是任何日期。每个月都必须付款。

例如,我想跟踪付款是否在需要付款前 5 天到期。这将每天检查一次。为此,我使用以下方法:

public function isDue()
{
    for ($i = 0; $i <= $this->months; $i++) {

        if (Carbon::now()->format('Y-m-d') >= Carbon::createFromFormat('Y-m-d', $this->start)->addMonthsNoOverflow($i)->subDays(5)->format('Y-m-d')
            &&
            Carbon::now()->format('Y-m-d') <= Carbon::createFromFormat('Y-m-d', $this->start)->addMonthsNoOverflow($i)->format('Y-m-d')
        ) {
            return true;
        }
    }
    return false;
}

$this->start 是开始日期。 $this->months表示一共需要支付多少个月的款项。因此,使用 for 循环,根据开始日期检查当前日期。

我的问题基本上是,既然我想做这个犯规证明,有没有好的方法来完成这个,或者像 for 循环之类的东西会起作用吗?上面的代码让我觉得很草率,恐怕不会产生正确的结果。

如果我没理解错的话,你想检查 "start date plus few months" 是否在现在和 5 天前之间。在这种情况下,您可以这样做:

if ($this->start->addMonthsNoOverflow($i)->between(now()->subDays(5), now()))

Carbon 有一些其他的比较辅助方法,包括您可以使用的 isToday()

public function isDue()
{
    for ($i = 0; $i < $this->months; $i++) {
        if ($this->start_date->addMonthsNoOverflow($i)->subDays(5)->isToday()) {
            return true;
        }
    }

    return false;
}

这将像以前一样为每个月创建一个循环,并检查调整后的日期是否为今天。如果是,方法立即 returns true.