标签:
通过composer安装扩展包. 在根目录的composer.json
文件中添加laravelcollective/html
.
"require": {
"laravelcollective/html": "5.3.*"
}
接着在终端中更新composer:
composer update
然后,在config/app.php文件中添加新的providers
:
‘providers‘ => [ // ... Collective\Html\HtmlServiceProvider::class, // ... ],
最后,在config/app.php中添加别名数组
:
‘aliases‘ => [ // ... ‘Form‘ => Collective\Html\FormFacade::class, ‘Html‘ => Collective\Html\HtmlFacade::class, // ... ],
{!! Form::open([‘url‘ => ‘foo/bar‘]) !!} // {!! Form::close() !!}
默认是post请求,你也可以使用其他请求:
echo Form::open([‘url‘ => ‘foo/bar‘, ‘method‘ => ‘put‘])
注意: HTML表单只支持
POST
和GET
,PUT
和DELETE方法
会被自动添加一个假的_method
隐藏字段到你的表单中.
You may also open forms that point to named routes or controller actions:你也可以打开指向到路由和控制器的表单:
echo Form::open([‘route‘ => ‘route.name‘]) echo Form::open([‘action‘ => ‘Controller@method‘])
还可以指定路由参数:
echo Form::open([‘route‘ => [‘route.name‘, $user->id]]) echo Form::open([‘action‘ => [‘Controller@method‘, $user->id]])
如果表单支持文件上传,添加files选项到数组中:
echo Form::open([‘url‘ => ‘foo/bar‘, ‘files‘ => true])
Laravel提供一种简单的方式保护你的应用防止跨域请求伪造,首先,你的session中会被置放一个随机的token,如果你使用 Form::open
方法,CSRF token会以隐藏字段的形式被自动添加到比表单中,或者,如果你想为隐藏的CSRF字段生成HTML,你可以使用token方法:
echo Form::token();
Route::post(‘profile‘, [ ‘before‘ => ‘csrf‘, function() { // } ] );
Often, you will want to populate a form based on the contents of a model. To do so, use the Form::model
method:
echo Form::model($user, [‘route‘ => [‘user.update‘, $user->id]])
Now, when you generate a form element, like a text input, the model‘s value matching the field‘s name will automatically be set as the field value. So, for example, for a text input named email
, the user model‘s email
attribute would be set as the value. However, there‘s more! If there is an item in the Session flash data matching the input name, that will take precedence over the model‘s value. So, the priority looks like this:
This allows you to quickly build forms that not only bind to model values, but easily re-populate if there is a validation error on the server!
Note: When using
Form::model
, be sure to close your form withForm::close
!
Laravel‘s Eloquent Accessor allow you to manipulate a model attribute before returning it. This can be extremely useful for defining global date formats, for example. However, the date format used for display might not match the date format used for form elements. You can solve this by creating two separate accessors: a standard accessor, and/or a form accessor.
To define a form accessor, create a formFooAttribute
method on your model where Foo
is the "camel" cased name of the column you wish to access. In this example, we‘ll define an accessor for the date_of_birth
attribute. The accessor will automatically be called by the HTML Form Builder when attempting to pre-fill a form field when Form::model()
is used.
<?php
namespace App;
use Carbon\Carbon;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
/**
* Get the user‘s first name.
*
* @param string $value
* @return string
*/
public function getDateOfBirthAttribute($value)
{
return Carbon::parse($value)->format(‘m/d/Y‘);
}
/**
* Get the user‘s first name for forms.
*
* @param string $value
* @return string
*/
public function formDateOfBirthAttribute($value)
{
return Carbon::parse($value)->format(‘Y-m-d‘);
}
}
echo Form::label(‘email‘, ‘E-Mail Address‘);
echo Form::label(‘email‘, ‘E-Mail Address‘, [‘class‘ => ‘awesome‘]);
Note: After creating a label, any form element you create with a name matching the label name will automatically receive an ID matching the label name as well.
echo Form::text(‘username‘);
echo Form::text(‘email‘, ‘example@gmail.com‘);
Note: The hidden and textarea methods have the same signature as the text method.
echo Form::password(‘password‘, [‘class‘ => ‘awesome‘]);
echo Form::email($name, $value = null, $attributes = []);
echo Form::file($name, $attributes = []);
echo Form::checkbox(‘name‘, ‘value‘);
echo Form::radio(‘name‘, ‘value‘);
echo Form::checkbox(‘name‘, ‘value‘, true);
echo Form::radio(‘name‘, ‘value‘, true);
echo Form::number(‘name‘, ‘value‘);
echo Form::date(‘name‘, \Carbon\Carbon::now());
echo Form::file(‘image‘);
Note: The form must have been opened with the
files
option set totrue
.
echo Form::select(‘size‘, [‘L‘ => ‘Large‘, ‘S‘ => ‘Small‘]);
echo Form::select(‘size‘, [‘L‘ => ‘Large‘, ‘S‘ => ‘Small‘], ‘S‘);
This will create an <option>
element with no value as the very first option of your drop-down.
echo Form::select(‘size‘, [‘L‘ => ‘Large‘, ‘S‘ => ‘Small‘], null, [‘placeholder‘ => ‘Pick a size...‘]);
echo Form::select(‘animal‘,[
‘Cats‘ => [‘leopard‘ => ‘Leopard‘],
‘Dogs‘ => [‘spaniel‘ => ‘Spaniel‘],
]);
echo Form::selectRange(‘number‘, 10, 20);
echo Form::selectMonth(‘month‘);
echo Form::submit(‘Click Me!‘);
Note: Need to create a button element? Try the button method. It has the same signature as submit.
It‘s easy to define your own custom Form class helpers called "macros". Here‘s how it works. First, simply register the macro with a given name and a Closure:
Form::macro(‘myField‘, function()
{
return ‘<input type="awesome">‘;
});
Now you can call your macro using its name:
echo Form::myField();
Custom Components are similar to Custom Macros, however instead of using a closure to generate the resulting HTML, Components utilize Laravel Blade Templates. Components can be incredibly useful for developers who use Twitter Bootstrap, or any other front-end framework, which requires additional markup to properly render forms.
Let‘s build a Form Component for a simple Bootstrap text input. You might consider registering your Components inside a Service Provider‘s boot
method.
Form::component(‘bsText‘, ‘components.form.text‘, [‘name‘, ‘value‘, ‘attributes‘]);
Notice how we reference a view path of components.form.text
. Also, the array we provided is a sort of method signature for your Component. This defines the names of the variables that will be passed to your view. Your view might look something like this:
// resources/views/components/form/text.blade.php
<div class="form-group">
{{ Form::label($name, null, [‘class‘ => ‘control-label‘]) }}
{{ Form::text($name, $value, array_merge([‘class‘ => ‘form-control‘], $attributes)) }}
</div>
Custom Components can also be created on the
Html
facade in the same fashion as on theForm
facade.
When defining your Custom Component‘s method signature, you can provide default values simply by giving your array items values, like so:
Form::component(‘bsText‘, ‘components.form.text‘, [‘name‘, ‘value‘ => null, ‘attributes‘ => []]);
Using our example from above (specifically, the one with default values provided), you can call your Custom Component like so:
{{ Form::bsText(‘first_name‘) }}
This would result in something like the following HTML output:
<div class="form-group">
<label for="first_name">First Name</label>
<input type="text" name="first_name" value="" class="form-control">
</div>
Generate a HTML link to the given URL.
echo link_to(‘foo/bar‘, $title = null, $attributes = [], $secure = null);
Generate a HTML link to the given asset.
echo link_to_asset(‘foo/bar.zip‘, $title = null, $attributes = [], $secure = null);
Generate a HTML link to the given named route.
echo link_to_route(‘route.name‘, $title = null, $parameters = [], $attributes = []);
Generate a HTML link to the given controller action.
echo link_to_action(‘HomeController@getIndex‘, $title = null, $parameters = [], $attributes = []);
https://laravelcollective.com/docs/5.3/html
标签:
原文地址:http://www.cnblogs.com/offcos/p/5840137.html