Laravel View module learning
This article mainly introduces you to the relevant information about the View module of the Laravel learning tutorial. The View module is introduced in great detail through sample code. It has certain reference learning value for everyone's study or work. Friends who need it Let’s learn together with the editor below.
Preface
This article mainly introduces to you the relevant information about the View module in Laravel, and shares it for your reference and study. The following words Not much more to say, let’s take a look at the detailed introduction.
This article is based on the analysis and writing of the routing module code of Laravel 5.4 version;
File structure
View The file format and functions of the module are shown in the figure below:
The approximate process of visual presentation:
1 , start the rendering of the view by calling the view() method;
2. First, find the view file;
(1) Traverse the path in sequence, if the file name With a namespace (that is, the part before ::), the path array corresponding to the namespace registration is used, otherwise the global path array (the paths variable in the Illuminate\View\FileViewFinder class) is used;
(2) Combine the current path, file name, and suffix name (the default order is blade.php, php, css) to determine whether the file exists;
(3) If the file does not exist, report an exception : The corresponding view file does not exist; if the file exists, the corresponding engine is called for parsing according to the suffix name;
3. If it is a css suffix, the file engine is used, and the core calling method is file_get_contents;
4. If it is a php suffix, use the php engine. The core calling method is
ob_start(); include $__path; ob_get_clean();
5. If it is a blade .php suffix, using blade engine;
This engine will take the initiative to cache. If the cache file has not expired, the cache file will be called directly. Otherwise, it will be recompiled and the cache file will be generated through sha1 (located in storage /framework/views directory);
##Blade engine compilation
protected $compilers = [ 'Comments', // 注释部分 'Extensions', // 扩展部分 'Statements', // 语句块 (@ 开头的指令) 'Echos', // 输出 ]; protected function parseToken($token) { list($id, $content) = $token; if ($id == T_INLINE_HTML) { foreach ($this->compilers as $type) { $content = $this->{"compile{$type}"}($content); } } }
Comment part
preg_replace("/{{--(.*?)--}}/s", '', $value);
Extension part
// 自定义的文本替换扩展 数组 protected $extensions = []; protected function compileExtensions($value) { foreach ($this->extensions as $compiler) { $value = call_user_func($compiler, $value, $this); } return $value; }
Instruction replacement
- View\Compilers\Concerns\CompilesAuthorizations: Permission Check
Instructions include: @can, @cannot, @elsecan, @elsecannot, @endcan, @endcannot
- Concerns\CompilesComponents: related to components and slots
Instructions include: @component, @endcomponent, @slot, @endslot
- Concerns\CompilesConditionals: related to judgment statements
Instructions include: @if, @unless, @else, @elseif, @endif, @endunless, @isset, @endisset, @hassection
##Concerns\CompilesIncludes: Embedded files -
Instructions include: @each, @include, @includeif, @includewhen
-
Instructions include: @inject
-
Instructions include: @extends, @section, @parent, @yield, @show, @append, @overwrite, @stop, @endsection
##Concerns\CompilesLoops: related to loops
Instructions include: @forelse, @empty, @endforelse, @endempty, @for, @foreach, @break, @continue, @endfor, @endforeach, @while, @endwhile -
Concerns\CompilesRawPhp: related to native PHP statements
Commands include: @php, @endphp, @unset -
Concerns\CompilesStacks: related to the stack
Instructions include: @stack, @push, @endpush, @prepend, @endprepend -
Instructions include: @lang, @endlang, @choice
##Concerns\CompilesTranslations: related to localization translation -
Echo replacement
echo output is for {!! !!} , {{ }}, {{{ }}} for regular replacement;
{!! !!} outputs unescaped characters, used to output native HTML tags value;
{{ }} normal output, supports ternary operator replacement;
{{{ }}} outputs escape characters, supports ternary operator operator replacement;
Ternary operator replacement refers to: {{ $a ?: "Default Value" }} (or {{$a or "Default Value"}}) Replacement Into {{ isset($a) ? $a : "Default value"}}
The above is the entire content of this article. I hope it will be helpful to everyone's learning. For more related content, please pay attention to PHP Chinese website!
Related recommendations:
Learning about transferring arrays to views in the Laravel5 framework
The model and controller of the Laravel 5 framework and the basics of views Process learning
The above is the detailed content of Laravel View module learning. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The latest versions of Laravel 9 and CodeIgniter 4 provide updated features and improvements. Laravel9 adopts MVC architecture and provides functions such as database migration, authentication and template engine. CodeIgniter4 uses HMVC architecture to provide routing, ORM and caching. In terms of performance, Laravel9's service provider-based design pattern and CodeIgniter4's lightweight framework give it excellent performance. In practical applications, Laravel9 is suitable for complex projects that require flexibility and powerful functions, while CodeIgniter4 is suitable for rapid development and small applications.

Compare the data processing capabilities of Laravel and CodeIgniter: ORM: Laravel uses EloquentORM, which provides class-object relational mapping, while CodeIgniter uses ActiveRecord to represent the database model as a subclass of PHP classes. Query builder: Laravel has a flexible chained query API, while CodeIgniter’s query builder is simpler and array-based. Data validation: Laravel provides a Validator class that supports custom validation rules, while CodeIgniter has less built-in validation functions and requires manual coding of custom rules. Practical case: User registration example shows Lar

Laravel - Artisan Commands - Laravel 5.7 comes with new way of treating and testing new commands. It includes a new feature of testing artisan commands and the demonstration is mentioned below ?

For beginners, CodeIgniter has a gentler learning curve and fewer features, but covers basic needs. Laravel offers a wider feature set but has a slightly steeper learning curve. In terms of performance, both Laravel and CodeIgniter perform well. Laravel has more extensive documentation and active community support, while CodeIgniter is simpler, lightweight, and has strong security features. In the practical case of building a blogging application, Laravel's EloquentORM simplifies data manipulation, while CodeIgniter requires more manual configuration.

When choosing a framework for large projects, Laravel and CodeIgniter each have their own advantages. Laravel is designed for enterprise-level applications, offering modular design, dependency injection, and a powerful feature set. CodeIgniter is a lightweight framework more suitable for small to medium-sized projects, emphasizing speed and ease of use. For large projects with complex requirements and a large number of users, Laravel's power and scalability are more suitable. For simple projects or situations with limited resources, CodeIgniter's lightweight and rapid development capabilities are more ideal.

The world of cryptocurrencies is always in flux, with new tokens capturing the attention of seasoned investors looking for the next big opportunity.

For small projects, Laravel is suitable for larger projects that require strong functionality and security. CodeIgniter is suitable for very small projects that require lightweight and ease of use.

Comparing Laravel's Blade and CodeIgniter's Twig template engine, choose based on project needs and personal preferences: Blade is based on MVC syntax, which encourages good code organization and template inheritance. Twig is a third-party library that provides flexible syntax, powerful filters, extended support, and security sandboxing.
