html表格框怎么变消失了,javascript – 打印时HTML表格上没有边框

我正在研究应该打印表的网站.

我遇到的一个问题是,虽然它们在屏幕上正确显示,但是不会打印某些表格边框.

我尝试过Firefox和Chrome.两者都在屏幕上显示所有表格边框,但在打印时省略了一些边框.

我需要做些什么来打印它们?

编辑1:添加了jsFiddle:

码:

JavaScript的:

function printDiv()

{

var divToPrint=document.getElementById('table');

newWin= window.open("");

newWin.document.write(divToPrint.outerHTML);

newWin.print();

newWin.close();

}

CSS:

html, body, div, span, object, iframe,

h1, h2, h3, h4, h5, h6, p, blockquote, pre,

abbr, address, cite, code,

del, dfn, em, img, ins, kbd, q, samp,

small, strong, sub, sup, var,

b, i,

dl, dt, dd, ol, ul, li,

fieldset, form, label, legend,

table, caption, tbody, tfoot, thead, tr, th, td {

margin: 0;

padding: 0;

border: 0;

outline: 0;

font-size: 100%;

vertical-align: baseline;

background: transparent;

}

body {

margin: 0;

padding: 0;

font: 12px/15px "Helvetica Neue", Arial, Helvetica, sans-serif;

color: #555;

background: #f5f5f5 url(bg.jpg);

}

a {

color: #666;

}

#content {

width: 65%;

max-width: 690px;

margin: 6% auto 0;

}

table {

overflow: hidden

border: 1px solid #d3d3d3;

background: #fefefe;

width: 70%;

margin: 5% auto 0;

-moz-border-radius: 5px; /* FF1+ */

-webkit-border-radius: 5px; /* Saf3-4 */

border-radius: 5px;

-moz-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);

-webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);

}

th, td {

padding: 18px 28px 18px;

text-align: center;

}

th {

padding-top: 22px;

text-shadow: 1px 1px 1px #fff;

background: #e8eaeb;

}

td {

border-top: 1px solid #e0e0e0;

border-right: 1px solid #e0e0e0;

}

tr.odd-row td {

background: #f6f6f6;

}

td.first, th.first {

text-align: left

}

td.last {

border-right: none;

}

/*

Background gradients are completely unnecessary but a neat effect.

*/

td {

background: -moz-linear-gradient(100% 25% 90deg, #fefefe, #f9f9f9);

background: -webkit-gradient(linear, 0% 0%, 0% 25%, from(#f9f9f9), to(#fefefe));

}

tr.odd-row td {

background: -moz-linear-gradient(100% 25% 90deg, #f6f6f6, #f1f1f1);

background: -webkit-gradient(linear, 0% 0%, 0% 25%, from(#f1f1f1), to(#f6f6f6));

}

th {

background: -moz-linear-gradient(100% 20% 90deg, #e8eaeb, #ededed);

background: -webkit-gradient(linear, 0% 0%, 0% 20%, from(#ededed), to(#e8eaeb));

}

tr:first-child th.first {

-moz-border-radius-topleft: 5px;

-webkit-border-top-left-radius: 5px; /* Saf3-4 */

}

tr:first-child th.last {

-moz-border-radius-topright: 5px;

-webkit-border-top-right-radius: 5px; /* Saf3-4 */

}

tr:last-child td.first {

-moz-border-radius-bottomleft: 5px;

-webkit-border-bottom-left-radius: 5px; /* Saf3-4 */

}

tr:last-child td.last {

-moz-border-radius-bottomright: 5px;

-webkit-border-bottom-right-radius: 5px; /* Saf3-4 */

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以使用HTML的`border-collapse`和`border`属性来合并表格边框。以下是一个示例代码: ```html <!DOCTYPE html> <html> <head> <title>合并表格边框</title> <style> table { border-collapse: collapse; } td, th { border: 1px solid black; padding: 10px; } </style> </head> <body> <table> <tr> <th>姓名</th> <th>年龄</th> <th>性别</th> <th>城市</th> </tr> <tr> <td>张三</td> <td>18</td> <td>男</td> <td>北京</td> </tr> <tr> <td>李四</td> <td>20</td> <td>女</td> <td>上海</td> </tr> </table> </body> </html> ``` 在上面的示例中,`border-collapse: collapse;`属性合并了表格边框,`border: 1px solid black;`属性为每个单元格添加了1像素的黑色边框。 ### 回答2: 要合并表格边框,可以使用CSS中的border-collapse属性。此属性可以用于合并两个或多个相邻单元格的边框。 首先,在HTML中创建一个表格元素。例如: <table> <tr> <td>单元格1</td> <td>单元格2</td> </tr> <tr> <td>单元格3</td> <td>单元格4</td> </tr> </table> 然后,在CSS中设置表格的border-collapse属性为collapse。例如: <style> table { border-collapse: collapse; } </style> 这样设置后,相邻单元格的边框将会合并在一起形成一个边框。如果不设置border-collapse属性,默认情况下相邻单元格会显示各自的边框。 最后,将HTML和CSS代码结合起来,就可以创建一个表格边框合并的效果了。 请注意,此方法只能合并相邻单元格的边框,如果想要合并非相邻单元格的边框,需要使用其他的技术或工具实现,比如使用JavaScript或使用其他表格合并工具。 ### 回答3: 在HTML中,我们可以使用CSS属性来合并表格边框。首先,在表格标签中添加class属性,示例如下: <table class="merged-border"> <tr> <th>标题1</th> <th>标题2</th> <th>标题3</th> </tr> <tr> <td>内容1</td> <td>内容2</td> <td>内容3</td> </tr> <tr> <td>内容4</td> <td>内容5</td> <td>内容6</td> </tr> </table> 接下来,在style标签或外部CSS文件中添加下面的CSS代码: <style> .merged-border { border-collapse: collapse; } .merged-border th, .merged-border td { border: 1px solid black; padding: 8px; text-align: left; } .merged-border th:first-child, .merged-border td:first-child { border-left: none; } .merged-border th:last-child, .merged-border td:last-child { border-right: none; } .merged-border tr:first-child th { border-top: none; } .merged-border tr:last-child td { border-bottom: none; } </style> 上述代码中,我们使用了border-collapse属性将表格边框合并为单一边框。同,我们为th和td元素设置了相同的边框样式,并将第一个和最后一个单元格的左右边框去掉,第一行的上边框去掉,最后一行的下边框去掉。 通过以上的HTML和CSS代码,我们可以实现表格边框合并的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值