我用telerik:RadComboBox
像这样 :
<telerik:RadComboBox runat="server" ID="RadComboBox1"  EnableLoadOnDemand="true"
                                            ShowMoreResultsBox="true" EnableVirtualScrolling="true" CollapseDelay="0" Culture="ar-EG" ExpandDelay="0" Filter="StartsWith" ItemsPerRequest="100"
                                            MarkFirstMatch="true" Skin="Outlook" ValidationGroup="L" Width="202px" EnableAutomaticLoadOnDemand="True"
                                            EmptyMessage="-Enter user name-"
                                            EnableItemCaching="true" >
                                            <WebServiceSettings Path="../WebService/Employees.asmx" Method="LoadData" />
和我的网络服务:
 [System.Web.Script.Services.ScriptService]
    public class Employees : System.Web.Services.WebService
    {
        [WebMethod(EnableSession = true)]  
            public RadComboBoxData LoadData(RadComboBoxContext context)
                {
                RadComboBoxData result = new RadComboBoxData();
                DataTable dt = FollowsDAL.GetAllEmployees();
                var allEmployees = from r in dt.AsEnumerable()
                                   orderby r.Field<string>("name")
                                   select new RadComboBoxItemData
                                   {
                                       Text = r.Field<string>("name").ToString().TrimEnd()
                                   };
                string text = context.Text;
                if (!String.IsNullOrEmpty(text))
                {
                    allEmployees = allEmployees.Where(item => item.Text.StartsWith(text));
                }
                //Perform the paging
                // - first skip the amount of items already populated
                // - take the next 10 items
                int numberOfItems = context.NumberOfItems;
                var employees = allEmployees.Skip(numberOfItems).Take(100);
                result.Items = employees.ToArray();
                int endOffset = numberOfItems + employees.Count();
                int totalCount = allEmployees.Count();
                //Check if all items are populated (this is the last page)
                if (endOffset == totalCount)
                    result.EndOfItems = true;
                //Initialize the status message
                result.Message = String.Format("Items <b>1</b>-<b>{0}</b> out of <b>{1}</b>",
                                               endOffset, totalCount);
                return result;
            }}
我的问题是:
虽然这个控件非常快,但每次我首先输入特定名称时,它都会在数据20000表中获取员工dt!
与每个字符。
我的问题是:
- 这种不良行为怎么会这么快?
- 有没有办法让所有员工只得到一次?
- 如何提升业绩?