How to make a HTML Page in A4 paper size page(s)?

前端 未结 15 1817
有刺的猬
有刺的猬 2020-11-22 16:30

Is it possible to make a HTML page behave, for example, like a A4-sized page in MS Word?

Essentially, I want to be able to show the HTML page in the browser, and out

相关标签:
15条回答
  • 2020-11-22 17:19

    Ages ago, in November 2005, AlistApart.com published an article on how they published a book using nothing but HTML and CSS. See: http://alistapart.com/article/boom

    Here's an excerpt of that article:

    CSS2 has a notion of paged media (think sheets of paper), as opposed to continuous media (think scrollbars). Style sheets can set the size of pages and their margins. Page templates can be given names and elements can state which named page they want to be printed on. Also, elements in the source document can force page breaks. Here is a snippet from the style sheet we used:

    @page {
       size: 7in 9.25in;
       margin: 27mm 16mm 27mm 16mm;
    }
    

    Having a US-based publisher, we were given the page size in inches. We, being Europeans, continued with metric measurements. CSS accepts both.

    After setting the up the page size and margin, we needed to make sure there are page breaks in the right places. The following excerpt shows how page breaks are generated after chapters and appendices:

    div.chapter, div.appendix {
        page-break-after: always;
    }
    

    Also, we used CSS2 to declare named pages:

    div.titlepage {
      page: blank;
    }
    

    That is, the title page is to be printed on pages with the name “blank.” CSS2 described the concept of named pages, but their value only becomes apparent when headers and footers are available.

    Anyway…

    Since you want to print A4, you'll need different dimensions of course:

    @page {
        size: 21cm 29.7cm;
        margin: 30mm 45mm 30mm 45mm;
         /* change the margins as you want them to be. */
    }
    

    The article dives into things like setting page-breaks, etc. so you might want to read that completely.

    In your case, the trick is to create the print CSS first. Most modern browsers (>2005) support zooming and will already be able to display a website based on the print CSS.

    Now, you'll want to make the web display look a bit different and adapt the whole design to fit most browsers too (including the old, pre 2005 ones). For that, you'll have to create a web CSS file or override some parts of your print CSS. When creating CSS for web display, remember that a browser can have ANY size (think: “mobile” up to “big-screen TVs”). Meaning: for the web CSS your page-width and image-width is best set using a variable width (%) to support as many display devices and web-browsing clients as possible.

    EDIT (26-02-2015)

    Today, I happened to stumble upon another, more recent article at SmashingMagazine which also dives into designing for print with HTML and CSS… just in case you could use yet-another-tutorial.

    EDIT (30-10-2018)

    It has been brought to my attention in that size is not valid CSS3, which is indeed correct — I merely repeated the code quoted in the article which (as noted) was good old CSS2 (which makes sense when you look at the year the article and this answer were first published). Anyway, here's the valid CSS3 code for your copy-and-paste convenience:

    @media print {
        body{
            width: 21cm;
            height: 29.7cm;
            margin: 30mm 45mm 30mm 45mm; 
            /* change the margins as you want them to be. */
       } 
    }
    

    In case you think you really need pixels (you should actually avoid using pixels), you will have to take care of choosing the correct DPI for printing:

    • 72 dpi (web) = 595 X 842 pixels
    • 300 dpi (print) = 2480 X 3508 pixels
    • 600 dpi (high quality print) = 4960 X 7016 pixels

    Yet, I would avoid the hassle and simply use cm (centimeters) or mm (millimeters) for sizing as that avoids rendering glitches that can arise depending on which client you use.

    0 讨论(0)
  • 2020-11-22 17:20

    A4 size is 210x297mm

    So you can set the HTML page to fit those sizes with CSS:

    html,body{
        height:297mm;
        width:210mm;
    }
    
    0 讨论(0)
  • 2020-11-22 17:23

    Technically, you could, but it would take a lot of work to get all browsers to print out the page exactly as it is displayed on screen. Also, most browsers force the URL, print date and page numbering on the print-out, which is not always desired. This cannot be altered or disabled.

    Instead, I would advise to create a PDF based on the contents on screen and serve the PDF for downloading and/or printing. Although most available PDF libraries are paid, there are a few free alternatives available for creating basic PDFs.

    0 讨论(0)
  • 2020-11-22 17:25

    Looking for similar problem I found this - http://www.indigorose.com/forums/archive/index.php/t-13334.html

    A4 is a document format, as a screen image that's going to depend on the image resolution, for example an A4 document resized to:

    • 72 dpi (web) = 595 X 842 pixels
    • 300 dpi (print) = 2480 X 3508 pixels (This is "A4" as I know it, i.e. "210mm X 297mm @ 300 dpi")
    • 600 dpi (print) = 4960 X 7016 pixels
    0 讨论(0)
  • 2020-11-22 17:27

    Many ways to do:

    html,body{
        height:297mm;
        width:210mm;
    }
    
    
    html,body{
        height:29.7cm;
        width:21cm;
    }
    
    html,body{
        height: 842px;
        width: 595px;
    }
    
    0 讨论(0)
  • 2020-11-22 17:32
    <link rel="stylesheet" href="/css/style.css" type="text/css">
    <link rel="stylesheet" href="/css/print.css" type="text/css" media="print">
    

    In your normal style.css:

    table.tableclassname {
      width: 400px;
    }
    

    In your print.css:

    table.tableclassname {
      width: 16 cm;
    }
    
    0 讨论(0)
提交回复
热议问题