前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >onpropertychange & oninput兼容性

onpropertychange & oninput兼容性

作者头像
全栈程序员站长
发布2022-09-15 13:06:48
1.3K0
发布2022-09-15 13:06:48
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

函数

onpropertychange事件:IE专有,disable=true的时候失效,onpropertychange是在触发对象改变任何属性时都会触发。onpropertychange==onchange+onblur。onchange只有在用键盘改变其值,然后在失去焦点(onblur)后才触发。

oninput 事件:JS 改变 value 值时不能触发,下拉列表中选值时,也不会触发。

修改方法:

代码语言:javascript
复制
使用
$(选择器).on(事件名, 处理函数) / $(选择器).off(事件名, 处理函数)
来替代原生JS中的
elem.attachEvent(‘on’ + 事件名, 处理函数) / elem.detachEvent(‘on’ + 事件名, 	处理函数) — IE
elem.addEventListener(事件名, 处理函数) / elem.addEventListener(事件名, 处	理函数) — chrome

案例:

1、onpropertychange:适用IE,谷歌不适用。IE:监听所有属性,也适用js 改变 value

代码语言:javascript
复制
<input name="fundName" id="fundName" type="hidden" value='<DM:DocumentTag field="fundName"/>'
onpropertychange="{
	if(''==this.value){
		return;
	}
	var vtime = document.f1.sys_createtime.value;
	vtime = vtime.substring(0,10).replace(/\-/gi,'');
	document.f1.sys_title.value = vtime+'【'+this.value+'】'+'<%=strshowName%>'; 

}">

2、IE,谷歌都适用(),谷歌js 改变 value 时,却不会触发oninput

代码语言:javascript
复制
<input name="fundName1" id="fundName1" type="text" value='<DM:DocumentTag field="fundCode"/>' onpropertychange="immediately()" oninput="immediately()">

function immediately(){ 
	alert("0");
   var element = document.getElementById("fundName1"); 
   if( window.ActiveXObject) { 
		element.onpropertychange = setTitle; 
   }else{ 
		element.addEventListener("input",setTitle,false); 
   } 
 } 
function setTitle(){
	alert("1");
	var fundName = document.getElementById("fundName1");
	if(''==fundName.value){
		return;
	}
	var vtime = document.f1.sys_createtime.value;
	vtime = vtime.substring(0,10).replace(/\-/gi,'');
	document.f1.sys_title.value = vtime+'【'+fundName.value+'】'+'<%=strshowName%>'; 
}

3、IE,谷歌都适用(),谷歌js 改变 value 时,触发oninput

方法:监听对象添加定时器

代码语言:javascript
复制
<td width="124" height="23" align="center" bgcolor="#efefef">基金名称</td>
<td  bgcolor="#FFFFFF">
	<input name="fundCode" id="fundCode" type="hidden" value='<DM:DocumentTag field="fundCode"/>'>
	//监听对象
	<input name="fundName" id="fundName" type="hidden" value='<DM:DocumentTag field="fundName"/>'
	onpropertychange="{
		if(''==this.value){
			return;
		}
		var vtime = document.f1.sys_createtime.value;
		vtime = vtime.substring(0,10).replace(/\-/gi,'');
		document.f1.sys_title.value = vtime+'【'+this.value+'】'+'<%=strshowName%>'; 
	
	}">
	<input type="button" onclick="selectFundInfo()" value="&nbsp;请点击选择基金&nbsp;">
	<U><span id="showFund"><DM:DocumentTag field="fundName"/></span></U>
</td>
		
		
$(function() {
	if( window.ActiveXObject) { 
		//IE
	}else{
		//其他:谷歌...
		var intervalName;   // 定时器句柄  
		var fundNames = document.getElementById("fundName"); 
		fundNames.addEventListener("input",setTitle,false); 
		setInterval(checkChange,1000);
		
		function checkChange(){
			var intervalNames = fundNames.value;
			if(intervalNames!= intervalName){
				setTitle(fundNames);
				intervalName = fundNames.val();
			}
		}
	}
});

function setTitle(fundNames){
	if(''==fundNames.value){
		return;
	}
	var vtime = document.f1.sys_createtime.value;
	vtime = vtime.substring(0,10).replace(/\-/gi,'');
	document.f1.sys_title.value = vtime+'【'+fundNames.value+'】'+'<%=strshowName%>'; 
}

4、onchange后监听:

代码语言:javascript
复制
<select name="<%=strUserSelId%>_show" id="<%=strUserSelId%>_show" style="width:118px;margin-left:-100px" onchange="this.parentNode.nextSibling.value=this.options[this.selectedIndex].innerHTML;setUserSearchValue(this);setuserboxValue();">
	<option value='' selected>请选择</option>   
</select> 
<input name="problemer" id="problemer" type="hidden" class="tab4" size="30" value='<DM:DocumentTag field="problemer"/>'>


function setuserboxValue(){
	if( window.ActiveXObject) { 
		//IE
	}else{
		//其他:谷歌...
		var intervalName;   // 定时器句柄  
		var problemer = document.getElementById("problemer"); 
		problemer.addEventListener("input",setUserboxValue,false); 
		setInterval(checkChange,1000);
		
		function checkChange(){
			var intervalNames = problemer.value;
			if(intervalNames!= intervalName){
				var problemercode = document.getElementById("<%=strUserSelId%>_show"); 
				setUserboxValue(problemer.value);
				intervalName = problemer.value;
			}
		}
	}
}

function setUserboxValue(obj)
{
	document.getElementById("userbox").value = obj
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/159248.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年7月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 函数
  • 修改方法:
  • 案例:
  • 1、onpropertychange:适用IE,谷歌不适用。IE:监听所有属性,也适用js 改变 value
  • 2、IE,谷歌都适用(),谷歌js 改变 value 时,却不会触发oninput
  • 3、IE,谷歌都适用(),谷歌js 改变 value 时,触发oninput
  • 4、onchange后监听:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档