2016-08-13 16 views
0

テキストを選択します。選択したテキストの冒頭に<div>が表示されます。テキストの選択位置に基づいてdivを配置する方法

これまでのところ、私が選択したテキストを追跡するためのコードを持っている:

$(document).ready(function() { 
 
    
 
    $("#actual_verse").mouseup(function() { 
 
    var text = ""; 
 
    if (window.getSelection) { 
 
     text = window.getSelection().toString(); 
 
    } else if (document.selection && document.selection.type != "Control") { 
 
     text = document.selection.createRange().text; 
 
    } 
 
    
 
    if (/\S/.test(text)) { 
 
     alert(text); 
 
    } 
 
    
 
    }); 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<span id='actual_verse'> A justo sit aut sit sed. Wisi a cras sed. Feugiat mus nulla sagittis proin, feugiat accumsan turpis neque, velit nec odio bibendum, cum dui mi turpis interdum, aptent risus vestibulum eu vitae sed. Nulla facilisis, id quis cubilia vel suscipit, fermentum ante aliquam nunc. Scelerisque lacinia, ut molestie dui libero arcu elit nec, faucibus tenetur maecenas sit ipsum rutrum. Non amet erat non sit quis, nonummy magna elit integer in sed in, suspendisse quis velit blandit, interdum quam dui mollis vestibulum elementum, urna donec eros eget. Mauris aliquam montes a, sem est sed, eveniet lacus nibh, donec ornare sit, aptent sit rutrum gravida. Wisi et amet lobortis. </span>

どのように私は今<div>は、選択したテキストの開始時に表示させるのですか?

+0

を選択したテキストをラップしますか、または追加したいん選択されたテキストの先頭にヒントボックスとしての 'div'ですか? – skobaljic

+0

'span 'の中に' div'をネストすることはできません、無効なhtmlです。 –

答えて

0

あなたが選択は、あなたがこのような何か行うことができます開始divの位置にしたい場合:

$(document).ready(function() { 
 
    $('.conttext').mouseup(function() { 
 
    var highlight = window.getSelection(); 
 
    var spn = '<span class="highlight">' + highlight + '<div class="mydiv"></div></span>'; 
 
    var text = $('.conttext').text(); 
 
    $('.conttext').html(text.replace(highlight, spn)); 
 
    }); 
 
});
.highlight { 
 
    position: relative; 
 
} 
 
.mydiv { 
 
    position: absolute; 
 
    top: 0; 
 
    left: 0; 
 
    height: 100px; 
 
    width: 100px; 
 
    background-color: gold; 
 
    z-index: -1; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div class="conttext">How hard can it be to achieve this here and now. Will it be difficult or can it be done with great simplicity</div>

+1

'mousedown'ではハイライトスパンを削除する必要があります。そうでなければバグがあります(すでに選択されているテキストを何回か選択してみてください)。 – skobaljic

+0

@skobaljicあなたが正しいです。これは単なる基本的なアイデアです –

+0

素晴らしい仕事、ハイライトされたテキストを維持する方法はありますか?このdivには、テキストをスタイルするための色があります。 –

関連する問題