2011-10-25 16 views
2

jqueryを使用してテキストボックスに入力されたテキストに基づいてListBoxの項目を選択しようとしています。テキストボックスに入力されたテキストの長さが1より大きい場合、ListBox内のアイテムをループして各アイテムの値を比較し、テキストボックスに入力された数値と一致する場合は選択/強調する必要がありますListBox私がやっていることはありますが、うまくいかないようです。 ListBoxのListItemは、データベースから実行時に移入されます。TextBoxのテキストに基づいてListBoxのListItemを選択します。

Asp.Net

<asp:TextBox ID="txtMediaCode" runat="server" MaxLength="2" Width="40px" /> 
<asp:ListBox ID="lsMediaCodes" runat="server" Width="296px" /> 

のjQuery

<script type="text/javascript"> 

    $(document).ready(function() { 

     $('#txtMediaCode').keyup(function() { 
      if ($('#txtMediaCode').length > 1) { 
       $('#lsMediaCodes').each(function (i, option) { 

        if ($(option).val() == $('#txtMediaCode').val()) { 
         $(option).attr('selected', 'selected'); 
        } 

       }); 
      } 
     }); 

    }); 

</script> 

誰もが何か提案がありますか?

答えて

0

てみてください -

$(document).ready(function() { 
    $('#txtMediaCode').keyup(function() { 
     console.log('in') 
     if ($('#txtMediaCode').val().length > 1) { 
      $('#lsMediaCodes > option').each(function(i, option) { 
       if ($(option).val() == $('#txtMediaCode').val()) { 
        $(option).attr('selected', 'selected'); 
       } 
      }); 
     } 
    }); 
}); 

これは変化のカップルとあなたのコードです -

  • それは今上にあるどのように多くの要素の#txtMediaCode "テキストボックス ではなく、中値の長さをチェックしますページ
  • は、ザ・各セレクタは、これは、すべてのオプション要素だけではなく、リスト自体
0123]を選択します $('#lsMediaCodes > option').each( に変更されました

デモ - http://jsfiddle.net/rMW2b/1/

+0

ipr101に感謝してくれてありがとうございます。申し訳ありませんが、テキストボックスの.val()。長さを打ち切ってしまいました...あなたの$( '#lsMediaCodes>オプション')。それぞれは完全に動作します。 – Nathan

0

この作業を行うには、いくつかのことを行う必要があります。まず、あなたが任意のASP.NETコントロールのために、次のようなセレクタを使用する必要がありますasp.netコントロールが描画される

$('#<%= lsMediaCodes.ClientID %>') 

があることは、あなたがasp.netコントロールを与えたものと非常に異なるIDを持っています。

次に、各リストアイテムを保持し、リストボックスではなくそれらを選択するために、ListBoxが生成するhtml要素を調べる必要があります。

プロジェクトでASP.NETコントロールを作成すると、ASP.NETとしてレンダリングされず、HTMLとしてレンダリングされます。このため、javascript/jQueryを使用して操作する場合と同様に、各コントロールのレンダリングの内容を把握する必要があります。

+0

ご回答いただきありがとうございます。 web.configでクライアントIDモードを静的に設定していますので、.netが生成したIDは取得できません。私はリストボックスとテキストボックスのIDを正しく取得していますが、各ループは機能していないようです。各ループの内部やループ自体に何が間違っているのか、ご意見はありますか? – Nathan

+0

あなたの例では、コールバック関数の 'option'はその子要素の代わりに' lsMediaCodes'となると思います。子要素がどのように描画されているかを見て、セレクタを次のように変更します: '$( '#lsMediaCodes .childElement')。each(' –

1

このような何かを試してみてください:

selectMediaCode ($("#<%txtMediaCode.ClientID%>").val()); 

selectMediaCode = function(text){  
    $("#<%=lsMediaCodes.ClientID%> option:contains('" + text + "')").attr("selected", "selected"); 
} 

あなたはまた、それをあまりにもこのよう行うことができます:

selectMediaCode = function(text){  
    $("#<%=lsMediaCodes.ClientID%> option[value='" + text + "']").attr("selected", "selected"); 
} 

EDIT

を私はあなたもこれを行うことができると思います

selectMediaCode = function(text){  
    $("#<%=lsMediaCodes.ClientID%>").val(text); 
} 
関連する問題