我正在尝试处理粘贴事件并尝试将富文本转换为纯文本,我在ID为main
$("#main").on("paste","div",function(event){
event.preventDefault();
var clipboarddata = event.clipboardData ||window.clipboardData || event.originalEvent.clipboardData;
var onlytext = clipboarddata.getData('text/plain');
document.execCommand("insertHTML", false, onlytext);
});
未捕获的TypeError:无法读取未定义的属性“getData”
我认为event.clipboarddata
不起作用,我的浏览器支持剪贴板API。我正在复制文本并将其粘贴到div中。所以剪贴板应该有一些价值
有人可以解释为什么我clipboardData
未定义
答案 0 :(得分:2)
对于最新的浏览器,Chrome以下线路可以使用。
var clipboarddata = window.event.clipboardData.getData('text');
$(document).ready(function(){
$("#main").on("paste",function(event){
event.preventDefault();
var clipboarddata = window.event.clipboardData.getData('text');
console.log("paste value" + clipboarddata);
$('#pasteData').text(clipboarddata);
});
});

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text" id="main" name="first_name" value="" maxlength="100" />
<div>paste value : <span id="pasteData"><span></div>
&#13;
答案 1 :(得分:0)
注意:这是为什么您收到错误。修复错误是另一回事,需要更多信息。
您收到错误的原因是因为当您对变量赋值使用OR运算符时,它将始终指定最后一个的值,即使它是null
,false
或{ {1}}。
基本上,就像这样
undefined
因此,由于这三个都是if (event.clipboardData != null/false/undefined) { //ignore the incorrectness of the truncation
var clipboarddata = event.clipboardData;
} else if (window.clipboardData != null/false/undefined) {
var clipboarddata = window.clipboardData;
} else { //default to the last option even if it is null/false/undefined
var clipboarddata = event.originalEvent.clipboardData;
}
,因此您获得undefined
的值event.originalEvent.clipboardData
,undefined
分配给变量。因此下一行的错误。