क्या jQuery का उपयोग करके किसी वेबसाइट के पैराग्राफ में हाइलाइट किए गए टेक्स्ट को प्राप्त करना संभव है?
क्या jQuery का उपयोग करके किसी वेबसाइट के पैराग्राफ में हाइलाइट किए गए टेक्स्ट को प्राप्त करना संभव है?
जवाबों:
उपयोगकर्ता द्वारा चयनित पाठ प्राप्त करना अपेक्षाकृत सरल है। JQuery को शामिल करने से कोई लाभ होने वाला नहीं है क्योंकि आपको वस्तुओं window
और document
वस्तुओं के अलावा कुछ भी नहीं चाहिए ।
function getSelectionText() {
var text = "";
if (window.getSelection) {
text = window.getSelection().toString();
} else if (document.selection && document.selection.type != "Control") {
text = document.selection.createRange().text;
}
return text;
}
यदि आप एक ऐसे कार्यान्वयन में रुचि रखते हैं जो चयन <textarea>
और पाठ <input>
तत्वों के साथ भी व्यवहार करेगा , तो आप निम्नलिखित का उपयोग कर सकते हैं। चूंकि अब यह 2016 है, मैं IE <= 8 समर्थन के लिए आवश्यक कोड को छोड़ रहा हूं, लेकिन मैंने एसओ पर कई स्थानों पर इसके लिए सामान पोस्ट किया है।
function getSelectionText() {
var text = "";
var activeEl = document.activeElement;
var activeElTagName = activeEl ? activeEl.tagName.toLowerCase() : null;
if (
(activeElTagName == "textarea") || (activeElTagName == "input" &&
/^(?:text|search|password|tel|url)$/i.test(activeEl.type)) &&
(typeof activeEl.selectionStart == "number")
) {
text = activeEl.value.slice(activeEl.selectionStart, activeEl.selectionEnd);
} else if (window.getSelection) {
text = window.getSelection().toString();
}
return text;
}
document.onmouseup = document.onkeyup = document.onselectionchange = function() {
document.getElementById("sel").value = getSelectionText();
};
Selection:
<br>
<textarea id="sel" rows="3" cols="50"></textarea>
<p>Please select some text.</p>
<input value="Some text in a text input">
<br>
<input type="search" value="Some text in a search input">
<br>
<input type="tel" value="4872349749823">
<br>
<textarea>Some text in a textarea</textarea>
window.getSelection()
) के लिए है। document.selection.type
जांच परीक्षण कर रहा है कि चयन एक नियंत्रण चयन एक पाठ चयन के बजाय है। IE में, एक नियंत्रण चयन एक संपादन तत्व के अंदर एक चयन होता है जिसमें एक या एक से अधिक तत्व (जैसे कि चित्र और प्रपत्र नियंत्रण) होते हैं और हैंडल का आकार बदल जाता है। यदि आप .createRange()
इस तरह के चयन पर कॉल करते हैं, तो आपको एक के ControlRange
बजाय एक मिलता है TextRange
, और ControlRange
एस के पास कोई text
संपत्ति नहीं है।
selectionStart
या selectionEnd
किसी <input>
तत्व प्रकार (जैसे "संख्या") में प्रवेश करने की कोशिश करते हैं तो क्रोम में कंसोल में आपको चेतावनी मिलती है। इसका समर्थन करें ( उदाहरण के लिए jsfiddle.net/6zoposby/2 देखें )। मैंने चेक को अस्तित्व के लिए छोड़ दिया selectionStart
ताकि कोड IE में टूट न जाए <= 8. मैं मानता हूं कि चेक activeElement
शायद अब ओवरकिल हो गया है। मैं उपयोग करता हूं slice
क्योंकि यह अधिक शक्तिशाली है (हालांकि यहां उपयोगी नहीं है) और टाइप करने के लिए थोड़ा छोटा है substring
।
इस तरह हाइलाइट किया हुआ टेक्स्ट प्राप्त करें:
window.getSelection().toString()
और निश्चित रूप से के लिए एक विशेष उपचार:
document.selection.createRange().htmlText
document.selection
समर्थन IE10 में हटा दिया गया था और window.getSelection
" के साथ बदल दिया । स्रोत: connect.microsoft.com/IE/feedback/details/795325/…
यदि आप क्रोम का उपयोग कर रहे हैं तो यह समाधान काम नहीं करता (अन्य ब्राउज़रों को सत्यापित नहीं कर सकता) और यदि पाठ उसी DOM तत्व में स्थित है:
window.getSelection().anchorNode.textContent.substring(
window.getSelection().extentOffset,
window.getSelection().anchorOffset)
का उपयोग करें window.getSelection().toString()
।
आप डेवलपर.mozilla.org पर अधिक पढ़ सकते हैं