ie中的html分页控制,用IE打印网页表格,实现自动分页、每页加表头

1. 建立表格样式表

.tabprint thead{

display:table-header-group;

}

.tabprint td{

border-right:1px solid black;

border-bottom:1px solid black;

}

.tabprint {

border-left:1px solid black;

/*border-top:1px solid black;*/

}

.tp_border_top td{

BORDER-TOP: black 1px solid;

BORDER-RIGHT: black 1px solid; BORDER-BOTTOM: black 1px solid;

}

第2步: .添加分页函数

//分页打印函数

function tabprintpage(ptabid){

var srctab = document.getElementById(ptabid);

for(var i=0;i

var tr=srctab.rows[i];

for(var j=0;j

if(tr.cells[j].innerText.replace(/ /g,"") == ""){

tr.cells[j].innerText = " ";  //这里给空单元格填充一个空格,否则表格线画不出来

}

}

}

var MAX_PAGE_HEIGHT = 720; //一页的高度,单位是象素,此处需要配置(不是恒定的值,与计算机单位象素的绝对长度有关,而不同计算机该值是不同的)

var page = 1;

var srctab = document.getElementById(ptabid);

var ohead = srctab.rows[0].getBoundingClientRect();

var tab_head_height = ohead.bottom - ohead.top;  //计算表头高度

var prev_page_bottom = 0; //上一页的页尾位置

for(var i=1;i

var obj = srctab.rows[i];

var oRect = obj.getBoundingClientRect();

var top = oRect.top;

var btm = oRect.bottom;

//if(page!=1){  //不是第一页时要减去表头高度

//  var top = oRect.top - tab_head_height;

//  var btm = oRect.bottom - tab_head_height;

//}

var page_height = MAX_PAGE_HEIGHT;

if(page!=1){

page_height = page_height - tab_head_height;  //只有第一页的页高要保留表头高度,其它页的页高要减表头高度

}

var mt = (top - prev_page_bottom) % page_height;

var mb = (btm - prev_page_bottom) % page_height;

/** 如果分页点落在行的起点,则在行前分页,行落在下一页 **/

if(mt==0 && top != 0 && top != prev_page_bottom){  //当在上一行的行尾分页时,下一行的行头也会满足mt==0,所以需要判断 top != prev_page_bottom

srctab.rows[i].style.pageBreakBefore="always";

prev_page_bottom = oRect.top;

page++;

continue;

}

/** 如果分页点落在行的终点,则在行后分页,行落在当前页 **/

else if(mb == 0){

srctab.rows[i].style.pageBreakAfter="always";

prev_page_bottom = oRect.bottom;

page++;

continue;

}

var rt = (top - prev_page_bottom - mt) / page_height

var rb = (btm - prev_page_bottom - mb) / page_height

if(rt != rb){   /* 如果行起点与行终点不在同一页,则在行前分页,行落在下一页 */

//alert(i + " " + page + " " + prev_page_bottom + " " + oRect.top + " " + oRect.bottom)

srctab.rows[i].style.pageBreakBefore="always";

prev_page_bottom = oRect.top;

//alert(top);

//alert(btm);

page++;

continue;

}

}

srctab.style.visibility = "visible";

}

3.建立表格

车型百公里系数百公里实际里程(km)百公里考核用油(升)吨公里考核用油(升)总考核用油(升)油卡加油量(升)

........... 

