Comment puis-je fixer le dernier jour des erreurs mois qui résultent de ce code php?

StackOverflow https://stackoverflow.com/questions/762106

  •  11-09-2019
  •  | 
  •  

Question

Le code ci-dessous est ce que je suis en utilisant un menu site qui déplace le lien pour la page du mois en cours au sommet de la liste des liens sur le changement du mois.

Mais cela échoue le 31 quelques mois, comme Avril; Je reçois deux liens vers le même mois pour la plupart des liens. Je l'ai lu à travers les problèmes avec la façon dont php génère dates, mais ne peut pas comprendre comment changer ce code.

Le manque Anyone php Ph.D de prendre un coup de poignard à elle? Merci

<?php $month1 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+1 , date('d'), date('Y'))));
$month2 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+2 , date('d'), date('Y'))));
$month3 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+3 , date('d'), date('Y'))));
$month4 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+4 , date('d'), date('Y'))));
$month5 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+5 , date('d'), date('Y'))));
$month6 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+6 , date('d'), date('Y'))));
$month7 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+7 , date('d'), date('Y'))));
$month8 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+8 , date('d'), date('Y'))));
$month9 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+9 , date('d'), date('Y'))));
$month10 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+10 , date('d'), date('Y'))));
$month11 = (date('F', mktime(date('H'), date('i'), date('s'), date('m')+11 , date('d'), date('Y')))); ?>

<a href="http://mydomain.com/<?php echo strtolower(date('F')); ?>/" title="<?php echo ucfirst(date('F')); ?>"><?php echo (date('F')); ?></a><br />

<a href="http://mydomain.com/<?php echo strtolower($month1); ?>/" title="<?php echo $month1; ?>"><?php echo $month1; ?></a><br />

...(2 through 10)...

<a href="http://mydomain.com/<?php echo strtolower($month11); ?>/" title="<?php echo $month11; ?>"><?php echo $month11; ?></a><br />
Était-ce utile?

La solution

<?php

$current_month = date('n');
$MONTHS = array();
for ($m=0; $m<12; $m++) {
  $display_month = $m + $current_month;
  $MONTHS[] = date('F',mktime(1,1,1,$display_month,1,date("Y")));
}
foreach ($MONTHS as $month) {
  echo "
    <a
      href=\"http://mydomain.com/".strtolower($month)."\"
      title=\"$month\">$month</a><br />";
}
?>

Autres conseils

Vous pouvez regarder dans strtotime () au lieu de mktime . Etant donné que dans strtotime () pour peut faire

strtotime("-1 day", time());

Le 1er mois un certain et il y retourner un jour exactement. Même en comptant les années bissextiles.

Utiliser 1 au lieu de la date ( 'd') dans votre code; Cependant, chaque fois que vous voyez le code dupliquée, où un nombre change, vous devriez penser à boucles:

<?php
for ($i = 0; $i < 12; $i++) {
    $month = date('F', mktime(0, 0, 0, date('m') + $i, 1, date('Y')));
?>

    <a href="http://mydomain.com/<?php echo strtolower($month); ?>" title="<?php echo $month; ?>"><?php echo $month; ?></a><br />

<?php
}
?>

je ne sais pas si cela résout votre problème, car je ne suis pas sûr d'avoir compris quel était le problème, mais j'ai une idée sur la façon dont vous pouvez faire ce code un peu plus lisible:

<?php 
    $month1 = date('F', strtotime("+1 month"));
    $month2 = date('F', strtotime("+2 month"));
    $month3 = date('F', strtotime("+3 month"));
    $month4 = date('F', strtotime("+4 month"));
    $month5 = date('F', strtotime("+5 month"));
    $month6 = date('F', strtotime("+6 month"));
    $month7 = date('F', strtotime("+7 month"));
    $month8 = date('F', strtotime("+8 month"));
    $month9 = date('F', strtotime("+9 month"));
    $month10 = date('F', strtotime("+10 month"));
    $month11 = date('F', strtotime("+11 month"));
?>

(mais je suis également d'accord avec la note du Tchad Birch sur l'utilisation de boucles au lieu de répéter le code)

<?php
    foreach(range(0,11) as $key){
        $months[$key]=date('F', strtotime("+{$key} month"));
    }
/* ... */
    foreach($months as $month){
        print "<a href='http://mydomain.com/".strtolower($month).
            "' title='".$month."'>".$month."</a><br />";
    }
?>

Oh dear, qui est un code laid. Vous devriez vraiment regarder dans boucles (pour / en / etc) et tableaux .

Le code que vous avez, il pourrait être réduit à ceci:

Modifié . mon code a le même problème que l'original, fixe en utilisant la solution de scronide, merci pour le signaler

<?php
for ($i = 0; $i < 12; $i++)
{
    $months[$i] = date('F', mktime(0, 0, 0, date('m') + $i, 1, date('Y')));
}

for ($i = 0; $i < 12; $i++)
{
    print '<a href="http://mydomain.com/'.strtolower($months[$i]).'/" title="'.$months[$i].'">'.$months[$i]."</a><br />\n";
}
?>

Ou si vous ne me dérange pas de combiner les deux fonctions (obtenir les noms de mois, et les liens d'impression) ensemble, et vous n'avez pas besoin les noms de mois stockés pour toute autre chose:

<?php
for ($i = 0; $i < 12; $i++)
{
    $month = date('F', mktime(0, 0, 0, date('m') + $i, 1, date('Y')));
    print '<a href="http://mydomain.com/'.strtolower($month)."/\" title=\"$month\">$month</a><br />\n";
}
?>
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top