JavaScript如何实现鼠标选中文本改变选中区域颜色
沉沙 2018-09-05 来源 : 阅读 5163 评论 0

摘要:本篇教程介绍了JavaScript如何实现鼠标选中文本改变选中区域颜色,希望阅读本篇文章以后大家有所收获,帮助大家对JavaScript的理解更加深入。

本篇教程介绍了JavaScript如何实现鼠标选中文本改变选中区域颜色,希望阅读本篇文章以后大家有所收获,帮助大家对JavaScript的理解更加深入。

<

直接上demo:

<!DOCTYPE html>
<html>
<head>
    <title>Field selection demo</title>
    <script type="text/javascript" src="//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{
      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>


   

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标WEB前端JavaScript频道!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 3 不喜欢 | 4
看完这篇文章有何感觉?已经有7人表态,43%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程