0

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();
    }
}

Default.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 コードにアクセスできるとは思わないことです。私のコードの問題は何ですか?どうすれば問題を解決できますか、誰か助けてください。

4

4 に答える 4

0

これに対する解決策を見つけました。答えてくれて助けてくれたすべての人に感謝します。ListSuggestions.cs を次のように変更しました。

public string[] loadArray(ref string[] companiesArray)
        {
            SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["DatabaseConnectionString"].ConnectionString);
            //Fetch the field to auto complete from the database
            SqlCommand cmd = new SqlCommand(@"SELECT [Name] FROM [Party_Company_General]", conn);
            //Open connection
            conn.Open();
            //Read data from the database
            SqlDataReader dr = cmd.ExecuteReader();
            //create a list of companies
            var companiesList = new List<string>();

            while (dr.Read())
            {
                companiesList.Add(dr["Name"].ToString());
            }
            //Convert list to an array
            companiesArray = companiesList.ToArray();

            //Return the array
            return companiesArray;
        }

また、Default.aspx.cs コードを次のように変更しました。

public partial class Default : System.Web.UI.Page
    {
        ListSuggestions listSuggestions;
        public string[] companiesArray;

        //A constructor
        public  Default()
        {
         listSuggestions= new ListSuggestions();
         companiesArray = listSuggestions.loadArray(ref companiesArray);
        }
        //Serializer
        public class JavaScript
        {
            public static string Serialize(object o)
            {
             JavaScriptSerializer js = new JavaScriptSerializer();
             return js.Serialize(o);
             }
          }
     }

コンストラクターを作成し、Page_Load メソッドを廃止しました。

最後に、スクリプトを次のように変更しました。

<script type="text/javascript">
      $(document).ready(function () {

          var availableTags = <%=JavaScript.Serialize(companiesArray) %>

          $(".searchbox").autocomplete({
              source: availableTags
          });
      });
  </script>
于 2013-06-21T14:14:01.097 に答える
0

どうですか:

public String[] CompaniesArray {
    get {
        return this.companiesArray;
    }
}

それで:

<script type="text/javascript">
    $(function () {
        var availableTags = <%=JavaScript.Serialize(CompaniesArray)%>;

        $(".searchbox").autocomplete({
            source: availableTags
        });
    });
</script>

配列は引き続きプライベートにすることができますが、パブリック ゲッターに誰でもアクセスできるようにします。クラスの外部から何かが配列を変更するリスクはありません。

于 2013-06-20T13:08:58.490 に答える