Grande funzionalità.
ho adattato per permettere la piena selezione di testo attraverso qualsiasi numero di div modificabili tramite una classe, se cliccato direttamente, o schede a:
$.fn.selectText = function(){
var doc = document;
var element = this[0];
//console.log(this, element);
if (doc.body.createTextRange) {
var range = document.body.createTextRange();
range.moveToElementText(element);
range.select();
} else if (window.getSelection) {
var selection = window.getSelection();
var range = document.createRange();
range.selectNodeContents(element);
selection.removeAllRanges();
selection.addRange(range);
}
};
$(".editable").on("focus", function() {
$(this).selectText();
});
$(".editable").on("click", function() {
$(this).selectText();
});
$('.editable').mouseup(function(e){
e.stopPropagation();
e.preventDefault();
// maximize browser compatability
e.returnValue = false;
e.cancelBubble = true;
return false;
});
HTML:
<div class="editable" style="border:dotted 1px #ccc;" contenteditable="true">01 text...</div>
<div class="editable" style="border:dotted 1px #ccc;" contenteditable="true">02 text...</div>
<div class="editable" style="border:dotted 1px #ccc;" contenteditable="true">03 text...</div>
FIDDLE :
http://jsfiddle.net/tw9jwjbv/
fonte
2015-06-04 23:56:07
Qual è il compatibilità del browser su questo? – crush
Fiddle funziona in FF 28, ma non funziona con elementi di input 'contenteditable' con il tema del sistema operativo (aspetto' di CSS '). Si potrebbe voler aggiungere 'element.focus();' selectText() 'function, o selezionerà il testo senza che il cursore si trovi in quel campo. – CoDEmanX
Solo un suggerimento, rimuovi la riga" console.log (this, element); ", poiché non è richiesto che funzioni. –