1

url name(varchar)、urlID(int)、およびそのEnabled status(bit)をデータベースから取得し、その結果をforeachループのCheckedListBoxに入力するメソッドがあります。私が抱えている問題は、チェックボックスリストが名前とそのチェックステータスしか取得していないように見えることです。私ができる必要があるのは、ユーザーがボタンイベントの選択を終えたときに、CheckedListBoxを読み取り、URL IDと有効なステータスを取得して、これをデータベースに書き戻すことができるようにすることです。

これは私が使用しているコードです:

/// <summary>
/// Create url names in check box list.
/// </summary>
/// <param name="rows"></param>
private void CreateURLCheckBoxes(DataRowCollection rows)
{
    try
    {
        int i = 0;
        foreach (DataRow row in rows)
        {
            //Gets the url name and path when the status is enabled. The status of Enabled / Disabled is setup in the users option page
            string URLName = row["URLName"].ToString();
            int URLID = Convert.ToInt32(row["URLID"]);
            bool enabled = Convert.ToBoolean(row["Enabled"]);

            //Adds the returned to rows to the check box list
            CBLUrls.Items.Add(URLName, enabled);

        }
        i++;
    }

    catch (Exception ex)
    {
        //Log error
        Functionality func = new Functionality();
        func.LogError(ex);

        //Error message the user will see
        string FriendlyError = "There has been populating checkboxes with the urls ";
        Classes.ShowMessageBox.MsgBox(FriendlyError, "There has been an Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
    }
}
4

3 に答える 3

8

ステップ 1: 名前を返す ToString() オーバーライドを使用して名前と ID を保持するクラスを作成する

public class UrlInfo
{
    public string Name;
    public int Id;
    public bool Enabled;

    public override string ToString()
    {
        return this.Name;
    }
}

ステップ 2: このクラスのインスタンスを CheckedListBox に追加する

 UrlInfo u1 = new UrlInfo { Name = "test 1", Id = 1, Enabled = false };
 UrlInfo u2 = new UrlInfo { Name = "test 2", Id = 2, Enabled = true };
 UrlInfo u3 = new UrlInfo { Name = "test 3", Id = 3, Enabled = false };

 checkedListBox1.Items.Add(u1, u1.Enabled);
 checkedListBox1.Items.Add(u2, u2.Enabled);
 checkedListBox1.Items.Add(u3, u3.Enabled);

ステップ 3: SelectedItem を UrlInfo にキャストし、.Id を取得する

private void checkedListBox1_ItemCheck(object sender, ItemCheckEventArgs e)
{
    UrlInfo urlInfo = checkedListBox1.Items[e.Index] as UrlInfo;
    if (null != urlInfo)
    {
        urlInfo.Enabled = e.NewValue == CheckState.Checked;
        Console.WriteLine("The item's ID is " + urlInfo.Id);
    }
}
于 2011-02-01T15:37:09.653 に答える
1

string(URL) とint(ID)を含む単純なクラスを作成し、ToString()メソッドをオーバーライドして URL を返し、それらのオブジェクトを のItemsプロパティに追加することをお勧めしCheckedListBoxます。選択したオブジェクトを取得したら、それを新しいクラスにキャストするだけで、両方のプロパティにアクセスできます。

何かのようなもの:

public class MyClass
{
    public string Url { get; set; }
    public int Id { get; set; }
    public override string  ToString()
    {
         return this.Url;
    }
}

そして、オブジェクトを追加すると:

CBLUrls.Items.Add(new MyClass { Id = URLID, Url = URLName }, enabled);
于 2011-02-01T15:34:49.040 に答える
0

このコントロールには、Value メンバーと Display メンバーがあります。Name を表示メンバ、ID を Value メンバにすれば何とかなると思います。

于 2011-02-01T15:27:00.667 に答える