js 剪切板应用clipboardData详细解析

1.怎样操作剪贴板,从而实现复制、剪切与粘贴?同时判断剪贴板里边的数据是否是文本?
if(!IsClipboardFormatAvailable(CF_TEXT)) return;
if(!OpenClipboard(hwndMain)) return; hglb=GetClipboardData(CF_TEXT);
if(hglb!=NULL) { lptstr=GlobalLock(hglb); if(lptstr!=NULL) {
//Calltheapplication-definedReplaceSelection
//functiontoinsertthetextandrepaintthe //window.
ReplaceSelection(hwndSelected,pbox,lptstr); GlobalUnlock(hglb); } }
CloseClipboard(); 2.可以使用javascript获得windows剪贴板里的字符串吗?
比如在网页中实现点击一个文本框就把剪贴板里的字符粘贴进去 当然可以 form p
inputname=txtSearchvalue=””
inputtype=buttonvalue=Copy2Cliponclick=’javascript:vartextRange=txtSearch.createTextRange();textRange.execCommand(“Copy”)’
/p p inputname=”copyto”type=”text”
inputtype=buttonvalue=PastefromCliponclick=’javascript:vartextRange=copyto.createTextRange();textRange.execCommand(“Paste”)’
/p /form 3.javascript和剪贴板的交互
一般可以这样将id为‘objid’的对象的内容copy到剪贴板
varrng=document.body.createTextRange();
rng.moveToElementText(document.getElementById(“objid”));
rng.scrollIntoView(); rng.select(); rng.execCommand(“Copy”);
rng.collapse(false); setTimeout(“window.status=””,1800)
也可以用rng.execCommand(“Past”);将剪贴板的内容粘到光标当前位置。
内容参见msdn的textRange对象。
不过,copy到剪贴板的都是不带html标签的,所有html标签都将被过滤。
4.window.clipboardData.getData(“Text”)//可以获得剪贴版的文字
window.clipboardData.setData(“Text”,”你的内容”)//向剪贴板里写文本信息
5.怎么判断剪贴板中的数据是否为字符串而不是图片或别的信息?
PrivateSubCommand1_Click()
IfClipboard.GetFormat(vbCFText)OrClipboard.GetFormat(vbCFRTF)Then
MsgBox”ok” EndIf EndSub 6.请问如何判断剪贴板中不为空? 一、 Eg
判断windows剪贴板里是否为空,没有则读取图片到Image中 usesclipbrd;
ifClipBoard.HasFormat(CF_Picture)then Image1.Picture.Assign(ClipBoard);
二、 usesClipbrd; procedureTForm1.Button1Click(Sender:TObject); begin
ifClipboard.FormatCount=0then {TODO:空}; end;
7.怎样确定剪贴板中的数据是否为图象? GetFormat方法示例
本示例使用GetFormat方法确定Clipboard对象上数据的格式。要检验此示例,可将本例代码粘贴到一个窗体的声明部分,然后按F5键并单击该窗体。
PrivateSubForm_Click() ‘定义位图各种格式。 DimClpFmt,Msg’声明变量。
OnErrorResumeNext’设置错误处理。
IfClipboard.GetFormat(vbCFText)ThenClpFmt=ClpFmt+1
IfClipboard.GetFormat(vbCFBitmap)ThenClpFmt=ClpFmt+2
IfClipboard.GetFormat(vbCFDIB)ThenClpFmt=ClpFmt+4
IfClipboard.GetFormat(vbCFRTF)ThenClpFmt=ClpFmt+8 SelectCaseClpFmt Case1
Msg=”TheClipboardcontainsonlytext.” Case2,4,6
Msg=”TheClipboardcontainsonlyabitmap.” Case3,5,7
Msg=”TheClipboardcontainstextandabitmap.” Case8,9
Msg=”TheClipboardcontainsonlyrichtext.” CaseElse
Msg=”ThereisnothingontheClipboard.” EndSelect MsgBoxMsg’显示信息。
EndSub

注意:ie7,与ie8
对网页有个复制的权限,需在“安全”中的“自定义级别”的脚本中设置

clipboardData 对象

提供了对剪贴板的访问。

三个方法 1.clearData(sDataFormat) 删除剪贴板中指定格式的数据。
2.getData(sDataFormat) 从剪贴板获取指定格式的数据。
3.setData(sDataFormat, sData) 给剪贴板赋予指定格式的数据。返回 true
表示操作成功。

