Я щойно почав працювати з Django, починаючи з років Spring MVC, і впровадження форм вражає як трохи божевільний. Якщо ви не знайомі, форми Django починаються з класу моделі форми, яка визначає ваші поля. Весна аналогічно починається з об'єкта, що підтримує форму. Але там, де Spring надає таліб для прив’язки елементів форми до резервного об'єкта у вашому JSP, Django має віджети форми, прив'язані безпосередньо до моделі. Існують віджети за замовчуванням, де ви можете додати атрибути стилю до своїх полів, щоб застосувати CSS або визначити повністю власні віджети як нові класи. Все це входить у ваш пітон-код. Мені це здається гайкою. По-перше, ви вводите інформацію про свій погляд безпосередньо у свою модель, а по-друге, ви прив'язуєте свою модель до певного виду. Я щось пропускаю?
EDIT: Деякі приклади коду за запитом.
Джанго:
# Class defines the data associated with this form
class CommentForm(forms.Form):
# name is CharField and the argument tells Django to use a <input type="text">
# and add the CSS class "special" as an attribute. The kind of thing that should
# go in a template
name = forms.CharField(
widget=forms.TextInput(attrs={'class':'special'}))
url = forms.URLField()
# Again, comment is <input type="text" size="40" /> even though input box size
# is a visual design constraint and not tied to the data model
comment = forms.CharField(
widget=forms.TextInput(attrs={'size':'40'}))
Весняний MVC:
public class User {
// Form class in this case is a POJO, passed to the template in the controller
private String firstName;
private String lastName;
get/setWhatever() {}
}
<!-- JSP code references an instance of type User with custom tags -->
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<!-- "user" is the name assigned to a User instance -->
<form:form commandName="user">
<table>
<tr>
<td>First Name:</td>
<!-- "path" attribute sets the name field and binds to object on backend -->
<td><form:input path="firstName" class="special" /></td>
</tr>
<tr>
<td>Last Name:</td>
<td><form:input path="lastName" size="40" /></td>
</tr>
<tr>
<td colspan="2">
<input type="submit" value="Save Changes" />
</td>
</tr>
</table>
</form:form>