我正在使用 asp.NET 和 c# 在搜索框上实现自动完成。这就是我划分代码的方式:我有一个类 ListSuggestions.cs、默认的 Default.aspx.cs 类和我的 jquery 自动完成代码所在的默认页面 Default.aspx。
这是我的 ListSuggestions.cs:
public class ListSuggestions
{
public string[] loadArray(string[] companiesArray)
{
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["DatabaseConnectionString"].ConnectionString);
SqlCommand cmd = new SqlCommand(@"SELECT [Name] FROM [Party_Company_General]", conn);
conn.Open();
SqlDataReader dr = cmd.ExecuteReader();
var companies = new List<string>();
while (dr.Read())
{
companies.Add(dr["Name"].ToString());
}
return companiesArray = companies.ToArray();
}
}
默认.aspx.cs:
public partial class Default : System.Web.UI.Page
{
private string[] companiesArray { set; get; }
public class JavaScript
{
public static string Serialize(object o)
{
JavaScriptSerializer js = new JavaScriptSerializer();
return js.Serialize(o);
}
}
protected void Page_Load(object sender, EventArgs e)
{
ListSuggestions listSuggestions = new ListSuggestions();
String[] companiesArray = listSuggestions.loadArray(this.companiesArray);
}
}
Default.aspx 脚本代码:
<script type="text/javascript">
$(function () {
var availableTags = <%=JavaScript.Serialize(this.companiesArray) %>
$(".searchbox").autocomplete({
source: availableTags
});
});
</script>
问题是我认为companiesArray
JavaScript 代码无法访问该字符串。我的代码可能有什么问题?我该如何解决我的问题,请有人帮助我。