本文目录一览:
- 1、JS实现内容复制功能
- 2、asp中复制一段文字到textarea,自动识别对应input的内容,分别填入其中,有谁可以用js做到啊!???
- 3、JS自动复制内容到剪贴板
- 4、如何利用JS实现复制/粘贴功能
- 5、js 复制文字功能
- 6、如何在页面加载后调用js的代码自动复制一段文字
JS实现内容复制功能
复制是一个使用频率特别高的操作,在网页中,一般可以选中要复制的内容,使用快捷键 ctrl+c 将内容复制到剪贴板。除了使用系统提供的快捷方式复制网页内容,我们还可以用JS实现复制,这得益于document的 execCommand('copy') 命令。
实现整个复制功能,需要以下三个步骤:
大部分HTML元素都有innerText和innerHTML两个属性,innerText属性返回文本内容,innerHTML属性返回标签元素。我们可以创建一个函数,用于获取需要返回的内容:
上面的selectText函数接收一个DOM元素,返回DOM元素的innerText属性值。
我们可以通过表单元素的select()方法选中内容,表单元素因为textarea限制少于input,所以推荐使用textarea。我们可以动态创建一个textarea元素,将textarea的value属性值设置为上面的innerText属性值,再执行textarea的select方法选中。
上面实现了选中,下面就可以实现复制功能了。
最后一步就可以用execCommand('copy')实现复制了,它可以复制浏览器中选中的文本,比如说上面被textarea选中的文本,复制之后记得移除textarea。
第二步和第三步可以优化一下,创建一个copy函数,函数参数设置为第一步需要复制的文本,返回值为复制的结果。
完整JS示例如下:
可以将上面的完整JS示例写入一个JS文件,将JS文件引入HTML中,通过JS点击事件来执行复制函数。
效果图:
asp中复制一段文字到textarea,自动识别对应input的内容,分别填入其中,有谁可以用js做到啊!???
先将textarea每行内容分离出来,然后根据冒号左边的内容遍历下面的表格找到对应名称的input输入冒号后面的内容.
JS自动复制内容到剪贴板
javascript代码
SCRIPT LANGUAGE="JavaScript"
function copyText(text)
{
window.clipboardData.setData("text",text);
}
/SCRIPT
HTML代码
body onload=copyText('123')
/body
如何利用JS实现复制/粘贴功能
1、最基本的复制
Java代码
script language="JavaScript"
function readTxt()
{
alert(window.clipboardData.getData("text"));
}
function setTxt()
{
var t=document.getElementById("txt");
t.select();
window.clipboardData.setData('text',t.createTextRange().text);
}
/script
input name="txt" value="测试"
input type="button" value="复制" onclick="setTxt()"
input type="button" value="读取" onclick="readTxt()"
2、扩展复制:复制表格
Java代码
INPUT TYPE="button" value="选中测试表格" onclick="CopyTable()"
测试
TABLE border="1" id="oTable"
TR
TD测试表格/TD
TD测试表格/TD
/TR
TR
TD测试表格/TD
TD测试表格/TD
/TR
/TABLE文字
SCRIPT LANGUAGE="JavaScript"
!--
function CopyTable()
{
var txt = document.body.createTextRange();
txt.moveToElementText(document.getElementById('oTable'));
txt.select();
}
//--
/SCRIPT
、兼容IE,firefox等浏览器的复制
Java代码
script
function copyToClipboard(txt) {
if(window.clipboardData) {
window.clipboardData.clearData();
window.clipboardData.setData("Text", txt);
} else if(navigator.userAgent.indexOf("Opera") != -1) {
window.location = txt;
} else if (window.netscape) {
try {
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
} catch (e) {
alert("被浏览器拒绝!\n请在浏览器地址栏输入'about:config'并回车\n然后将'signed.applets.codebase_principal_support'设置为'true'");
}
var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
if (!clip)
return;
var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
if (!trans)
return;
trans.addDataFlavor('text/unicode');
var str = new Object();
var len = new Object();
var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
var copytext = txt;
str.data = copytext;
trans.setTransferData("text/unicode",str,copytext.length*2);
var clipid = Components.interfaces.nsIClipboard;
if (!clip)
return false;
clip.setData(trans,null,clipid.kGlobalClipboard);
}
}
/script
button onclick="copyToClipboard('你好!');"复制文本“你好!”/button
textarea id="test"/textarea
js 复制文字功能
功能 :点击按钮,复制值。
实现方法 :通过原生js 的方法 document.execCommand('copy')
巨坑 :document.execCommand(‘copy’)不生效
原因 :
1.input框不能有disabled属性
2.根据第一条扩展,input的width || height 不能为0;
3.input框不能有hidden、display:none属性
解决方案 :在不改变原需求的情况下,新增一个input框,然后设置 opacity:0; 实现不可见, position:absolute; 脱离文档流解决占空间的问题
语法:
document.execCommand(aCommandName,aShowDefaultUI,aValueArgument),返回值Boolean 如果返回false 则表示还不能支持;
参数说明:
1.aCommandName
命令的名称:常用的为"copy","cut"等;
注:“copy” 拷贝当前选中内容到剪贴板
“cut” 剪贴当前选中的文字并复制到剪贴板
2.aShowDefaultUI
是否展示用户界面,一般为 false;
3.aValueArgument
默认为null,
示例
!-- html --
!-- 点击复制输入框value值 --
input type="text" id="copyVal" value="被复制的内容" /
!-- 点击复制div标签的innerHTML --
div id="copyInner"被复制的内容/div
button onclick="myCopy"点击复制/button
// 方法一:点击按钮复制文本框内容
function myCopy(){
var copyVal = document.getElementById('copyVal');
copyVal.select();
document.execCommand('copy');
}
// 方法二:点击按钮复制div标签内容
function myCopy(){
const range = document.createRange();
range.selectNode(document.getElementById('copyInner'));
const selection = window.getSelection();
if(selection.rangeCount 0) selection.removeAllRanges();
selection.addRange(range);
document.execCommand('copy');
}
如何在页面加载后调用js的代码自动复制一段文字
1、首先建立一个父级页面parent.html,代码如图,一个pop函数方法,一个链接到child.html的iframe标签。
2、再新建一个child.html页面,如图,展示一个id=link的div标签,和link的点击事件,因为是调用父级方法,所以需要用到window.parent.pop()方法。
3、预览页面,可明显看到parent.html里面的iframe框架,指向的就是child子页面。
4、点击页面中“调用父级pop方法”的文字链,会提示错误,这是因为没配置好域名等相关设置。
5、打开iis,右键iframe文件夹——“管理文件夹”——“浏览”;即可打开本地测试地址;(如小伙伴没配置iis,需要先配置iis建立站点)。
6、再次点击“调用父级pop方法”的文字链,即可成功弹出提示。