我试图让用户复制文本并重写他们粘贴的内容。
例子....
<p>This is some awesome text that i wrote</p>
说用户复制了“很棒的文字”
我想使用“很棒的文字”一词并添加“-来自 mywebsite.com”
所以现在当用户粘贴从我的网站复制的这个文本时,它会说,“真棒文本 - 来自我的 mywebsite.com”
我已经用谷歌搜索了这是我到目前为止得到的http://jsfiddle.net/YD88T/
我试图让用户复制文本并重写他们粘贴的内容。
例子....
<p>This is some awesome text that i wrote</p>
说用户复制了“很棒的文字”
我想使用“很棒的文字”一词并添加“-来自 mywebsite.com”
所以现在当用户粘贴从我的网站复制的这个文本时,它会说,“真棒文本 - 来自我的 mywebsite.com”
我已经用谷歌搜索了这是我到目前为止得到的http://jsfiddle.net/YD88T/
也许这段代码可以解决问题。它会在用户实际复制之前将您的文本附加到用户选择中。
jQuery.fn.addtocopy = function(usercopytxt) {
var options = {htmlcopytxt: '<br>More: <a href="'+window.location.href+'">'+window.location.href+'</a><br>', minlen: 25, addcopyfirst: false}
$.extend(options, usercopytxt);
var copy_sp = document.createElement('span');
copy_sp.id = 'ctrlcopy';
copy_sp.innerHTML = options.htmlcopytxt;
return this.each(function(){
$(this).mousedown(function(){$('#ctrlcopy').remove();});
$(this).mouseup(function(){
if(window.getSelection){ //good times
var slcted=window.getSelection();
var seltxt=slcted.toString();
if(!seltxt||seltxt.length<options.minlen) return;
var nslct = slcted.getRangeAt(0);
seltxt = nslct.cloneRange();
seltxt.collapse(options.addcopyfirst);
seltxt.insertNode(copy_sp);
if (!options.addcopyfirst) nslct.setEndAfter(copy_sp);
slcted.removeAllRanges();
slcted.addRange(nslct);
} else if(document.selection){ //bad times
var slcted = document.selection;
var nslct=slcted.createRange();
var seltxt=nslct.text;
if (!seltxt||seltxt.length<options.minlen) return;
seltxt=nslct.duplicate();
seltxt.collapse(options.addcopyfirst);
seltxt.pasteHTML(copy_sp.outerHTML);
if (!options.addcopyfirst) {nslct.setEndPoint("EndToEnd",seltxt); nslct.select();}
}
});
});
}
我从这里拿走了它:http: //naviny.by/js/main.min.js
演示(选择至少 25 个字符)
如果您是拥有
<p>This is some awesome text that i wrote</p>
您可以制作一个捕获右键单击事件的脚本,用您制作的菜单替换普通菜单,还可以捕获 ctrl+c 组合并从那里做任何您想做的事情。
如果你不是……你不能。