Anas Fares
Anas Fares

Reputation: 31

how to get selected text from iframe with javascript?

how to get selected text from iframe with javascript ?

Upvotes: 3

Views: 5040

Answers (2)

Tim Down
Tim Down

Reputation: 324567

function getIframeSelectionText(iframe) {
  var win = iframe.contentWindow;
  var doc = iframe.contentDocument || win.document;

  if (win.getSelection) {
    return win.getSelection().toString();
  } else if (doc.selection && doc.selection.createRange) {
    return doc.selection.createRange().text;
  }
}

var iframe = document.getElementById("your_iframe");
alert(getIframeSelectionText(iframe));

As noted by jAndy, this will only work if the iframe document is served from the same domain as the containing document.

Upvotes: 0

jAndy
jAndy

Reputation: 236012

var $ifx = $('<iframe src="filename.html" height=200 width=200></iframe>').appendTo(document.body);

$(document.body).bind('click', function(){
     var u_sel;
     if(window.getSelection){
        u_sel = ifx[0].contentWindow.getSelection();
      // u_sel.text()   InternetExplorer !!
      alert(u_sel);
     }
});

That should do it, as long as the iframe src is targeting your own domain. Tested only on FireFox 3.6.7 so far.

Upvotes: 2

Related Questions