3

以下のように、選択された HTML ページ (gtkmozembed でレンダリング) のテキストを強調表示できます。

    var range, sel;
    if (window.getSelection) {
        sel = window.getSelection();
        if (sel.getRangeAt) {
          range = sel.getRangeAt(0);
        }
        document.designMode = "on";
        if (range) {
            sel.removeAllRanges();
            sel.addRange(range);
        }
        document.execCommand("HiliteColor", false, colour);
        document.designMode = "off";
   }  

さて、それは非常にうまく機能します.今、強調表示されたテキストに関する情報(startNode、startOffset、endNode、endOffset)を保存しようとしています.次に同じページを開いたときに、同じテキストを強調表示します. 情報を正常に保存し、同じページが開いたときにそれらを取得できます。そして、次のコードを使用してテキストを強調表示しようとしています。

    var range = document.createRange();
    range.setStart(startNode, startOffset);
    range.setEnd(endNode, endOffset);

    document.designMode = "on";
    range.execCommand("HiliteColor", false, colour);
    document.designMode = "off";

しかし、期待どおりに機能していません。必要なものを達成するのを手伝ってくれる人はいますか? ありがとう...

4

2 に答える 2

7

execCommandメソッドはドキュメントのメソッドであり、Range ではありません。また、 Firefox でのみ動作するため、WebKit と Opera でのhilitecolor使用にフォールバックする必要があります。backcolor

アップデート

IE 9 で修正されました。

function makeEditableAndHighlight(colour) {
    var sel = window.getSelection();
    var range = null;
    if (sel.rangeCount && sel.getRangeAt) {
        range = sel.getRangeAt(0);
    }
    document.designMode = "on";
    if (range) {
        sel.removeAllRanges();
        sel.addRange(range);
    }
    // Use HiliteColor since some browsers apply BackColor to the whole block
    if (!document.execCommand("HiliteColor", false, colour)) {
        document.execCommand("BackColor", false, colour);
    }
    document.designMode = "off";
}

function highlight(colour) {
    var range, sel;
    if (window.getSelection) {
        // IE9 and non-IE
        try {
            if (!document.execCommand("BackColor", false, colour)) {
                makeEditableAndHighlight(colour);
            }
        } catch (ex) {
            makeEditableAndHighlight(colour)
        }
    } else if (document.selection && document.selection.createRange) {
        // IE <= 8 case
        range = document.selection.createRange();
        range.execCommand("BackColor", false, colour);
    }
}
于 2010-05-03T09:27:03.227 に答える
1

このページでは、スクリプトによるハイライトに関するすべての詳細を説明します。私は自分でやったことがないので、ページの推奨事項を使用するのがおそらく最善です.

于 2010-05-03T08:42:31.040 に答える