经亲自实践,目前可行的方法主要有如下两种:
可以在任何运行使用js
代码的网站中使用,比如本人在自己的博客园博客中实现了一下,可亲自测试。
方法1:
代码语言:javascript复制<script language="javascript" type="text/javascript">
jQuery(document).on('copy', function(e)
{
var selected = window.getSelection();
var selectedText = selected.toString().replace(/n/g, '<br>'); // Solve the line breaks conversion issue
var copyFooter = '<br>---------------------<br>著作权归作者所有。<br>'
'商业转载请联系作者获得授权,非商业转载请注明出处。<br>'
'作者:Bravo Yeung<br> 源地址:' document.location.href
'<br>来源:博客园cnblogs<br>© 版权声明:本文为博主原创文章,转载请附上博文链接!';
var copyHolder = $('<div>', {id: 'temp', html: selectedText copyFooter, style: {position: 'absolute', left: '-99999px'}});
$('body').append(copyHolder);
selected.selectAllChildren( copyHolder[0] );
window.setTimeout(function() {
copyHolder.remove();
},0);
});
</script>
方法2:
代码语言:javascript复制<script type="text/javascript">
var ua = navigator.userAgent.toLowerCase();
if (window.ActiveXObject) { /* 兼容IE */
document.body.oncopy = function () {
event.returnValue = false;
var selectedText = document.selection.createRange().text;
var pageInfo = '<br>---------------------<br>著作权归作者所有。<br>'
'商业转载请联系作者获得授权,非商业转载请注明出处。<br>'
'作者:Bravo Yeung<br> 源地址:' document.location.href
'<br>来源:博客园cnblogs<br>© 版权声明:本文为博主原创文章,转载请附上博文链接!';
clipboardData.setData('Text', selectedText.replace(/n/g, '<br>') pageInfo);
}
}
else {
function addCopyRight() {
var body_element = document.getElementsByTagName('body')[0];
var selection = window.getSelection();
var pageInfo = '<br>---------------------<br>著作权归作者所有。<br>'
'商业转载请联系作者获得授权,非商业转载请注明出处。<br>'
'作者:Bravo Yeung<br> 源地址:' document.location.href
'<br>来源:博客园cnblogs<br>© 版权声明:本文为博主原创文章,转载请附上博文链接!';
var copyText = selection.toString().replace(/n/g, '<br>') pageInfo; // Solve the line breaks conversion issue
var newDiv = document.createElement('div');
newDiv.style.position = 'absolute';
newDiv.style.left = '-99999px';
body_element.appendChild(newDiv);
newDiv.innerHTML = copyText;
selection.selectAllChildren(newDiv);
window.setTimeout(function () {
body_element.removeChild(newDiv);
}, 0);
}
document.oncopy = addCopyRight;
}
</script>
方法1最初发表在本人的博客园文章中: https://www.cnblogs.com/enjoy233/p/10328361.html