• js实现鼠标选中文本改变选中区域颜色以及给选中区域加上html标签


    这个demo是看了dialog flow 的intent模块下面的Training phrases 得到的心得,实现的一个简单的选中区域实现的效果,不过这里就没写选中之后会弹出数据了。直接上demo:

    第一个:

    <!DOCTYPE html>
    <html>
    <head>
        <title>Field selection demo</title>
        <script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
    	<style>
    		#trainPhase {
    			border: 1px solid #ddd;
    			padding: 10px;
    		}
    	</style>
    </head>
    <body>
    	<div contentEditable="true" id="trainPhase">
    		div test body. Please input content.
    	</div>
    	<!-- <button id="replace">replace selection</button> -->
    	<script>
    		(function() {
    			$('#trainPhase').on('mouseup', function(event) {
    				var selection_text = window.getSelection().toString();
    				if(selection_text) {
    					var childNodes = $(event.currentTarget)[0].childNodes;
    					var range = window.getSelection().getRangeAt(0);
    					var startOffset = range.startOffset;
    					var endOffset = range.endOffset;
    					if (childNodes.length == 1){
    						var nodeText = childNodes[0].textContent.trim();
    						var prefix = nodeText.substring(0, startOffset);
    						var middle = '<span style="color:red;">' + nodeText.substring(startOffset, endOffset) + "</span>";
    						var suffix = nodeText.substring(endOffset, nodeText.length);
    						$(event.currentTarget)[0].innerHTML = prefix + middle + suffix;
    					}
    					
    					if (childNodes.length > 1){
    						if(range.startContainer == range.endContainer){
    							for(var idx in childNodes){
    								if (childNodes[idx] == range.startContainer ||
    								childNodes[idx] == range.startContainer.parentNode){
    									var nodeText = childNodes[idx].textContent;
    									var prefix = nodeText.substring(0, startOffset);
    									var middle = '<span style="color:red;">' + nodeText.substring(startOffset, endOffset) + "</span>";
    									var suffix = nodeText.substring(endOffset, nodeText.length);
    									$(childNodes[idx]).replaceWith( prefix + middle + suffix);
    								}
    							}
    						}else{ 
                                                            //多个span合并
    							var isStart = false;
    							var repalce_span = ""
    							for(var idx in childNodes){
    								if (childNodes[idx] == range.startContainer || childNodes[idx] == range.startContainer.parentNode){
    									isStart = true;
    									var nodeText = childNodes[idx].textContent;
    									var prefix = nodeText.substring(0, startOffset);
    									var suffix = '<span style="color:red;">' + nodeText.substring(startOffset, nodeText.length);
    									repalce_span =  prefix + suffix;
    									childNodes[idx].replaceWith("")
    								}else if(childNodes[idx] == range.endContainer ||
    									childNodes[idx] == range.endContainer.parentNode){
    									isStart = false;
    									var nodeText = childNodes[idx].textContent;
    									var prefix = nodeText.substring(0, endOffset) + "</span>";
    									var suffix = nodeText.substring(endOffset, nodeText.length);
    									repalce_span += prefix + suffix
    									$(childNodes[idx]).replaceWith(repalce_span);
    									break;
    								}else{
    									if(isStart){
    										repalce_span += childNodes[idx].textContent
    										childNodes[idx].replaceWith("")
    									}
    								}
    							}
    							
    						}
    					}
    				}
    			});
    		}());
    	</script>
    </body>
    </html>
    

      第二个:

    <!DOCTYPE html>
    <html>
    <head>
        <title>Field selection demo</title>
        <script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
    	<style>
    		#trainPhase {
    			border: 1px solid #ddd;
    			padding: 10px;
    		}
    	</style>
    </head>
    <body>
    	<div contentEditable="true" id="trainPhase">
    		div test body. Please input content.
    	</div>
    	<!-- <button id="get">get selection</button> -->
    	<button id="replace">replace selection</button>
    	<script>
             (function() { var $elem; $('#trainPhase').focus(function(){ $elem = $(this); }); // $('#get').on('click', function() { // alert($elem.fieldSelection().text); // window.console && console.log($elem.fieldSelection()); // }); $('#replace').on('click', function() { var selection_text = window.getSelection().toString(); var childNodes = document.getElementById("trainPhase").childNodes; var range = window.getSelection().getRangeAt(0); var startOffset = range.startOffset; var endOffset = range.endOffset; if (childNodes.length == 1){ var nodeText = childNodes[0].textContent.trim(); var prefix = nodeText.substring(0, startOffset); var middle = '<span style="color:red;">' + nodeText.substring(startOffset, endOffset) + "</span>"; var suffix = nodeText.substring(endOffset, nodeText.length); document.getElementById("trainPhase").innerHTML = prefix + middle + suffix; } if (childNodes.length > 1){ if(range.startContainer == range.endContainer){ for(var idx in childNodes){ if (childNodes[idx] == range.startContainer || childNodes[idx] == range.startContainer.parentNode){ var nodeText = childNodes[idx].textContent; var prefix = nodeText.substring(0, startOffset); var middle = '<span style="color:red;">' + nodeText.substring(startOffset, endOffset) + "</span>"; var suffix = nodeText.substring(endOffset, nodeText.length); $(childNodes[idx]).replaceWith( prefix + middle + suffix); } } }else{                            //多个span合并 var isStart = false; var repalce_span = "" for(var idx in childNodes){ if (childNodes[idx] == range.startContainer || childNodes[idx] == range.startContainer.parentNode){ isStart = true; var nodeText = childNodes[idx].textContent; var prefix = nodeText.substring(0, startOffset); var suffix = '<span style="color:red;">' + nodeText.substring(startOffset, nodeText.length); repalce_span = prefix + suffix; childNodes[idx].replaceWith("") }else if(childNodes[idx] == range.endContainer || childNodes[idx] == range.endContainer.parentNode){ isStart = false; var nodeText = childNodes[idx].textContent; var prefix = nodeText.substring(0, endOffset) + "</span>"; var suffix = nodeText.substring(endOffset, nodeText.length); repalce_span += prefix + suffix $(childNodes[idx]).replaceWith(repalce_span); break; }else{ if(isStart){ repalce_span += childNodes[idx].textContent childNodes[idx].replaceWith("") } } } } } }); }()); </script> </body> </html>

  • 相关阅读:
    NX二次开发-创建直线(起点-向量方向-长度)UF_CURVE_create_line
    NX二次开发-创建圆弧(圆心-半径)UF_CURVE_create_arc
    NX二次开发-UFUN获取直线的两个端点UF_CURVE_ask_line_data
    NX-二次开发创建圆弧(三点圆弧)UF_CURVE_create_arc_3point
    NX二次开发-创建直线UF_CURVE_create_line与NXOpen->CreateLine
    NX二次开发-创建圆弧(起点-终点-半径)UF_CURVE_create_arc_point_point_radius
    NX二次开发-UFUN打开信息窗口UF_UI_open_listing_window()
    NX二次开发-UFUN信息窗口打印UF_UI_write_listing_window
    NX二次开发-UFUN单按钮模态对话框窗口打印uc1601用法
    NX二次开发-UFUN打开二进制STL文件函数UF_STD_open_binary_stl_file
  • 原文地址:https://www.cnblogs.com/bertha-zm/p/9208257.html
Copyright © 2020-2023  润新知