js 字符串根据开始结束索引范围值高亮显示

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript" src="../js/jquery-2.1.1.js"></script>
		<style>
			
		</style>
	</head>
	<body>
		<div>
			<button class="pre">上一个</button>
			<button class="next">下一个</button>
			<div id="pdfString">
					
			</div>
		</div>
		<script>
			
			//pdf 文章内容
			var textString = "cccasfadgADGSADVSGBHY76EGSFasdSDSDFDFFASFAfsdfadfaegsdzcccasfasfacvxcbvfhtyietjrtkyilnbzfgFwfrsbzdnfhgjfvbxcvger"
			//放进 div中
			$("#pdfString").html(textString);
			//后台传过来的数组
			var valueIndex = ["0-5", "9-12", "24-26"];
			
			var a = valueIndex[0].replace("-",",").split(",")[0];
			
			var b = valueIndex[0].replace("-",",").split(",")[1];
			
			const element = document.getElementById('pdfString');
			const textNode = element.childNodes[0];
			
			const range = document.createRange();
			
			range.setStart(textNode, a);  // Start at first character
			range.setEnd(textNode, b);    // End at fifth character
			const mark = document.createElement('mark');
			range.surroundContents(mark); 
			
			$(function(){ 
					var index1=0;
			//		下一个
					var valueIndexlenght = valueIndex.length;
					$(".next").click(function(){
						if(index1>=(valueIndexlenght-1)){
							alert("已经是最后一个了");
							return false;
						}
						index1++;
						
						$("#pdfString").html("");
						
						$("#pdfString").html(textString);
						
						var a = valueIndex[index1].replace("-",",").split(",")[0];
						
						var b = valueIndex[index1].replace("-",",").split(",")[1];
						
						const element = document.getElementById('pdfString');
						
						const textNode = element.childNodes[0];
						
						const range = document.createRange();
						
						range.setStart(textNode, a);  // Start at first character
						range.setEnd(textNode, b);    // End at fifth character
						
						const mark = document.createElement('mark');
						
						range.surroundContents(mark);
					});
			//		上一个
					$(".pre").click(function(){
						if(index1 <= 0){
							alert("已经是第一个了");
							return false;
						}
						index1--;
						
						$("#pdfString").html("");
						
						$("#pdfString").html(textString);
						
						var a = valueIndex[index1].replace("-",",").split(",")[0];
						
						var b = valueIndex[index1].replace("-",",").split(",")[1];
						
						const element = document.getElementById('pdfString');
						const textNode = element.childNodes[0];
						
						const range = document.createRange();
						
						range.setStart(textNode, a);  // Start at first character
						range.setEnd(textNode, b);    // End at fifth character
						
						const mark = document.createElement('mark');
						
						range.surroundContents(mark);
					});
				})
				
				
			
			
		</script>
	</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值