0

次のasp.netおよびC#コードを使用して、Ajaxツールキットのオートコンプリートを使用しました。

 <asp:UpdatePanel ID="updPnlMedicineName" runat="server" >
  <ContentTemplate>
           Name<br />
               <asp:TextBox ID="txtMedName" runat="server" Width="150px" 
                   ontextchanged="txtMedName_TextChanged"></TextBox>
  <cc1:AutoCompleteExtender ID="txtSearchID_AutoCompleteExtender" runat="server"    DelimiterCharacters="" OnClientItemSelected="ItemSelected" Enabled="True" GetMedicine" ServicePath="Search/NameSearch.asmx" TargetControlID="txtMedName" MinimumPrefixLength="1">
 </cc1:AutoCompleteExtender>

私の背後にあるコードは次のとおりです。

[WebMethod]
public string[] GetMedicine(string prefixText)
{
 List<string> listString = new List<string>();
 using (SqlConnection con = new  SqlConnection(ConfigurationManager.ConnectionStrings["NewLandConnectionString"].ConnectionString))
{
 SqlCommand com = new SqlCommand("select ProductName+','+ProductCode+',' + (select unitName from Unit where Unit.Id=product1.UnitId) as ProductDetails,ProductId from product1 where ProductName like '"+prefixText+"%'", con);
 con.Open();
 SqlDataAdapter adr = new SqlDataAdapter(com);
 DataTable dt = new DataTable();
 adr.Fill(dt);
  for (int j = 0; j < dt.Rows.Count; j++)
        {
            string countProduct = dt.Rows[j]["ProductDetails"].ToString();

           listString.Add(AutoCompleteExtender.CreateAutoCompleteItem(dt.Rows[j]["ProductDetails"].ToString(),dt.Rows[j]["ProductId"].ToString()));
        }
  }
    string[] strarray = listString.ToArray();
    return strarray;
 }

オートコンプリートが機能すると、somename、code、unitの形式で値を取得しますが、値が選択されている場合は、csvから最初の値、つまりそのtexboxの「somename」と他の2つの値のみを取得する必要があります(つまり、 code,unit ) は、それぞれ他の texbox に入力する必要があります。

このタスクを達成するのを手伝ってください。

前もって感謝します !!

4

1 に答える 1

0

最後に、 このリンクの助けを借りて自分で解決策を見つけました。これが誰かにも役立つことを願っています。したがって、上記のクエリに対して以下のコードを提供しています。

OnClientItemSelected on the AutoCompleteExtender control run a javascript function

 <script type="text/javascript">
    function ItemSelected(sender, args) {
        __doPostBack(sender.get_element().name, "");
    }
</script>

TextBox(AutoExtender) のテキスト変更について:

 Put the below code on textchange event

    string obj = txtMedName.Text.ToString();//in this texbox you are getting your 
                  //values from autoextender and so store this value in to a string
    string[] nameList = obj.Split(','); //finally using split separate your CSV 
                                    //values and store in an array which you are 
                                    // getting on autoextender
    txtMedName.Text = nameList[0].ToString();//Now pass the values to respective 
                                             //texboxes
    txtBox2.Text = nameList[1].ToString();
    txtBox3.Text = nameList[2].ToString();
于 2013-04-05T10:02:59.140 に答える