Перетаскивать текст из iFrame из внешнего домена в элемент для удаления в родительском окне? - PullRequest
2 голосов
/ 02 мая 2011

Я создаю веб-приложение с требованием разрешить пользователям перетаскивать текст из iframe (src может быть из любого внешнего домена) в элемент drop-drop в моем родительском окне. Несмотря на то, что я легко могу получить указатель на окно iFrame, я получаю ожидаемые ошибки безопасности, когда пытаюсь выбрать данные из iFrame.

В настоящее время я играю с кодом, скопированным с поста Марка Колича на его веб-сайте. Я изменил его, чтобы искать выделенный текст в iFrame. Я попытался изменить фрагмент URL (то есть добавить «#crunch» в конец URL) на основе того, что я прочитал здесь: http://softwareas.com/cross-domain-communication-with-iframes

... но это, похоже, не имеет значения. Я пока не пытался заполучить выделенный текст.

Есть ли способ захвата текста, выделенного внутри iFrame (указывающего на внешний домен), чтобы его можно было перетащить в элемент в родительском окне?

Вот код:


if(!window.crunch){
  crunch = {};
}

crunch.Selector = {};
crunch.Selector.getSelected = function(){

    var s = $("#xFrameWindow").attr('src');
    $("#xFrameWindow").attr('src', s + "#crunch")

    var t = '';

    if (window.frames["xFrameWindow"].getSelection) {
        t = window.frames["xFrameWindow"].getSelection();
    } else if(window.frames["xFrameWindow"].document.getSelection) {
        t = window.frames["xFrameWindow"].document.getSelection();
    } else if(window.frames["xFrameWindow"].document.selection) {
        t = window.frames["xFrameWindow"].document.selection.createRange().text;
    }

    return t;
}

crunch.Selector.mouseup = function(){
  var st = crunch.Selector.getSelected();
  if(st!=''){
    alert("You selected:\n"+st);
  }
}

$(document).ready(function(){
  $(document).bind("mouseup", crunch.Selector.mouseup);
});

...