私はこのaspxコードを持っています:(サンプル)
_<asp:DropDownList runat="server" ID="ddList1"></asp:DropDownList>
_
このコードビハインド:
_List<System.Web.UI.WebControls.ListItem> colors = new List<System.Web.UI.WebControls.ListItem>();
colors.Add(new ListItem("Select Value", "0"));
colors.Add(new ListItem("Red", "1"));
colors.Add(new ListItem("Green", "2"));
colors.Add(new ListItem("Blue", "3"));
ddList1.DataSource = colors;
ddList1.DataBind();
_
出力は次のようになります。
_<select name="ddList1" id="ddList1">
<option value="Select Value">Select Value</option>
<option value="Red">Red</option>
<option value="Green">Green</option>
<option value="Blue">Blue</option>
</select>
_
私の質問は:なぜ私の値(数字)が消えて、テキストが値とテキストとして使用されたのですか? ddList1.Items.Add(New ListItem("text", "value"))
メソッドを使用すれば機能することはわかっていますが、他の理由でデータソースとして汎用リストを使用する必要があります。
DataBindメソッドは、DataValueFieldプロパティが設定されている場合にのみ値をバインドするためです。 DataBindを呼び出す前にDataValueFieldプロパティを「Value」に設定すると、値がマークアップに表示されます。
更新:DataTextFieldプロパティを「Text」に設定する必要もあります。これは、データバインディングとアイテムの手動追加が同じように機能しないためです。データバインディングはタイプListItemの存在を認識せず、データソース内のアイテムを評価することによってマークアップを生成します。
そして、これがデータバインディングを実行するメソッドです。あなたは何が起こっているかを正確に見ることができます:
protected internal override void PerformDataBinding(IEnumerable dataSource)
{
base.PerformDataBinding(dataSource);
if (dataSource != null)
{
bool flag = false;
bool flag2 = false;
string dataTextField = this.DataTextField;
string dataValueField = this.DataValueField;
string dataTextFormatString = this.DataTextFormatString;
if (!this.AppendDataBoundItems)
{
this.Items.Clear();
}
ICollection is2 = dataSource as ICollection;
if (is2 != null)
{
this.Items.Capacity = is2.Count + this.Items.Count;
}
if ((dataTextField.Length != 0) || (dataValueField.Length != 0))
{
flag = true;
}
if (dataTextFormatString.Length != 0)
{
flag2 = true;
}
foreach (object obj2 in dataSource)
{
ListItem item = new ListItem();
if (flag)
{
if (dataTextField.Length > 0)
{
item.Text = DataBinder.GetPropertyValue(obj2, dataTextField, dataTextFormatString);
}
if (dataValueField.Length > 0)
{
item.Value = DataBinder.GetPropertyValue(obj2, dataValueField, null);
}
}
else
{
if (flag2)
{
item.Text = string.Format(CultureInfo.CurrentCulture, dataTextFormatString, new object[] { obj2 });
}
else
{
item.Text = obj2.ToString();
}
item.Value = obj2.ToString();
}
this.Items.Add(item);
}
}
if (this.cachedSelectedValue != null)
{
int num = -1;
num = this.Items.FindByValueInternal(this.cachedSelectedValue, true);
if (-1 == num)
{
throw new ArgumentOutOfRangeException("value", SR.GetString("ListControl_SelectionOutOfRange", new object[] { this.ID, "SelectedValue" }));
}
if ((this.cachedSelectedIndex != -1) && (this.cachedSelectedIndex != num))
{
throw new ArgumentException(SR.GetString("Attributes_mutually_exclusive", new object[] { "SelectedIndex", "SelectedValue" }));
}
this.SelectedIndex = num;
this.cachedSelectedValue = null;
this.cachedSelectedIndex = -1;
}
else if (this.cachedSelectedIndex != -1)
{
this.SelectedIndex = this.cachedSelectedIndex;
this.cachedSelectedIndex = -1;
}
}
ListItemsを作成している場合は、最初にDataBind()を使用する必要はありません。
それらをDropDownListに追加するだけです。
ddList1.Items.Add(new ListItem("Select Value", "0"));
ddList1.Items.Add(new ListItem("Red", "1"));
ddList1.Items.Add(new ListItem("Green", "2"));
ddList1.Items.Add(new ListItem("Blue", "3"));
DataBind()は、DataTextFieldとDataValueField(buyutecが書いたように)を設定することにより、データソースとして使用できるコレクション/データオブジェクト(通常はDataTableまたはDataView)が既にある場合に役立ちます。
「ListItemsを作成している場合は、最初にDataBind()を使用する必要はありません。」
ドロップダウンリストに直接追加するのは簡単な方法です(そしてサンプルコードが正しいものを与えられた場合)が、順序付けられていないデータソースがあり、リストアイテムを並べ替えたいとしましょう。
これを実現する1つの方法は、ListItemの汎用リストを作成し、リストにデータバインディングする前に継承された並べ替えメソッドを使用することです。
猫の皮を剥ぐ方法はたくさんあります...