28172 sujets

CSS et mise en forme, CSS3

Bonjour à tous,

je vous expose mon problème :

je dois pouvoir imprimer une facture sans utiliser le format pdf. Pour cela j'utilise la fonction window.print() . Mon problème est que je voudrais pouvoir mettre un haut de page et bas de page identique sur chacune de mes pages. Pour info, le contenu principale de ma page est un tableau (en gros je voudrai header=>tableau=>footer sur chaque page). J'ai réussi à le faire en utilisant :

<style type=text/css media=print>
#enTetePrint {
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  }
#piedPagePrint {
  display: block;
  position: fixed;
  bottom: 0;
  right: 0;
  }

</style>

Grâce à ce code, j'affiche le header et le footer sur chacunes des pages. Le problème est que mon tableau chevauche le header et le footer. Je voudrais donc dire à mon tableau tu commences à 3 cm du haut et 3 cm du bas sur chacune des pages afin de laisser de la place au pied et haut de page. Je n'ai pas trouvé de solution, j'ai essayé avec @page{ margin-top:3 cm; margin-bottom:3cm;} mais cela pousse le header, le footer et le table de 3cm. J'ai essayé des combinaisons avec @page et le table sans réussir. J'ai aussi essayé avec des thead, tfoot, tbody mais je n'ai pas été convaincu car premièrement, les navigateurs réagissaient différemment et deuxièmement le footer n'était pas tout en bas de la page mais juste après la fin du tableau pour la dernière page.

Je vous demande donc de l'aide pour pouvoir définir des marges mais seulement sur mon tableau. J'espère avoir été à peu prêt claire.

PS : j'utilise ce code :

 tr{
page-break-inside:avoid;
}

pour que les tr de mon tableau ne soit pas coupé. Petit problème, la bordure bottom de chaque <tr> de fin de page n'est pas visible sur le bas de la page mais seulement sur le haut de la prochaine page (sur le tr d'après en gros). Ca fait un peu bisar de pas avoir cette bordure, on a l'impression que le tr n'est pas fini.
Je précise que je souhaite éviter le css3 afin de rendre cela le plus accessible possible.
Bonjour,


Aurais-tu une url présentant ton problème ? Il serait plus facile pour nous de bien comprendre ce qu'il se passe...
Bonjour masseuro,

Je suis désolé, je ne peux donner une url car il s'agit d'un site protégé privé contenant des informations commerciales (c'est pour cela que je veux imprimer des factures Smiley cligne ).

Après réflexion, j'ai opté pour la solution tfoot, thead, tbody. J'ai réglé les problèmes que cela posaient sur les différents navigateurs. Quand j'imprime, j'ai bien mon header, mon contenu, mon footer sur chacune des pages et sans chevauchement. Cependant je suis face à deux problèmes :

- Pour passer à la page suivante à chaque TR j'utilisais page-break-inside:avoid;
Cependant, maintenant cela n'est plus pris en compte. J'ai essayé avec page-break-after et before en auto ça ne fonctionne pas. En always ça fonctionne mais (et c'est logique) ça me fait beaucoup de feuilles pour pas beaucoup de contenu.

- il faut que le footer soit toujours tout en bas. Or sur la dernière page il est juste à la fin du tableau (logique aussi). Avec un height à 100% ça ne rend pas comme ça (encore moins sous IE). De plus si j'arrive à faire le saut de page quand un TR est coupé, le footer sera plus ou moins bas en fonction de la taille du TR le précédent.

Je pense pouvoir régler le problème pour la dernière page afin que le footer soit tout en bas, mais seulement pour la dernière page. Je vais compter le nombre de ligne et s'il n'y a pas assez de ligne pour que le footer soit tout en bas alors j'ajoute des br. (je fais cela en php car j'utilise des requêtes pour afficher le contenu)

Si vous comprenez pas ce que je dis, n'hésitez pas à poser des questions.

Merci d'avance