選択したすべてのテキストを選択解除するためのJavaScriptの関数はありますか?私はそれがdocument.body.deselectAll();
何かのような単純なグローバル関数である必要があると思います。
選択したすべてのテキストを選択解除するためのJavaScriptの関数はありますか?私はそれがdocument.body.deselectAll();
何かのような単純なグローバル関数である必要があると思います。
回答:
これを試して:
function clearSelection()
{
if (window.getSelection) {window.getSelection().removeAllRanges();}
else if (document.selection) {document.selection.empty();}
}
これにより、主要なブラウザの通常のHTMLコンテンツの選択がクリアされます。テキスト入力や<textarea>
Firefoxでの選択はクリアされません。
removeAllRanges()
メソッドは、現在のすべてのブラウザで、段落内のテキストまたは同様の非フォームフィールド要素に対して機能します。(textareaのような)フォームフィールドの場合、このメソッドはIE9およびFF5では機能しません。
window.getSelection().removeAllRanges();
最初に使用します。独自仕様のコードは常に最後に実行する必要があります。2004年であろうと4004標準準拠であろうと常に最終的には私たちが使用するコードなので、例外なく最初にそれを検出します!
これは、テキスト入力やテキストエリア内を含め、選択をクリアするバージョンです:
デモ:http : //jsfiddle.net/SLQpM/23/
function clearSelection() {
var sel;
if ( (sel = document.selection) && sel.empty ) {
sel.empty();
} else {
if (window.getSelection) {
window.getSelection().removeAllRanges();
}
var activeEl = document.activeElement;
if (activeEl) {
var tagName = activeEl.nodeName.toLowerCase();
if ( tagName == "textarea" ||
(tagName == "input" && activeEl.type == "text") ) {
// Collapse the selection to the end
activeEl.selectionStart = activeEl.selectionEnd;
}
}
}
}
<div>
、mouseup
イベントは発生しません。代わりにドキュメントにマウスアップハンドラーを配置すると、問題ありません。jsfiddle.net
Internet Explorerの場合、document.selectionオブジェクトのemptyメソッドを使用できます。
document.selection.empty();
クロスブラウザソリューションについては、この回答を参照してください。
document.selection.clear()
作品だけ IEで。ここを参照してください:jsfiddle.net/9spL8/4また、このメソッドは、選択を解除するだけでなく、選択したテキストを削除します。テキストの選択を解除するには、document.selection.empty()
代わりにを使用します。
これは私にとって信じられないほど簡単に機能しました...
document.getSelection().collapseToEnd()
または
document.getSelection().removeAllRanges()
クレジット:https : //riptutorial.com/javascript/example/9410/deselect-everything-that-is-selected
window.getSelection().removeAllRanges();
現在のすべてのブラウザで動作することを確認できます。ライブデモ: jsfiddle.net/hWMJT/1