3.表格标记的属性样式必须按上面提供的定义,不能更改, 否则效果会变化 4.表格必须有  标记,当有多表头时,该标记可以包含多行, 5.表头第一行 标记要有 tp_border_top 样式 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要实现分页打印每页表头,可以使用 Vue.js 的自定义指令和 CSS 的 @media print 属性。 首先,在 Vue.js 创建一个自定义指令,用于将分页打印样式应用于需要打印的元素。例如: ```javascript Vue.directive('print', { bind: function(el, binding, vnode) { el.printStyle = document.createElement('style') el.printStyle.setAttribute('media', 'print') document.head.appendChild(el.printStyle) el.printStyle.sheet.insertRule('@page { size: A4; margin: 0; }', 0) el.printStyle.sheet.insertRule('@media print { body { visibility: hidden; } }', 1) el.printStyle.sheet.insertRule('@media print { .page { visibility: visible; } }', 2) el.printStyle.sheet.insertRule('.page { page-break-after: always; }', 3) }, unbind: function(el, binding, vnode) { document.head.removeChild(el.printStyle) el.printStyle = null } }) ``` 在这个自定义指令,我们首先创建一个 style 元素,并将其设置为打印媒体类型。然后,我们插入一些 CSS 规则,以实现以下效果: - 将页面大小设置为 A4,同时将页边距设置为 0; - 将页面内容设置为不可见,以便在打印时隐藏非打印内容; - 将所有带有 .page 类名的元素设置为可见,并在它们之间插入分页符; - 将所有带有 .page 类名的元素之后的内容设置为不可见。 接下来,在需要分页打印的元素上添 .page 类名,并使用 v-print 指令将其转换为打印样式。例如: ```html <div v-print> <div class="page"> <h1>表头</h1> <table> <!-- 表格内容 --> </table> </div> <div class="page"> <h1>表头</h1> <table> <!-- 表格内容 --> </table> </div> <!-- 更多 .page 元素 --> </div> ``` 在这个示例,我们将需要分页打印的元素包装在一个包含 v-print 指令的 div 元素。然后,我们在每个需要打印表格之前添一个带有 .page 类名的 div 元素,以将其转换为打印页面。在每个 .page 元素,我们包含一个表头和一个表格,以及任何其他需要打印的内容。 最后,我们可以使用浏览器的打印功能来打印分页内容,每页都会自动包含表头。 ### 回答2: Vue实现分页打印每页表头可以通过以下步骤来实现: 1. 首先,准备好需要打印的数据以及表头,可以将它们存储在Vue的数据对象。 2. 在Vue的模板,使用一个table来展示需要打印的数据,并在表格表头。 3. 使用Vue提供的计算属性computed来对需要打印的数据进行分页处理。根据每页显示的行数,将数据分成多个页,每页存储在一个数组。 4. 在Vue的方法methods,编写一个打印函数。该函数会根据当前页数,获取对应的数据数组,并将其渲染到打印预览页面。 5. 在打印预览页面,使用CSS样式设置每一页打印的格式,包括设置每页的大小、页眉、页脚等。可以使用@media print媒体查询来适应打印样式。 6. 在打印预览页面,使用Vue的v-for指令遍历当前页的数据数组,将数据逐行渲染到打印预览页面的table。 7. 为了实现每页表头,需要在每页的table单独添表头。可以通过条件判断,只在每页的第一行添表头。 8. 最后,通过window.print()方法来触发浏览器的打印功能,将打印预览页面的内容打印出来。 以上就是用Vue实现分页打印每页表头的大致步骤。通过分页和渲染不同的数据数组,上设置打印样式和条件判断,可以实现每页表头打印效果。 ### 回答3: Vue.js可以通过在模板使用`v-for`指令和计算属性来实现分页打印,并且每一页都带有表头。 首先,需要定义一个计算属性来根据当前页数和每页显示的数量来计算要显示的数据列表。计算属性可以利用数组的`slice`方法来截取对应页数的数据,然后在模板使用`v-for`指令循环渲染数据。 ```javascript data() { return { pageNum: 1, // 当前页数 pageSize: 10, // 每页显示的数量 tableData: [/* 数据列表 */], tableHeader: [/* 表头数据 */], } }, computed: { paginatedData() { const start = (this.pageNum - 1) * this.pageSize; const end = this.pageNum * this.pageSize; return this.tableData.slice(start, end); } } ``` 然后,在模板使用`paginatedData`计算属性来渲染每一页的数据列表,同时在表格的头部也渲染表头数据。 ```html <table> <thead> <tr> <th v-for="header in tableHeader" :key="header">{{ header }}</th> </tr> </thead> <tbody> <tr v-for="item in paginatedData" :key="item.id"> <td>{{ item.field1 }}</td> <td>{{ item.field2 }}</td> <!-- 其他表格列 --> </tr> </tbody> </table> ``` 此时,在页面显示的表格将会按照当前页数和每页显示的数量进行分页,并且每一页都带有表头。 当用户切换页数时,Vue.js会自动触发计算属性的重新计算,从而更新显示的数据列表。可以通过给页码增按钮来实现翻页功能,当用户点击按钮时,更新`pageNum`的值,从而触发计算属性的重新计算。 ```html <button @click="pageNum -= 1" :disabled="pageNum === 1">上一页</button> <button @click="pageNum += 1" :disabled="(pageNum * pageSize) >= tableData.length">下一页</button> ``` 以上就是使用Vue.js实现分页打印并且每一页带有表头的方法。有了这个实现,可以根据实际需求来对分页功能进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值