javascript/jQuery 如何获得鼠标右键黏贴在input中的值并用alert弹窗显示出来

 我来答
马后雷鼓下扬州5058
推荐于2017-09-04 · TA获得超过4321个赞
知道小有建树答主
回答量:693
采纳率:33%
帮助的人:812万
展开全部

这个问题主要是监听 onpaste (鼠标右键粘贴或 Ctrl + V)。


如果 input 值为空,那么很简单,在 onpaste 之后获取 input 的值就是被粘贴的内容。

但如果 input 内已经有内容,用户选择在中间部位粘贴,或者选择一部分内容后再粘贴 (替换粘贴),那实施起来就比较复杂。下面是完整的代码


function getSelectionBoundary(el, start) {
var property = start ? "selectionStart" : "selectionEnd";
var originalValue, textInputRange, precedingRange
, pos, bookmark, isAtEnd;

if(typeof el[property] == "number") {
return el[property];
}
else if(document.selection && document.selection.createRange) {
el.focus();
var range = document.selection.createRange();
if(range) {
if(document.selection.type == "Text") {
range.collapse(!!start);
}
originalValue = el.value;
textInputRange = el.createTextRange();
precedingRange = el.createTextRange();
pos = 0;
bookmark = range.getBookmark();
textInputRange.moveToBookmark(bookmark);
if(/[\r\n]/.test(originalValue)) {
try {
range.move("character", 1);
isAtEnd = (range.parentElement() != el);
}
catch(ex) {
isAtEnd = true;
}
range.moveToBookmark(bookmark);
if(isAtEnd) {
pos = originalValue.length;
}
else {
textInputRange.text = " ";
precedingRange.setEndPoint("EndToStart",
textInputRange);
pos = precedingRange.text.length - 1;
textInputRange.moveStart("character", -1);
textInputRange.text = "";
}
}
else {
precedingRange.setEndPoint("EndToStart", textInputRange);
pos = precedingRange.text.length;
}
return pos;
}
}
return 0;
}

function getInputSelection(ele) {
var start = getSelectionBoundary(ele, true),
end = getSelectionBoundary(ele, false);
return {
start: start,
end: end,
length: end - start,
text: ele.value.slice(start, end)
};
}

function detectPaste(ele, callback) {
ele.onpaste = function() {
var sel = getInputSelection(ele);
var initialLength = ele.value.length;
window.setTimeout(function() {
var val = ele.value;
var pastedTextLength =
val.length - (initialLength - sel.length);
var end = sel.start + pastedTextLength;
callback({
start: sel.start,
end: end,
length: pastedTextLength,
text: val.slice(sel.start, end),
replacedText: sel.text
});
}, 1);
};
}


以上都是监听 onpaste 和获取粘贴内容的函数,下面是用法。(如果你只是使用,不需要理解上面代码的内容)


window.onload = function() {
// 获取要监听的 input 或 textarea
var content = document.getElementById("content");

// 开始监听,第二个参数为回调函数,返回一个对象,其中包括
// start: 光标开始位置,end: 粘贴后光标位置
// length: 粘贴内容的长度,replacedtext: 被替换的内容
// text: 这个就是被粘贴的内容
detectPaste(content, function(pasteInfo) {
alert(pasteInfo.text);
});
};


<input type="text" id="content" value="" />
永久的指针oO
推荐于2017-09-30 · TA获得超过145个赞
知道小有建树答主
回答量:189
采纳率:33%
帮助的人:49万
展开全部
粘贴后会触发change事件
通过$(this).val()取出事件触发后input内的值
$('input').on('change',function(){
alert($(this).val());

});
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
明月清风618
2013-04-12 · TA获得超过737个赞
知道小有建树答主
回答量:395
采纳率:100%
帮助的人:128万
展开全部
貌似不能把,你只能把用户选择后复制到文本框的值给alert出来,这样是检测文本中值是否变化,变了就弹。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tianheww
2015-08-15 · TA获得超过140个赞
知道小有建树答主
回答量:230
采纳率:66%
帮助的人:71.2万
展开全部
<input id="tt" type="text"/>
如果是这样的话,直接用alert($("#tt").val())就可以了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友c32a9f5fb2
2015-07-14 · TA获得超过683个赞
知道小有建树答主
回答量:295
采纳率:33%
帮助的人:149万
展开全部
try it see see.试试看

$("#input_id").bind('change',function(e){
alert(this.val()) ;

});
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式