Kohana 3.2, отображение ошибок в форме - PullRequest
0 голосов
/ 15 января 2012

Я хотел бы отображать ошибки в моей форме, выделяя поля, в которых есть ошибки, и отображая текст ошибки рядом с полем.Если нет элегантного способа отображать рядом с каждым полем, выше будет хорошо.

Я нашел примеры из более ранних версий, но API, похоже, изменился, и они не работают для 3.2.

Это всего лишь проект, с которым я учу Кохану, так что это не критично.Я просто хочу знать, как "kohana" решить эту проблему.

В моем контроллере у меня есть это:

if (isset($_POST) && Valid::not_empty($_POST))
{
    $post = Validation::factory($_POST)
    ->rule('zipcode', 'not_empty'));

    if ($post->check()) {
        $errors = $post->errors('zipcode');
    }
}

$this->template->content = View::factory('myview', $data)
->bind('errors', $errors);

А вот моя форма в 'myview.php':

<?php echo Form::open(); ?>
<dl>
    <dt><?php echo Form::label('zipcode', 'Zip Code') ?></dt>
    <dd><?php echo Form::input('zipcode') ?></dd>
</dl>
<p><?php echo Form::submit(NULL, 'Get Records'); ?></p>
<?php echo Form::close(); ?>

Ответы [ 2 ]

3 голосов
/ 15 января 2012

Я воспользовался подходом расширения вспомогательного класса Form для добавления имени класса error в поля формы, а также для отображения сообщения об ошибке в метке поля.

<?php defined('SYSPATH') or die('No direct script access.');

class Form extends Kohana_Form {

    private static function attributes($name, & $attributes = NULL, $errors = NULL)
    {
        // Set the id attribute
        if (!isset($attributes['id']))
        {
            $attributes['id'] = $name;
        }

        if ($errors !== NULL)
        {
            // Merge in external validation errors.
            $errors = array_merge($errors, (isset($errors['_external']) ? $errors['_external'] : array()));

            // Set the error classname
            if (isset($errors[$name]))
            {
                $attributes['class'] = trim( (string) @$attributes['class'].' error-field');            
            }
        }
    }

    public static function input($name, $value = NULL, array $attributes = NULL, array $errors = NULL)
    {
        static::attributes($name, $attributes, $errors);

        return parent::input($name, $value, $attributes);
    }

    public static function select($name, array $options = NULL, $selected = NULL, array $attributes = NULL, array $errors = NULL)
    {
        static::attributes($name, $attributes, $errors);

        return parent::select($name, $options, $selected, $attributes);
    }

    public static function password($name, $value = NULL, array $attributes = NULL, array $errors = NULL)
    {
        static::attributes($name, $attributes, $errors);

        return parent::password($name, $value, $attributes);
    }

    public static function textarea($name, $body = '', array $attributes = NULL, $double_encode = TRUE, array $errors = NULL)
    {
        static::attributes($name, $attributes, $errors);

        return parent::textarea($name, $body, $attributes, $double_encode);
    }

    public static function file($name, array $attributes = NULL, array $errors = NULL)
    {
        static::attributes($name, $attributes, $errors);

        return parent::file($name, $attributes);
    }

    public static function label($input, $text = NULL, array $attributes = NULL, array $errors = NULL, $view = 'messages/label_error')
    {
        if ($errors !== NULL)
        {
            // Merge in external validation errors.
            $errors = array_merge($errors, (isset($errors['_external']) ? $errors['_external'] : array()));

            // Use the label_error view to append an error message to the label
            if (isset($errors[$input]))
            {
                $text .= View::factory($view)->bind('error', $errors[$input]);
            }
        }

        return parent::label($input, $text, $attributes);
    }    
} 

Затем вы передаете массив $errors в методы label и field helper:

<?php echo
    Form::label('username', 'Username', NULL, $errors),
    Form::input('username', $user->username, NULL, $errors);
?>

Эта идея была предложена на форумах Kohana, но я изо всех сил пытался найти оригинальную ветку. Во всяком случае, я обнаружил, что этот подход лучше всего подходит для меня.

[править] Посмотреть пример этого подхода в действии можно здесь: http://kohana3.badsyntax.co/contact (отправить форму)

0 голосов
/ 15 января 2012

Это пример кода, который я использовал для личного эксперимента с формами Kohana.Это часть контактной формы.Это должно работать для вас.

Код ниже показывает контактную форму.После того как пользователь отправляет форму, он отправляет отзыв (ошибка + ошибки / успех).

if (isset($errors) && count($errors) > 0)
{
    echo '<ul>';

    foreach ($errors as $error)
    {
        echo '<li>' . $error . '</li>';
    }

    echo '</ul>';
}
// form
echo Form::open(null);

    // fields
    echo Form::label('firstname') . Form::input('firstname', null, array('id' => 'firstname')) . '<br />';
    echo Form::label('email') . Form::input('email', null, array('id' => 'email')) . '<br />';
    echo Form::label('message') . Form::textarea('message', '', array('id' => 'message')) . '<br />';

    // submit
    echo Form::submit('submit', 'Send message');

echo Form::close();

В контроллере я проверяю форму и назначаю сообщения об ошибках и успехе представлению.

public function action_index()
{
    // make view
    $view = View::factory('pages/contact')
        ->bind('post', $post)
        ->bind('errors', $errors)
        ->bind('success', $success);

    // check if form is submitted
    if ($_POST)
    {
        // trim fields
        $post = array_map('trim', $_POST);

        $post = Validation::factory($_POST)
            ->rules('firstname', array(
                array('not_empty'),
                array('min_length', array(':value', '2'))
            ))
            ->rules('email', array(
                array('not_empty'),
                array('email')
            ))
            ->rule('message', 'not_empty');

        if ($post->check())
        {
            $success[] = 'Thank you for your message!';
        }
        else
        {
            $errors = $post->errors('contact');
        }
    }

    // view
    $this->response->body($view);
}

Надеюсь, это поможет!

...