您的位置:首页 > 产品设计 > UI/UE

JS改变input的value值不触发onchange事件解决方案 (转)

2017-12-07 10:36 351 查看
方法(一)(转载的网络资料)

需要了解的知识

首先,我们需要了解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可行,火狐可行)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: