JS改变input的value值不触发onchange事件解决方案 (转)
2017-12-07 10:36
351 查看
方法(一)(转载的网络资料)
需要了解的知识
onchange在属性值改变时还必须使得当前元素失去焦点(onblur)才可以激活该事件。
onpropertychange 是IE浏览器的专属方法
oninput的使用
下面我们先了解一下oninput如何使用。
如果您是将注册时间直接写在页面里面,那么如下写法就可以实现
但是,将oninput写在JS代码中分离出来时与普通事件注册的方法有些不同,必须使用addEventListener来注册。
ttachEvent和addEventListener 的不同
attachEvent方法,为某一事件附加其它的处理事件。(不支持Mozilla系列)
addEventListener方法 用于 Mozilla系列
document.getElementById(“btn”).onclick = method1;
document.getElementById(“btn”).onclick = method2;
document.getElementById(“btn”).onclick = method3;
如果这样写,那么将会只有medhot3被执行
var btn1Obj = document.getElementById(“btn1”);
btn1Obj.attachEvent(“onclick”,method1);
btn1Obj.attachEvent(“onclick”,method2);
btn1Obj.attachEvent(“onclick”,method3);
执行顺序为method3->method2->method1
如果是Mozilla系列,并不支持该方法,需要用到addEventListener
var btn1Obj = document.getElementById(“btn1”);
btn1Obj.addEventListener(“click”,method1,false);
btn1Obj.addEventListener(“click”,method2,false);
btn1Obj.addEventListener(“click”,method3,false);
执行顺序为method1->method2->method3
了解了如何使用addEventListener来注册oninput事件后我们再回到要解决的问题[划分浏览器]。
这似乎是一个老生常谈的问题,网络中有很多找那个方法,归类为两类:
其一,是判断浏览器的功能属性。
其二,就是判断传统的 user-agent 字符串,这可能是最古老也是最流行的检测方式。
在这里就不做深入了解了,我们这里用一种比较简单的方法来判断
if(“\v”==”v”) {
alert(“IE”);
}else{
alert(“NO”);
}
到目前为止我们遇到的问题就已经解决了,开始写代码来测试我们的思路是否能够实现。
监听输入框值的即时变化 onpropertychange oninput
function immediately(){
var element = document.getElementById("mytext");
if("\v"=="v") {
element.onpropertychange = webChange;
}else{
element.addEventListener("input",webChange,false);
}
function webChange(){
if(element.value){document.getElementById("test").innerHTML = element.value};
}
}
直接写在页面中的示例:
您输入的值为:还未输入
写在JS中的示例:
您输入的值为:还未输入
immediately();
更改为使用js往input里面加载值!
监听输入框值的即时变化 onpropertychange oninput
function immediately(){
var element = document.getElementById("mytext");
if("\v"=="v") {
element.onpropertychange = webChange;
}else{
element.addEventListener("input",webChange,false);
}
function webChange(){
if(element.value){document.getElementById("test").innerHTML = element.value};
}
}
function addValue(){
document.getElementById("mytext").value='dfdsafdsfsfsdfsdfdsf';
document.getElementById("mytext2").value='dfdsafdsfsfsdfsdfdsf';
}
直接写在页面中的示例:
您输入的值为:还未输入
写在JS中的示例:
您输入的值为:还未输入
immediately();
实践证明在IE中可以,在火狐中不可以!猜测可能是在火狐中不适用!于是使用了方法(二),方法(二)是比较笨重的一种手法,花了很多事情去测试和 更改方法二,但并没有达到我要的效果!况且有计时器的存在,会影响到一定的效率问题!方法(二)并不是说不是好做法,只是适用于什么地方,有可能以后又需 要的地方还得使用呢!
那这样的话,方法二我们都不用看了!
在不断的尝试中发现,方法一并不是不可用,只是,从网上看到的代码存在一点问题。只能说,为什么这些文章上传地有点草率了,给后来人带了不少麻烦。就这么一点点的错误就可以让我们不断尝试呀!为了不让更多的人尝试,希望这篇文章能给纠正一下!
其实,主要修改为:给方法加上()
document.getElementById(“mytext”).addEventListener(“input”,changeValue,false);
改为:document.getElementById(“mytext”).addEventListener(“input”,changeValue(),false);
以下为实验代码:(IE可行,火狐可行)
需要了解的知识
首先,我们需要了解onchange和onpropertychange的不同: IE下,当一个HTML元素的属性改变的时候,都能通过 onpropertychange来即时捕获。
onchange在属性值改变时还必须使得当前元素失去焦点(onblur)才可以激活该事件。
onpropertychange 是IE浏览器的专属方法
了解这一点后我们发现onpropertychange的效果就是我们想要的,可是很遗憾,它只在IE下有效果。我们能不能找到另外一个时间来代替onpropertychange呢? 经过翻阅资料得知,在其他浏览器下可以使用oninput事件来达到同样的效果,真是太好了,我们只需要把IE浏览器区分出来就可以。
oninput的使用
下面我们先了解一下oninput如何使用。
如果您是将注册时间直接写在页面里面,那么如下写法就可以实现
但是,将oninput写在JS代码中分离出来时与普通事件注册的方法有些不同,必须使用addEventListener来注册。
ttachEvent和addEventListener 的不同
说到这里我们再来了解一下 attachEvent和addEventListener 的使用方法:
attachEvent方法,为某一事件附加其它的处理事件。(不支持Mozilla系列)
addEventListener方法 用于 Mozilla系列
document.getElementById(“btn”).onclick = method1;
document.getElementById(“btn”).onclick = method2;
document.getElementById(“btn”).onclick = method3;
如果这样写,那么将会只有medhot3被执行
var btn1Obj = document.getElementById(“btn1”);
btn1Obj.attachEvent(“onclick”,method1);
btn1Obj.attachEvent(“onclick”,method2);
btn1Obj.attachEvent(“onclick”,method3);
执行顺序为method3->method2->method1
如果是Mozilla系列,并不支持该方法,需要用到addEventListener
var btn1Obj = document.getElementById(“btn1”);
btn1Obj.addEventListener(“click”,method1,false);
btn1Obj.addEventListener(“click”,method2,false);
btn1Obj.addEventListener(“click”,method3,false);
执行顺序为method1->method2->method3
了解了如何使用addEventListener来注册oninput事件后我们再回到要解决的问题[划分浏览器]。
判断IE浏览器 如何将IE区分出来呢?
这似乎是一个老生常谈的问题,网络中有很多找那个方法,归类为两类:
其一,是判断浏览器的功能属性。
其二,就是判断传统的 user-agent 字符串,这可能是最古老也是最流行的检测方式。
在这里就不做深入了解了,我们这里用一种比较简单的方法来判断
if(“\v”==”v”) {
alert(“IE”);
}else{
alert(“NO”);
}
到目前为止我们遇到的问题就已经解决了,开始写代码来测试我们的思路是否能够实现。
监听输入框值的即时变化 onpropertychange oninput
function immediately(){
var element = document.getElementById("mytext");
if("\v"=="v") {
element.onpropertychange = webChange;
}else{
element.addEventListener("input",webChange,false);
}
function webChange(){
if(element.value){document.getElementById("test").innerHTML = element.value};
}
}
直接写在页面中的示例:
您输入的值为:还未输入
写在JS中的示例:
您输入的值为:还未输入
immediately();
更改为使用js往input里面加载值!
监听输入框值的即时变化 onpropertychange oninput
function immediately(){
var element = document.getElementById("mytext");
if("\v"=="v") {
element.onpropertychange = webChange;
}else{
element.addEventListener("input",webChange,false);
}
function webChange(){
if(element.value){document.getElementById("test").innerHTML = element.value};
}
}
function addValue(){
document.getElementById("mytext").value='dfdsafdsfsfsdfsdfdsf';
document.getElementById("mytext2").value='dfdsafdsfsfsdfsdfdsf';
}
直接写在页面中的示例:
您输入的值为:还未输入
写在JS中的示例:
您输入的值为:还未输入
immediately();
实践证明在IE中可以,在火狐中不可以!猜测可能是在火狐中不适用!于是使用了方法(二),方法(二)是比较笨重的一种手法,花了很多事情去测试和 更改方法二,但并没有达到我要的效果!况且有计时器的存在,会影响到一定的效率问题!方法(二)并不是说不是好做法,只是适用于什么地方,有可能以后又需 要的地方还得使用呢!
那这样的话,方法二我们都不用看了!
在不断的尝试中发现,方法一并不是不可用,只是,从网上看到的代码存在一点问题。只能说,为什么这些文章上传地有点草率了,给后来人带了不少麻烦。就这么一点点的错误就可以让我们不断尝试呀!为了不让更多的人尝试,希望这篇文章能给纠正一下!
其实,主要修改为:给方法加上()
document.getElementById(“mytext”).addEventListener(“input”,changeValue,false);
改为:document.getElementById(“mytext”).addEventListener(“input”,changeValue(),false);
以下为实验代码:(IE可行,火狐可行)
相关文章推荐
- JS改变input的value值不触发onchange事件解决方案
- JS改变input的value值不触发onchange事件解决方案
- JS改变input的value值不触发onchange事件解决方案(超简版)
- JS改变input的value值不触发onchange事件解决方案
- JS改变input的value值不触发onchange事件解决方案
- JS改变input的value值不触发onchange事件解决方案 (转)
- JS改变input的value值不触发onchange事件解决方案
- JS改变input的value值不触发onchange事件解决方案
- js动态改变value 不触发onchange事件解决办法
- JSP中input内容改变触发onchange事件使用
- 实时监听js改变value,触发事件,跨浏览器支持
- js动态改变input的值不触发input的change事件的解决办法
- JS 实时监听input的value值改变 解决方案
- 当用js动态的改变一个输入框中的值后,并不能触发它的onchange事件why?
- 当用js动态的改变一个输入框中的值后,并不能触发它的onchange事件
- input propertychange事件,当input的value值发生改变时触发(文本框的值即时搜索)
- js中input标签内容改变的触发事件
- 回车键触发事件的js代码、input输入框值改变事件、js数组
- input标签内容改变的触发事件
- input 内容发生改变时触发事件