onpropertychange & oninput兼容性

onpropertychange & oninput兼容性onpropertychange:适用IE,谷歌不适用。IE:监听所有属性,也适用js改变value<inputname=”fundName”id=”fundName”type=”hidden”value='<DM:DocumentTagfield=”fundName”/>’onpropertychange=”{ if(”==this.value){ return; } varvtime=document.f1.sys_createtime.value;

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

函数

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

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

修改方法:

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

案例:

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

<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

<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

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

<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后监听:

<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.net/159248.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • FEC介绍(一)_FEC项目是什么意思

    FEC介绍(一)_FEC项目是什么意思1、FEC是什么。FEC,forwarderrorcorrection,前向纠错。2、FEC用来做什么。网络数据传输时,难免出现数据包丢失等问题。数据传输出现丢包时,常用的传输方式有2种:丢包重传和前向纠错(FEC)。丢包重传是接收方发现数据包有丢失,请求发送方重新发包。帧头信息中的sequencenumber,正常状态下,该序列号是连续的。接收方根据该序列号判断是否丢包。可以看出,丢包重传是接收方和发送方本身有几次交互。FEC通过另外一种方式处理丢包。发送方在发送数据时,在每

    2022年8月11日
    8
  • 五大主流浏览器及四大内核1

    五大主流浏览器及四大内核1

    2021年10月23日
    44
  • realsense深度图像保存方法

    realsense深度图像保存方法一般使用realsense时会保存视频序列,当保存深度图像时,需要注意保存的图像矩阵的格式,不然可能造成深度值的丢失。在众多图像库中,一般会使用opencv中的imwrite()函数进行深度图像的保存。一般深度图像中深度值的单位是mm,因此一般使用np.uint16作为最终数据格式保存。例子:importnumpyasnpimportcv2deffun1(…

    2022年4月25日
    33
  • MySQL修改表名注释「建议收藏」

    MySQL修改表名注释「建议收藏」MySQL修改表名注释altertabletest1comment’修改后的表的注释’;

    2022年6月1日
    30
  • linux生成initramfs,Linux启动过程与initramfs

    linux生成initramfs,Linux启动过程与initramfsLinux启动过程概述这里先简单列一下Linux操作系统启动的全过程:按下电脑的电源键后,电脑通电,BIOS启动;BIOS读取硬盘的MBR,运行启动扇区中的代码,旧系统往往需要自己写启动扇区,而新系统基本上由专用的启动软件接管了,在Linux世界中,目前都是用的Grub2。由于启动扇区空间太小,放不下太复杂的代码逻辑,所以Grub2也使用了多阶段启动的策略;Grub2负责将操作系统…

    2022年8月11日
    6
  • 【流量代理】代理模式「建议收藏」

    【流量代理】代理模式「建议收藏」文章目录直连模式pac模式全局模式参考找了好几篇文章,终于找到了Pac的全称。直连模式顾名思义直连模式就是不适用任何代理的模式,这种模式下你访问网站时不会走代理ip还是你自己的。pac模式这个是大家普遍适用的一种模式全称叫(Proxyauto-config)代理自动配置模式,这种模式浏览器会根据一些配置的规则选择某个网站是否走代理。一般情况下,使用Pac模式访问国内网站不会走代理,访问国外网站会走代理,优点是节省流量。全局模式这个模式就是指所有的请求都会通过代理服务器。这种模式下虽然简单粗

    2022年10月18日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号