例子

<script language=”JavaScript”>
<!–
var text = “123”;
if (!window.clipboardData.setData(‘Text’, text)) // 赋予 text
格式的数据
{
     alert(“复制失败!”);
}
text = window.clipboardData.getData(‘Text’); // 获取 text 格式的数据
alert(text);
window.clipboardData.clearData(‘Text’); // 清除 text 格式的数据
text = window.clipboardData.getData(‘Text’);
alert(text);
//–>
</script>

一些方法:

<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN”
“;
<html xmlns=”;
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″
/>
<title>Js复制代码</title>
</head>
<body>
<p>
<input type=”button” name=”anniu1″ onClick=’copyToClipBoard()’
value=”复制专题地址和url地址,传给QQ/MSN上的好友”>
<script language=”javascript”>
   function copyToClipBoard(){
    var clipBoardContent=””;
    clipBoardContent+=document.title;
    clipBoardContent+=””;
    clipBoardContent+=this.location.href;
    window.clipboardData.setData(“Text”,clipBoardContent);
    alert(“复制成功,请粘贴到你的QQ/MSN上推荐给你的好友”);
}
</script>  
<br />
<br />

直接复制url <input type=”button” name=”anniu2″ onClick=’copyUrl()’
value=”复制URL地址”>
<script language=”javascript”>
   function copyUrl()
   {
    var clipBoardContent=this.location.href;
    window.clipboardData.setData(“Text”,clipBoardContent);
    alert(“复制成功!”);
   }
</script>
<br/>
<br/>
点击文本框时,复制文本框里面的内容
<input onclick=”oCopy(this)” value=”你好.要copy的内容!”>
<script language=”javascript”>
function oCopy(obj){
obj.select();
js=obj.createTextRange();
js.execCommand(“Copy”)
alert(“复制成功!”);
}
</script>
<br />
<br />
复制文本框或者隐藏域中的内容 <script language=”javascript”>
function CopyUrl(target){
target.value=myimg.value;
target.select();  
js=myimg.createTextRange();  
js.execCommand(“Copy”);
alert(“复制成功!”);
}
function AddImg(target){
target.value=”[IMG]”+myimg.value+”[/ img]”;
target.select();
js=target.createTextRange();  
js.execCommand(“Copy”);
alert(“复制成功!”);
}
</script>

<input name=myimg type=hidden id=myimg
value=”” />
<input name=imgurl type=text size=32 value=””
/>
<input type=button value=”点击这里复制本站地址”
onclick=”CopyUrl(imgurl);” />

<br />
<br/>
复制span标记中的内容 <script type=”text/javascript”>
</script>
<br />
<br />
<script type=”text/javascript”>function copyText(obj)  
{
var rng = document.body.createTextRange();
rng.moveToElementText(obj);
rng.scrollIntoView();
rng.select();
rng.execCommand(“Copy”);
rng.collapse(false);
alert(“复制成功!”);
}
</script>

以下是代码片段:<br />
<br />
<span id=”tbid”>www.463.com,;  
[<a href=”#”
onclick=”copyText(document.all.tbid)”>点击复制</a>]<br/><br/>
<span id=”tbid2″>;  
[<a href=”#”
onclick=”copyText(document.all.tbid2)”>点击复制</a>]<br/><br/>

</p>
</body>
</html>

还有一种方法:

function copyQQ(qq){
var obj=document.getElementById(qq);
obj.select();
     js=obj.createTextRange();
     js.execCommand(“Copy”);
     alert(“代码已经被成功复制!”);

}

//设置复制内容 附加 本网站的URL
        function SetCopyContent() {
            window.event.returnValue = false;
            var content = document.title + “/r/n”;
            content += document.getElementById(“txt1”).value + “/r/n”;
            content += “本资源来自 ” + this.location.href;
            window.clipboardData.setData(‘Text’, content);
            alert(“复制成功,请粘贴到你的QQ/MSN上推荐给你的好友”);
        }

调用:

<input id=”txt1″ type=”text” value=”Hello World!” 
onclick=”getTxtSelect(event)”/>
<input type=”button” value=”复制文本框中的值” 
onclick=”SetCopyContent();” />

复制代码 代码如下:

发表评论

电子邮件地址不会被公开。 必填项已用*标注