<table width="99%" border="0" cellpadding="0" cellspacing="0" class="firtable">
<tr>
<th width="100%" style="color: white"><s:text name="询单明细"></s:text></th>
</tr>
<tr>
<td align="center">
<textarea name="inquiryContact1" id="inquiryContact1" rows="15" cols="60" readonly="readonly"></textarea>
<div id="inquiryInfoDIV" style="display:none">
<s:property value="inquiryContact" escape="false"/>
</div>
<script>dojo.byId("inquiryContact1").innerText=dojo.byId("inquiryInfoDIV").innerText
</script>
</td></tr>
<tr>
<td align="center">
<input type="button" id="button" name="button" value="复制" onclick="copyContact()"/>
</td></tr></table>
<script type="text/javascript">
var i = 0
function copyContact(){
var contat = document.getElementById("inquiryContact1").value
window.clipboardData.setData('text', contat)
if(window.clipboardData.getData('text')==''){
if(i==1){
alert("复制失败,请手动Ctrl+C快捷键复制!")
}else{
alert("复制失败,请重新复制!")
i = 1
}
}else{
alert("内容已经复制到剪贴板!")
}
}
</script>
功能 :点击按钮,复制值。
实现方法 :通过原生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')
}