JavaScrippt Как извлечь ссылку из выделенного текста
Я ищу решение, как извлечь URL из выделенного текста, используя window.getSelection
а также document.selection
,
Текст для выбора смотрите, что:
<p>Lorem Ipsum is <a href="http://example.com">simply <b>dummy</b> text</a> of the printing and typesetting industry.</p>
Выбранный текст (выбранный пользователем) для извлечения ссылки:
Вариант 1 (включить текст и текст между тегами):
Ipsum is simply dummy text of
Вариант 2 (выбрать текст и фрагмент ссылки):
Ipsum is simply
Функция должна быть возвращена http://example.com
2 ответа
Трудно написать для кросс-браузерной функции. См. Как связать обработчик с изменением выбора в окне?,
Мы должны захватить некоторые события, такие как mousedown
, mouseup
, touchstart
, touchend
, Сочетание этих событий может быть в порядке.
function addEvent(elem, event, func) {
if (elem.addEventListener) {
elem.addEventListener(event, func, false);
} else {
elem.attachEvent('on' + event, func);
}
}
Далее идет getSelectedHTML()
с помощью window.getSelection
или же document.selection
,
function getSelectedHTML(event) {
// http://www.w3.org/TR/2000/REC-DOM-Level-2-Traversal-Range-20001113/ranges.html
var range = window.getSelection ? window.getSelection() /* W3C */
: document.getSelection ? document.getSelection() /* redundant? */
: document.selection ? document.selection.createRange() /* IE */
: null;
if (range) {
if (range.getRangeAt) {
range = range.getRangeAt(0);
} else if (range.setStart) { // Safari 1.3
// Create range by itself
range.setStart(range.anchorNode, range.anchorOffset);
range.setEnd(range.focusNode, range.focusOffset);
} else {
// IE is already reange
}
var html = null, link = null;
if (range.cloneContents) {
var dummy = document.createElement('div');
dummy.appendChild(range.cloneContents());
html = dummy.innerHTML;
} else {
html = range.htmlText; /* IE */
}
if (html) {
link = html.match(/<a.*?href\s*?=['"](.*?)['"]/);
return link ? link[1] : null;
}
}
return null;
}
Этот код следует проверять, особенно в старых браузерах.
Вот образец скрипки: http://jsfiddle.net/tokkonoPapa/CQ63a/
Извините, если я неправильно понял вопрос, но вот мое предложение.
Имейте функцию и передайте ей выбранный HTML, и он будет обрабатывать это следующим образом.
function FindLink(str){
// str='<p>Lorem Ipsum is <a href="http://example.com">simply <b>dummy</b> text</a> of the printing and typesetting industry.</p>';
// we get the index of the beginning of the <a> tag
var n = str.indexOf("<a") ;
// we find the href property of the <a> element, starting from the <a we found
var n2 = str.indexOf("href=\"", n) + 6;
// we find the end of the href property
n3 = str.indexOf("\">",n2);
// we find the substring starting at the beginning of the link and going for however many characters the link is
link = str.substr(n2,n3-n2);
return link;
}
Я надеюсь, что это помогло!