Ho questo modello:MVC 3 modificare vista per alcuni settori solo
public class ExchangeRate
{
[Key]
public int ExchangeRateID { get; set; }
[Required]
[Display(Name = "Currency:")]
public string Currency { get; set; }
[Required]
public decimal Rate { get; set; }
}
Il "Crea" Vista sta lavorando bene, ma quando sono nella vista edit, voglio solo la proprietà valuta da visualizzare e non modificabile. Come dovrei farlo? Se creo un altro modello di "sola visione" per questa classe, allora ometterei la proprietà "Valuta" e non sarei in grado di visualizzarla.
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>ExchangeRate</legend>
@Html.HiddenFor(model => model.ExchangeRateID)
<div class="editor-label">
@Html.LabelFor(model => model.Currency)
</div>
<div class="editor-field">
@Html.DisplayFor(model => model.Currency)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Rate)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Rate)
@Html.ValidationMessageFor(model => model.Rate)
</div>
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
}
Modifica @ Html.EditorFor (modello => model.Currency) a @ Html.DisplayFor (modello => model.Currency) non funziona perché lo stato modello non è più valido quando si invia di nuovo al controller.
Funziona anche in combinazione con il bootstrap di Twitter, ad es. nella seguente vista: ' @ Html.DisplayFor (m => m.ProductName)' – Manfred
L'utente non può modificare i campi read-olny tramite firebug ecc.? – Sami