我的自动完成功能在使用我的旧网站时工作正常但在我移植到C#和Entity Framework时不起作用。以下HTML是用户控件的一部分。我在Web服务代码中添加了断点,它甚至看起来都没有被调用。我不知道在哪里可以查看休息的地方。任何帮助,将不胜感激。感谢。
<asp:ScriptManagerProxy ID="ScriptManagerProxy1" runat="server">
</asp:ScriptManagerProxy>
<asp:TextBox ID="TextBoxDamName" runat="server" Columns="50"></asp:TextBox>
<asp:AutoCompleteExtender ID="TextBoxDamName_AutoCompleteExtender"
runat="server"
DelimiterCharacters=""
Enabled="True"
ServicePath="DamSafetyAutoComplete.asmx"
ServiceMethod="SelectDamNames"
FirstRowSelected="True"
MinimumPrefixLength="1"
CompletionInterval="200"
TargetControlID="TextBoxDamName">
</asp:AutoCompleteExtender></td>
namespace ExternalDamSafetySearch
{
/// <summary>
/// Summary description for DamSafetyAutoComplete
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
// To allow this Web Service to be called from script, using ASP.NET AJAX, uncomment the following line.
[System.Web.Script.Services.ScriptService]
public class DamSafetyAutoComplete : System.Web.Services.WebService
{
[WebMethod]
[System.Web.Script.Services.ScriptMethod]
public string[] SelectDamNames(string prefixText, Int32 count)
{
try
{
EnterprisePubEntities EE = new EnterprisePubEntities();
return EE.DamSafetyDatas
.Take(count)
.Where(c => c.DamName.StartsWith(prefixText))
.Distinct()
.OrderBy(c => c.DamName)
.Select(c => c.DamName)
.ToArray();
}
catch (Exception) { throw; }
}
}
}
答案 0 :(得分:1)
原来我没有将控件指向我的Webservice文件的正确位置。一旦我修复了,即使我在网络服务中点击该方法,我仍然没有得到结果。事实证明我没有正确地返回结果。我通过转动
来修复它 return EE.DamSafetyDatas
.Take(count)
.Where(c => c.DamName.StartsWith(prefixText))
.Distinct()
.OrderBy(c => c.DamName)
.Select(c => c.DamName)
.ToArray();
到
return EE.DamSafetyDatas
.Where(c => c.DamName.StartsWith(prefixText))
.Distinct().Take(count)
.OrderBy(c => c.DamName)
.Select(c => c.DamName)
.ToList.ToArray();
我还必须更改.Take(count)的位置,因为它会从列表中取第一个(count = 10)THEN过滤它们。