gpt4 book ai didi

javascript - 是否可以填充 "oninput"事件?

转载 作者:行者123 更新时间:2023-12-03 10:29:50 27 4
gpt4 key购买 nike

我正在尝试通过这种方式填充“oninput”:

var $el = document.getElementById("ctx");

if( "oninput" in $el ) {
// native oninput
$el.addEventListener("input", function(e) {
// skip nodeType === 3
this.nextSibling.nextSibling.textContent = this.value;
}, false);
} else {
// trying to polyfill
$el.addEventListener("keyup", function(e) {
this.nextSibling.nextSibling.textContent = this.value;
}, false);
};

但是,有一个问题——只有在 key 打开后才能工作;可以修复吗?

演示:http://jsfiddle.net/zhak55/m9up2d78/

最佳答案

我不久前编写了这个简单的 JavaScript 函数来监视输入字段的任何更改,即使在不支持 input 事件的旧版浏览器中也是如此,并且它尝试涵盖输入字段的所有方式。可能会发生更改,包括复制/粘贴、按键输入、拖/放等...

// create self-executing function wrapper so we have a private scope for
// things that we just want to define/execute once
(function() {
var isIE = false;
// conditional compilation which tells us if this is old IE
// which is needed because old IE has a buggy `oninput`
// implementation that must be worked around (so we can't use feature detection)
/*@cc_on
isIE = true;
@*/

// Which events to monitor
// the boolean value is whether we have to
// re-check after the event with a setTimeout()
var events = [
"keyup", false,
"blur", true,
"focus", true,
"drop", true,
"change", false,
"input", false,
"paste", true,
"cut", true,
"copy", true
];

// Test if the input event is supported
// It's too buggy in IE so we never rely on it in IE
if (!isIE) {
var el = document.createElement("input");
var gotInput = ("oninput" in el);
if (!gotInput) {
el.setAttribute("oninput", 'return;');
gotInput = typeof el["oninput"] == 'function';
}
el = null;
// if 'input' event is supported, then use a smaller
// set of events
if (gotInput) {
events = [
"input", false,
"textInput", false
];
}
}

// add event cross browser
function addEvent(elem, event, fn) {
if (elem.addEventListener) {
elem.addEventListener(event, fn, false);
} else {
elem.attachEvent("on" + event, function() {
// set the this pointer same as addEventListener when fn is called
return(fn.call(elem, window.event));
});
}
}

// simplified shallow copy of an object
function copyObj(o) {
var x = {};
for (var i in o) {
x[i] = o[i];
}
return(x);
}

// define global function
window.onChange = function(elem, fn, data) {
var priorValue = elem.value;

function checkNotify(e, delay) {
if (elem.value !== priorValue) {
priorValue = elem.value;
fn.call(elem, e, data);
} else if (delay) {
var eCopy = copyObj(e);
// the actual data change happens aftersome events
// so we queue a check for after
setTimeout(function() {checkNotify(eCopy, false)}, 1);
}
}

for (var i = 0; i < events.length; i+=2) {
(function(i) {
addEvent(elem, events[i], function(e) {
checkNotify(e, events[i+1]);
});
})(i);
}
}
})();

// sample usage
onChange(elem, function(e) {
// The this ptr is set to the element that had the change
});

关于javascript - 是否可以填充 "oninput"事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29263616/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com