用JavaScript实现TEXTbox与DropDownList的交互

本文介绍如何使用JavaScript实现DropDownList与TextBox之间的数据同步。包括:将DropDownList的选择项文本或值赋给TextBox,以及TextBox值变化时查找DropDownList中最匹配的项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

从DropDownList到TextBox,也就是当DropDownList选择时,把DropDownList的TEXT或VALUE值赋给TEXTBOX

None.gif // ddl是dropdownlist控件的名称,txt是textbox控件的名称
None.gif//
把dropdownlist的Text值赋给TEXTBOX
None.gif
function  DdlSelectedTextToTxt(ddl,txt)
ExpandedBlockStart.gifContractedBlock.gif
... {
InBlock.gif    document.all(txt).value
=document.all(ddl).options[document.all(ddl).selectedIndex].text;
InBlock.gif    
return false;
ExpandedBlockEnd.gif}

None.gif
// 把dropdownlist的VALUE值赋给TEXTBOX
None.gif
function  DdlSelectedTextToTxt(ddl,txt)
ExpandedBlockStart.gifContractedBlock.gif
... {
InBlock.gif    document.all(txt).value
=document.all(ddl).options[document.all(ddl).selectedIndex].value;
InBlock.gif    
return false;
ExpandedBlockEnd.gif}

把方法绑定到 DropDownList的onchange事件上

None.gif ddl.Attributes.Add( " onchange " " return DdlSelectedTextToTxt(' "   +  ddl.ClientID  +   " ',' "   +  txt.ClientID  +   " ') " );

从TextBox到DropDownList,也就是当textbox的值改变时,从DropDownList的text或value中查找最相近的值(下面的代码只是在DropDownList的text中查找),并把DropDownList的TEXT或VALUE值赋给TEXTBOX。

1.先比较textbox与dropdownlist的值

None.gif   // 返回值:bool, ddl所有项与txt.text值进行匹配,若找到返回true,否则返回false
None.gif
 function Match_DdlToTxt(txt,ddl)
ExpandedBlockStart.gifContractedBlock.gif 
... {
InBlock.gif     var returnValue
=false;
InBlock.gif     var txtValue
=document.all(txt).value;
InBlock.gif     
for( i=0;i<document.all(ddl).options.length;i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif     
...{
InBlock.gif         
if(IsMatch(txtValue,document.all(ddl).options[i].text)==true)
ExpandedSubBlockStart.gifContractedSubBlock.gif         
...{
InBlock.gif            document.all(txt).value
=document.all(ddl).options[i].text;
InBlock.gif            document.all(ddl).options[i].selected
=true;
InBlock.gif            returnValue
= true;
InBlock.gif            
break;
ExpandedSubBlockEnd.gif         }

ExpandedSubBlockEnd.gif     }
  
InBlock.gif    
return returnValue; 
ExpandedBlockEnd.gif}
 
None.gif
// 返回值:bool,匹配sValue1与sValue2项,sValue2是否包含sValue1,包含返回true,否则返回false
None.gif
function IsMatch(sValue1,sValue2)
ExpandedBlockStart.gifContractedBlock.gif
... {
InBlock.gif    var index
=sValue2.indexOf(sValue1);
InBlock.gif    
if(index>=0)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
...{
InBlock.gif        
return true;
ExpandedSubBlockEnd.gif    }

InBlock.gif       
return false;
ExpandedBlockEnd.gif}
 

2.设置当textbox中输入是回车键时响应比较查询事件

None.gif function ChkKeyEnterDdl(txt,ddl) 
ExpandedBlockStart.gifContractedBlock.gif
... {
InBlock.gif    
if(event.keyCode==13)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
...{    
InBlock.gif       
if(Match_DdlToTxt(txt,ddl)==false)
ExpandedSubBlockStart.gifContractedSubBlock.gif       
...{
InBlock.gif          alert(
"数据不匹配!");
ExpandedSubBlockEnd.gif       }

InBlock.gif       
return false;
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

3.把方法绑定到textbox的onkeypress事件或onkeydown事件上

None.gif TextBox1.Attributes.Add( " onkeydown " " return ChkKeyEnterDdl(' "   +  txt.ClientID  +   " ',' "   +  ddl.ClientID  +   " ') " );
None.gif
None.gif
None.gif
None.gifTextBox1.Attributes.Add(
" onkeypress " " return ChkKeyEnterDdl(' "   +  txt.ClientID  +   " ',' "   +  ddl.ClientID  +   " ') " );

转载于:https://www.cnblogs.com/lhuser/articles/1460786.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值