onchange事件是在客户端改变输入控件的值,比如一个textbox,会出发的这个事件。
onchange 在元素值改变时触发。
onchange 属性适用于:<input>、<textarea>以及 <select>元素。
语法:onchange="JavaScript代码"
例如
<script type="text/javascript">function upperCase(){
var x = document.getElementById("fname").value//获取input中的值
document.getElementById("fname").value = x.toUpperCase()//input中的值转换成大写。
}
</script>
<body>
<input type="text" id="fname" onchange="upperCase()" /></p> onchange设置为uppercase时间
</body>
js中onchange事件是在客户端改变输入控件的值,比如一个textbox,会出发的一个事件。但是如果在js代码中改变一个textbox的value,而不是通过键盘输入改变一个textbox值的话,是不会出发onchange事件的。那么,如何在js代码模式通过代码触发textbox控件的onchange事件呢,经过查阅资料,发现js提供了一个方法,可以触发控件的应该是所有事件。object.fireEvent()方法,使用方法如
object.fireEvent('onchange'),即可触发控件的onchange事件。
同理,js中使用fireEvent方法还可以触发其他的空间事件。
•补充一下,上述的fireEvent方法,在firefox浏览器并不支持,那么,如果想在ie和ff都可以运行的话,可是尝试下面的代码。
复制代码
代码如下:
if
(obj.fireEvent)
{
obj.fireEvent('onchange')
}
else
{
obj.onchange()
}
也就是判断一下fireEvent事件是否可用,不可用则直接使用onchange()方法。
javascript onchange()事件:javascript onchange()事件一般用于用户表单中,例如:当文本框内容发生改变时触发的事件,或者下拉列表框内容发生改变时触发的事件等。
示例分享:onchange()事件,用户输入时,将小写字母转换为大写。
此处用到了javascript中的一个方法 toUpperCase()//将小写母转换为大写字母。
<!DOCTYPE html><html>
<head>
<meta charset="utf-8" />
<title>用户表单验证</title>
<script>
function changeValue(){
var userName=document.getElementById("userName") //通过Id获得对象userName
userName.value=userName.value.toUpperCase() //将对象的值进行大小写的转换赋值给当前对象的值;
}
</script>
</head>
<body>
<form name="myform" method="POST" action="register.php" onsubmit="return checkForm()">
userName:<input type="text" name="userName" value="" id="userName" onchange="changeValue()" /><br/>
<input type="submit" name="" value="用户注册" />
</form>
</body>
</html>