laravel 登录html,laravel-html

这篇博客介绍了如何使用Spatie的laravel-html包来创建和操作HTML元素,包括动态生成表单、设置默认值、从模型中获取数据。此包提供了一个简单易读的API,使得在Laravel应用中构建HTML变得轻松。升级到2.0版的过程也很平滑,同时支持从session中填充表单字段,并且提供了详细的文档和变更日志。

Painless html generation ¶

laravel-html.svg?style=flat-square

license-MIT-brightgreen.svg?style=flat-square

master.svg?style=flat-square

laravel-html.svg?style=flat-square

shield?branch=master

laravel-html.svg?style=flat-square

This package helps you generate HTML using a clean, simple and easy to read API. All elements can be dynamically generated and put together. The HTML builder helps you generate dynamically assigned form elements based on your selected model, the session or a default value.

Documentation ¶

You'll find full documentation here.

Upgrading to 2.0 ¶

Version 2.0 was tagged because it could break some very specific cases, but you most likely don't have any work upgrading! Check out "Upgrading" for a detailed explanation.

Generating elements ¶

For example creating a new span element with a class is super easy with the fluent methods for elements:

html()->span()->text('Hello world!')->class('fa fa-eye');

Building forms ¶

Here's a quick example that builds a basic form with an e-mail input:

{{ html()->form('PUT', '/post')->open() }}

{{ html()->email('email')->placeholder('Your e-mail address') }}

{{ html()->form()->close() }}

The generated HTML will look like this:

Notice how the hidden _method and _token fields were automatically added and filled? You'll never forget to add csrf_field() again because now you simply wont have to anymore!

Another common use case might be to fill an input element based on the value that was previously submitted (using $request->old()). Worry no more, this has been taken care of as well. The above code will automatically fill in the email field if $session->old('email') exists. Amazing.

Models in the HTML builder ¶

The HTML builder can also generate elements based on a model:

{{ html()->modelForm($user)->open() }}

{{ html()->input('name') }}

{{ html()->closeModelForm() }}

The value of the name field will automatically be filled with the model's name property if available:

A "model" can be any object that implements ArrayAccess — anything from a complex Eloquent model to a plain array.

Postcardware ¶

You're free to use this package (it's MIT-licensed), but if it makes it to your production environment we highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using.

Our address is: Spatie, Samberstraat 69D, 2060 Antwerp, Belgium.

All postcards are published on our website.

Installation ¶

You can install the package via composer:

composer require spatie/laravel-html

Next, you must install the service provider:

// config/app.php

'providers' => [

...

Spatie\Html\HtmlServiceProvider::class,

];

And optionally register an alias for the facade.

// config/app.php

'aliases' => [

...

'Html' => Spatie\Html\Facades\Html::class,

];

Usage ¶

Concepts ¶

Elements—classes under the Spatie\Html\Elements namespace—are generally created via a Spatie\Html\Html builder instance.

html()->span()->text('Hello world!');

Element attributes and contents are modified via with fluent methods which return a new instance. This means element instances are immutable.

$icon = html()->span()->class('fa');

$icon->class('fa-eye'); // ''

$icon->class('fa-eye-slash'); // ''

Element classes don't have any knowledge of the outside world. Any coupling to other concepts, like requests and sessions, should happen in the builder class, not on the element classes.

By convention, we assume that builder methods will modify values to our advantage (like pulling old values from the session on a failed form request), and element methods will be deterministic.

// This will try to resolve an initial value, and fall back to 'hello@example.com'

$email = html()->email('email', 'hello@example.com');

// This will always have 'hello@example.com' as it's value

$email = html()->email('email')->value('hello@example.com');

Upgrading ¶

From v1 to v2 ¶

Version 2 was created because the typehints in version 1 was holding the package back in some cases (like multiple select which requires an array of values instead of a string which was assumed).

Luckily, bumping the version number in composer.json and running composer update should be non-breaking. Here are some caveats to look out for:

The package now ships with a html() function by default, which returns an instance of the Html builder class. If you've defined your own method, you'll need to remove it.

Various type hints have been removed throughout the package, if you've extended a class to override its methods, you'll need to update them accordingly (everything still behaves the same!)

Changelog ¶

Please see CHANGELOG for more information what has changed recently.

Testing ¶$ composer test

Contributing ¶

Please see CONTRIBUTING for details.

Security ¶

If you discover any security related issues, please email freek@spatie.be instead of using the issue tracker.

Credits ¶

About Spatie ¶

Spatie is a webdesign agency based in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.

License ¶

The MIT License (MIT). Please see License File for more information.

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值