html编辑文本固定分页,富文本编辑器[WYSIWYG],使用javascript进行分页

本文介绍了一种使用JavaScript实现类似MS Word中分页功能的方法。通过编写特定的JavaScript代码,可以实现在富文本编辑器中根据输入文本的长度自动创建新页面的功能。此外,还详细说明了如何处理从其他源复制的大段文本,并根据其长度计算所需的页面数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

是否可以使用JavaScript在富文本编辑器中实现类似于MS Word的分页.

我需要使用包含页面文本的JavaScript来实现编辑器.如果我输入的文本超出了页面的限制,则将自动创建一个新页面,并且文本将以完整的格式溢出到新页面.另外,如果我从其他来源复制大文本,则它应根据文本长度计算页面数,并将其划分为具有原始文本所有格式的页面.

我需要仅使用JavaScript,HTML和CSS根据像素大小将文本分成几行.

如果我从页面内部删除内容,则应该在当前页面中填充下一页的内容,如果删除页面中的所有内容,则应该删除该页面. MS word中几乎所有的寻呼功能都应在此实现.

解决方法:

请尝试这个…

Javascript代码pagination.js文件

function Pager(tableName, itemsPerPage) {

this.tableName = tableName;

this.itemsPerPage = itemsPerPage;

this.currentPage = 1;

this.pages = 0;

this.inited = false;

this.showRecords = function(from, to) {

var rows = document.getElementById(tableName).rows;

// i starts from 1 to skip table header row

for (var i = 1; i < rows.length; i++) {

if (i < from || i > to)

rows[i].style.display = 'none';

else

rows[i].style.display = '';

}

}

this.showPage = function(pageNumber) {

if (! this.inited) {

alert("not inited");

return;

}

var oldPageAnchor = document.getElementById('pg'+this.currentPage);

oldPageAnchor.className = 'pg-normal';

this.currentPage = pageNumber;

var newPageAnchor = document.getElementById('pg'+this.currentPage);

newPageAnchor.className = 'pg-selected';

var from = (pageNumber - 1) * itemsPerPage + 1;

var to = from + itemsPerPage - 1;

this.showRecords(from, to);

}

this.prev = function() {

if (this.currentPage > 1)

this.showPage(this.currentPage - 1);

}

this.next = function() {

if (this.currentPage < this.pages) {

this.showPage(this.currentPage + 1);

}

}

this.init = function() {

var rows = document.getElementById(tableName).rows;

var records = (rows.length - 1);

this.pages = Math.ceil(records / itemsPerPage);

this.inited = true;

}

this.showPageNav = function(pagerName, positionId) {

if (! this.inited) {

alert("not inited");

return;

}

var element = document.getElementById(positionId);

var pagerHtml = ' « Prev | ';

for (var page = 1; page <= this.pages; page++)

pagerHtml += '' + page + ' | ';

pagerHtml += ' Next »';

element.innerHTML = pagerHtml;

}

}

HTML文件

.pg-normal {

color: black;

font-weight: normal;

text-decoration: none;

cursor: pointer;

}

.pg-selected {

color: black;

font-weight: bold;

text-decoration: underline;

cursor: pointer;

}

#field
1rajeev
2ramesh
3Rahul
4Bala
5Teamjhon
6Robin
7Sambha
8Arjun
9Satyan
10Singapore

var pager = new Pager('results' 3);

pager.init();

pager.showPageNav('pager' 'pageNavPosition');

pager.showPage(1);

//-->

标签:paging,richtextediting,javascript

来源: https://codeday.me/bug/20191210/2103252.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值