Web2py - формы и валидаторы
web2py имеет мощные функции для генерации форм. Четыре различных способа создания форм в web2py следующие:
FORM- С точки зрения помощников HTML это считается реализацией низкого уровня. Объект FORM знает о содержимом своего поля.
SQLFORM - Он предоставляет функции создания, обновления и удаления существующей базы данных.
SQLFORM.factory- Он рассматривается как слой абстракции поверх SQLFORM, который генерирует форму, аналогичную SQLFORM. Здесь нет необходимости создавать новую базу данных.
CRUD Methods - Как следует из названия, он предоставляет функции создания, извлечения, обновления и удаления с аналогичными функциями на основе SQLFORM.
ФОРМА
Рассмотрим приложение, которое принимает ввод от пользователя и имеет кнопку «отправить» для отправки ответа.
Контроллер
Контроллер default.py будет включать следующую связанную функцию
def display_form():
return dict()
Посмотреть
Связанное представление "default / display_form.html" будет отображать отображение формы в HTML как -
{{extend 'layout.html'}}
<h2>Basic Form</h2>
<form enctype = "multipart/form-data" action = "{{= URL()}}" method = "post">
Your name:
<input name = "name" />
<input type = "submit" />
</form>
<h2>Submitted variables</h2>
{{= BEAUTIFY(request.vars)}}
Приведенный выше пример представляет собой обычную HTML-форму, которая запрашивает ввод данных пользователем. Ту же форму можно сгенерировать с помощью таких помощников, как объект FORM.
Контроллер
def display_form():
form = FORM('Value:', INPUT(_value = 'name'), INPUT(_type = 'submit'))
return dict(form = form)
Вышеупомянутая функция в контроллере default.py включает объект FORM (помощник HTML), который помогает в создании формы.
Посмотреть
{{extend 'layout.html'}}
<h2>Basic form</h2>
{{= form}}
<h2>Submitted variables</h2>
{{= BEAUTIFY(request.vars)}}
Форма, которая порождается заявлением {{= form}}сериализует объект FORM. Когда пользователь заполняет форму и нажимает кнопку отправки, форма отправляется самостоятельно, а переменнаяrequest.vars.value вместе с его входным значением отображается внизу.
SQLFORM
Это помогает в создании формы для существующей базы данных. Шаги по его реализации обсуждаются ниже.
Устанавливая соединение с базой данных с помощью DAL, он создается с помощью объекта DAL, который также называется конструктором DAL. После установления соединения пользователь может создать соответствующую таблицу.
db = DAL('sqlite://storage.sqlite')
db.define_table('employee', Field('name', requires = IS_NOT_EMPTY()))
Таким образом, мы создали таблицу с именем «сотрудник». Контроллер создает форму и кнопку со следующими операторами:
form = SQLFORM(
db.mytable,
record = mytable_index,
deletable = True,
submit_button = T('Update')
)
Следовательно, для созданной таблицы сотрудников модификация в контроллере будет -
def display_form():
form = SQLFORM(db.person)
Нет изменений в View. В новом контроллере необходимо построить ФОРМУ, так как конструктор SQLFORM, построенный из таблицы db.employee, определен в модели. Новая форма после сериализации выглядит следующим образом:
<form enctype = "multipart/form-data" action = "" method = "post">
<table>
<tr id = "employee_name__row">
<td>
<label id = "person_name__label" for = "person_name">Your name: </label>
</td>
<td>
<input type = "text" class = "string" name = "name" value = "" id = "employee_name" />
</td>
<td></td>
</tr>
<tr id = "submit_record__row">
<td></td>
<td><input value = "Submit" type = "submit" /></td>
<td></td>
</tr>
</table>
<input value = "9038845529" type = "hidden" name = "_formkey" />
<input value = "employee" type = "hidden" name = "_formname" />
</form>
Все теги в форме имеют имена, производные от имени таблицы и поля.
An SQLFORMобъект также имеет дело с полями «загрузки», сохраняя загруженные файлы в папку «загрузки». Это делается автоматически. SQLFORM отображает «логические» значения в виде флажков и текстовых значений с помощью“textareas”.
SQLFORM также использует метод процесса. Это необходимо, если пользователь хочет сохранить значения в связанной SQLFORM.
Если form.process(keepvalues = True) тогда это принято.
пример
def display_form():
form = SQLFORM(db.employee)
if form.process().accepted:
response.flash = 'form accepted'
elif form.errors:
response.flash = 'form has errors'
else:
response.flash = 'please fill out the form'
return dict(form = form)
SQLFORM.factory
Иногда пользователю необходимо создать форму таким образом, чтобы существовала таблица базы данных без реализации базы данных. Пользователь просто хочет воспользоваться возможностями SQLFORM.
Это делается через form.factory и поддерживается в сеансе.
def form_from_factory():
form = SQLFORM.factory(
Field('your_name', requires = IS_NOT_EMPTY()),
Field('your_image', 'upload'))
if form.process().accepted:
response.flash = 'form accepted'
session.your_name = form.vars.your_name
session.your_image = form.vars.your_image
elif form.errors:
response.flash = 'form has errors'
return dict(form = form)
Форма будет выглядеть как SQLFORM с именем и изображением в качестве полей, но такой таблицы в базе данных нет.
Представление "default / form_from_factory.html" будет представлено как -
{{extend 'layout.html'}}
{{= form}}
CRUD методы
CRUD- это API, используемый поверх SQLFORM. Как следует из названия, он используется для создания, поиска, обновления и удаления соответствующей формы.
CRUD, по сравнению с другими API в web2py, не отображается; следовательно, необходимо, чтобы он был импортирован.
from gluon.tools import Crud
crud = Crud(db)
Определенный выше объект CRUD предоставляет следующий API -
Старший Нет | API и функциональность |
---|---|
1 | crud.tables() Возвращает список таблиц, определенных в базе данных. |
2 | crud.create(db.tablename) Возвращает форму создания для table tablename. |
3 | crud.read(db.tablename, id) Возвращает форму только для чтения для tablename и идентификатор записи. |
4 | crud.delete(db.tablename, id) удаляет запись |
5 | crud.select(db.tablename, query) Возвращает список записей, выбранных из таблицы. |
6 | crud.search(db.tablename) Возвращает кортеж (форма, записи), где форма - это форма поиска. |
7 | crud() Возвращает одно из вышеперечисленных на основе request.args (). |
Создание формы
Создадим форму. Следуйте приведенным ниже кодам.
Модель
Новая модель создается под modelsпапка приложения. Имя файла будет“dynamic_search.py”.
def build_query(field, op, value):
if op == 'equals':
return field == value
elif op == 'not equal':
return field != value
elif op == 'greater than':
return field > value
elif op == 'less than':
return field < value
elif op == 'starts with':
return field.startswith(value)
elif op == 'ends with':
return field.endswith(value)
elif op == 'contains':
return field.contains(value)
def dynamic_search(table):
tbl = TABLE()
selected = []
ops = ['equals',
'not equal',
'greater than',
'less than',
'starts with',
'ends with',
'contains']
query = table.id > 0
for field in table.fields:
chkval = request.vars.get('chk'+field,None)
txtval = request.vars.get('txt'+field,None)
opval = request.vars.get('op'+field,None)
row = TR(TD(INPUT(_type = "checkbox",_name = "chk"+field,value = chkval == 'on')),
TD(field),TD(SELECT(ops,_name = "op"+field,value = opval)),
TD(INPUT(_type = "text",_name = "txt"+field,_value = txtval)))
tbl.append(row)
if chkval:
if txtval:
query &= build_query(table[field], opval,txtval)
selected.append(table[field])
form = FORM(tbl,INPUT(_type="submit"))
results = db(query).select(*selected)
return form, results
Контроллер
Связанный файл, а именно “dynamic_search.py” в разделе контроллеров будет включен следующий код -
def index():
form,results = dynamic_search(db.things)
return dict(form = form,results = results)
Посмотреть
Мы можем отобразить это в следующем виде.
{{extend 'layout.html'}}
{{= form}}
{{= results}}
Вот как это выглядит -