Copia o texto selecionado com links acrescentados em texto simples?

4

Existe uma maneira de um link ser copiado com o texto selecionado?

"Algum texto selecionado com este link em algum lugar no parágrafo"

Para ser copiado como:

"Algum texto selecionado com este {link | link } em algum lugar no parágrafo"

Se houver algo assim, seria de grande ajuda.

    
por Matthew Sprankle 06.11.2012 / 15:54

1 resposta

2

Uma solução pode ser transformar todos os links da página no formato desejado. Isso pode ser feito usando o Greasemonkey no Firefox e um UserScript personalizado. Como alternativa, o Tampermonkey for Chrome pode funcionar também, mas eu não o uso, portanto não posso verificar isso. A desvantagem dessa solução é que você deseja ativá-la apenas quando necessário, pois deixá-la ativada para navegação normal na Web distorceria o layout dos elementos da página, como cabeçalhos, rodapés e barras laterais.

Download do Greasemonkey para o Firefox OU Baixar o Tampermonkey para o Chrome

O seguinte UserScript pode ser salvo em um arquivo * .user.js (por exemplo: tmpscript.user.js) e, em seguida, o arquivo pode ser arrastado para o Firefox depois que o Greasemonkey for instalado para instalar o UserScript.

// ==UserScript==
// @name        Transform All Links
// @namespace   myscripts
// @description Transforms <a=href>link</a> to { link | <a=href>href</a> }
// @include     http*
// @version     1
// @grant       none
// ==/UserScript==
try{
    transformAnchors();
}catch(err){
    alert("error#" + err.number + " name: " + err.name + "\n"
        + "message: " + err.message + "\n"
        + "description: " + err.description);
    var errmsg = "";
    for (atr in err) {
        errmsg = errmsg + atr + " = " + err[atr] + "<br>\n";
    }
    alert(errmsg);
}

function transformAnchors() {
    //get every anchor node
    var anchornodes = document.getElementsByTagName("A");
    //transform every anchor
    for (var i=0; i<anchornodes.length; ++i){
        //grab the current anchor node
        anchornode = anchornodes[i];
        //ignore erroneous nodes with no parent
        if (anchornode.parentNode == undefined || anchornode.parentNode == null) continue;
        //add text sibling before anchor node : { <a=href>link</a>
        anchornode.parentNode.insertBefore(document.createTextNode("{ "),anchornode);
        //create styled anchor node to preserve styling
        styledanchornode = document.createElement("A");
        styledanchornode.setAttribute("class",anchornode.getAttribute("class"));
        styledanchornode.setAttribute("style",anchornode.getAttribute("style"));
        styledanchornode.setAttribute("title",anchornode.getAttribute("title"));
        //put styled anchor node before anchor node
        anchornode.parentNode.insertBefore(styledanchornode,anchornode);
        //move all anchor node children to before anchor node inside styled anchor node : { link <a=href></a>
        while (anchornode.hasChildNodes()){
            styledanchornode.appendChild(anchornode.childNodes[0]);
        }
        //remove styling from anchor node
        anchornode.removeAttribute("style");
        anchornode.removeAttribute("class");
        anchornode.removeAttribute("title");
        //add text sibling before anchor node : { link | <a=href></a>
        anchornode.parentNode.insertBefore(document.createTextNode(" | "),anchornode);
        //add href text child inside anchor node : { link | <a=href>href</a>
        anchornode.appendChild(document.createTextNode(anchornode.href));
        //add text sibling after anchor node : { link | <a=href>href</a> }
        anchornode.parentNode.insertBefore(document.createTextNode(" }"),anchornode.nextSibling);
        //increment index to compensate for extra styled anchor node
        ++i
    }
}
    
por 25.11.2012 / 12:41