1

選択したテキストと単語のxy座標を同時に取得する方法は??

4

4 に答える 4

1

@MatuDuke の回答を拡張するには、次のように選択したテキストの位置を取得できます。

var txt = window.getSelection(),
    range = txt.getRangeAt(0),
    boundary = range.getBoundingClientRect();

// Available positions:
// boundary.top
// boundary.bottom
// boundary.left
// boundary.right

これらは、ビューポートに相対的なピクセル値を提供します。ただし、テキスト領域内では機能しないようです。これは、現在解決しようとしている問題です。

于 2014-12-02T10:54:01.343 に答える
1

グーグルで検索しただけです:

var txt = "";

if (window.getSelection) {
    txt = window.getSelection();
} else if (document.getSelection) {
    // FireFox 
    txt = document.getSelection();
} else if (document.selection) {
    // IE 6/7 
    txt = document.selection.createRange().text;
}

txt = txt.toString()

選択したテキストの X/Y 座標を取得する簡単な方法はありません。コンテナの位置とサイズ、テキスト フォント、テキスト レイアウト、その他多くの変数に依存するためです。

于 2010-11-05T13:24:54.303 に答える
0

あなたはこのようなことを試すことができます

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
   "http://www.w3.org/TR/html4/loose.dtd">

<html lang="en">
<head>
    <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></script>
    <script type="text/javascript" src="jquery.textselect.js"></script>
    <script type="text/javascript">
        $(function(){
            $('#select').bind('textselect click', function(e){
                console.log(e.text);
                console.log(e.pageX);

                var selected_text = e.text
                var original_text = $(this).text();
                var parts = original_text.replace(e.text, "/").split("/");

                for(i in parts) {
                    console.log(parts[i])
                }
            })
        });
    </script>
    <!-- Date: 2010-11-05 -->
</head>
<body>
    <div id="select">
        This is a simple select test
    </div>
</body>
</html>
于 2010-11-05T15:11:09.793 に答える
0

プロジェクトにこの jQuery プラグインhttp://plugins.jquery.com/node/7411を使用していますが、問題なく動作しているようです。jQuery を使用してマウスの位置を取得できますhttp://docs.jquery.com/Tutorials:Mouse_Position

ここに私が取り組んだいくつかのサンプルコードがあります

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
   "http://www.w3.org/TR/html4/loose.dtd">

<html lang="en">
<head>
    <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></script>
    <script type="text/javascript" src="jquery.textselect.js"></script>
    <script type="text/javascript">
        $(function(){
            $('#select').bind('textselect click', function(e){
                console.log(e.text);
                console.log(e.pageX);
            })
        });
    </script>
    <!-- Date: 2010-11-05 -->
</head>
<body>
    <div id="select">
        This is a simple select test
    </div>
</body>
</html>
于 2010-11-05T13:44:19.457 に答える