- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试通过这种方式填充“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 打开后才能工作;可以修复吗?
最佳答案
我不久前编写了这个简单的 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/
我正在使用 Blazor 服务器端。 我有几个输入框绑定(bind)到不同的值,但只要有输入,它们就必须调用相同的函数。该函数本质上启动计时器,用于在 X 时间过去后保存数据。 Summary: 我
我正在使用 Blazor 服务器端。 我有几个输入框绑定(bind)到不同的值,但只要有输入,它们就必须调用相同的函数。该函数本质上启动计时器,用于在 X 时间过去后保存数据。 Summary: 我
我在oninput="setCustomValidity('')标记上完美地使用了这个input,但是它似乎在select标记中不起作用。这在select标记中有效吗? 最佳答案 只是否,不适用于s
我遇到了 JavaScript 函数仅触发一次的问题。 我一开始在函数中使用了更简洁的结构,但将其分解为离散的操作,看看我是否能弄清楚任何事情。行为完全相同。 在我的 HTML 中,在 HEAD 标记
我做错了什么导致onInput报告的值是后面的一个字符? 例如,在文本字段中键入“mil”以过滤到里程碑行。然后将其删除,恢复为空,您将看到其仍在过滤的里程碑(另请参阅浏览器控制台以查看该值仍然是“m
我做错了什么导致onInput报告的值是后面的一个字符? 例如,在文本字段中键入“mil”以过滤到里程碑行。然后将其删除,恢复为空,您将看到其仍在过滤的里程碑(另请参阅浏览器控制台以查看该值仍然是“m
JSFIDDLE HTML: Javascript: /**************************************************************** docum
我的 friend 们,下面的代码曾经在 Chrome 52.x 版本之前工作,但在最新版本中它不再工作了。你们中有人知道为什么它不起作用吗? https://jsfiddle.net/2jtrs2m
为了提供条目的预览,我使用了 jQuery,如下所示 $('#text').on('input',function(){ $('#previewText').html($('#text').v
以下代码不适用于所有输入元素: $(':input').on('input', function(){ alert('boom shakalaka'); }); 它对复选框没有影响,即使它们是输入
我正在创建一个打字测试页面并遇到了一个小问题。 我试图在用户键入时启动计时器,并且使用 onInput 有效,但问题是每次我键入 textArea 时它都会注册,这会导致 starttimer 函数自
一周前,我终于找到了一种将消息分成不同类别的方法 (Here is the SO question where I got my answer) 现在我已经实现了这个解决方案: type Msg
晚上好, 我在修改测试对象中的日期值时遇到问题。 oninput 事件似乎只在加载文档时触发一次。当日期更改时,oninput 事件似乎不会触发。 var TestO
我正在尝试通过这种方式填充“oninput”: var $el = document.getElementById("ctx"); if( "oninput" in $el ) { // nati
我想用文本框本身的值和另一个输入框的值来设置文本框的数据值。我已经编写了简单的 JavaScript 代码片段来在 oninput 属性处处理此问题,但它并未使用预期值更新 data-value 属性
我正在尝试通过获取用户的颜色输入来实时调整渐变。每当我调整一个值时,我都会收到错误 - 它表明未给出另一个值。 function btnGradient(input1, input2){ btn.s
我正在构建一个计算天数差异的应用程序。有多个可能使用或不使用的日期选项。因此,我正在构建一个 switch/case 逻辑流程来计算不同的变量组合。一切正常,除了我似乎无法获取函数 add_sd()
比如说,我需要在自定义元素中调用一个函数,这样当 slider 在该元素中移动时,文本会得到更新(仅针对该元素)。 main.js文件, class OninputClassDemo extends
这个问题已经有答案了: Regex accept numeric only. First character can't be 0 (7 个回答) 已关闭 6 年前。 我正在尝试创建一个仅允许具有任意
我有一个数字输入字段,我想像这样在 oninput 上调用一个函数。 function onInput(){ $('.left-arrow' ).click(function(e) {
我是一名优秀的程序员,十分优秀!