使用laravel框架的`"illuminate/view"` ,該組件可以將視圖以模板的方式創建,在其他視圖中可以調用,繼承已經創建的模板,并通過模板語法使得視圖設計更加簡單,規范,高效
修改composer.json文件
~~~
{
"require": {
"illuminate/routing": "*",
"illuminate/events": "*",
"illuminate/database": "*",
"illuminate/view": "*"
},
"autoload": {
"psr-4": {
"App\\": "app/"
}
}
}
~~~
接著`composer update`命令完成視圖組件的添加.視圖組件的使用需要完成下面四個工作:
一是添加視圖模板和編譯文件的存儲路徑
二是對視圖進行相關配置和服務注冊
三是使用視圖文件
四是創建視圖模板文件
`"illuminate/view"` 組件將視圖模板文件編譯成普通的視圖文件存儲起來,所以首先需要添加相應的存儲路徑.這里依然按照laravel框架目錄結構添加2個文件路徑,其中視圖模板文件的存儲路徑為項目下的`"resources\views\"` ,編譯文件的存儲路徑為 項目目錄下的` "storage\framework\views\"` .接下來完成視圖組件的相關配置和服務注冊,這部分內容是在入口文件實現的
public/index.php
~~~
<?php
use Illuminate\Database\Capsule\Manager;
use Illuminate\Support\Fluent;
//調用自動加載文件,添加自動加載文件函數
require __DIR__.'/../vendor/autoload.php';
//實例化服務容器,注冊事件,路由服務提供者
$app = new Illuminate\Container\Container;
Illuminate\Container\Container::setInstance($app);
with(new Illuminate\Events\EventServiceProvider($app))->register();
with(new Illuminate\Routing\RoutingServiceProvider($app))->register();
//啟動ORM模塊并進行相關配置
$manager = new Manager();
$manager->addConnection(require '../config/database.php');
$manager->bootEloquent();
//視圖
$app->instance('config', new Fluent);
$app['config']['view.compiled'] = __DIR__.'/../storage/framework/views';
$app['config']['view.paths'] = [__DIR__.'/../resources/views'];
with(new Illuminate\View\ViewServiceProvider($app))->register();
with(new Illuminate\Filesystem\FilesystemServiceProvider($app))->register();
//加載路由
require __DIR__.'/../app/Http/routes.php';
//實例化請求分發處理請求
$request = Illuminate\Http\Request::createFromGlobals();
$response = $app['router']->dispatch($request);
//返回請求響應
$response->send();
~~~
**通過服務容器中的setInstance()靜態方法將服務容器實例添加為靜態屬性.這樣就可以在任何位置獲取服務容器的實例**
視圖模塊的配置稍微復雜一些,首先通過服務容器實例的instance()方法將服務名稱為`config`和`Illuminate\Support\Fluent`類的實例進行綁定,該類的實例主要用于存儲視圖模塊的配置信息.這里用到的配置信息分別是前文中創建的視圖模板文件和編譯文件存儲路徑,分別添加到配置實例中.接下來進行服務注冊,因為視圖模塊的使用需要文件模塊的支持,在下載視圖組件時,文件組件會作為依賴下載,所以可以直接使用文件組件的服務提供者進行服務注冊.然后就可以使用視圖組件了,這里在處理函數中使用視圖組件實現視圖的加載,其中路由文件與在控制器模塊中添加的相同,處理函數依然是index()函數
~~~
<?php
namespace App\Http\Controllers;
use App\Models\Student;
use Illuminate\Container\Container;
class WeclomeController
{
public function index()
{
$student = Student::first();
$data = $student->getAttributes();
$app = Container::getInstance();
$factory = $app->make('view');
return $factory->make('welcome')->with('data',$data);
}
}
~~~
首先通過服務容器的getInstance()靜態方法獲取服務容器的實例,然后通過服務容器獲取服務名稱為view的實例對象,即為視圖創建工廠類(Illuminate\View\Factory)實例,接著通過視圖創建工廠的make()方法來創建視圖實例對象,其中參數為視圖文件的名稱,實際上是在視圖模板文件路徑中查找對應的文件名的文件,視圖文件將在后面進行創建,最后通過視圖實例的with()方法添加數據,使其可以在視圖文件中使用
接下來進行視圖模板的創建,首先在視圖模板文件目錄中創建"welcome.blade.php"文件,該視圖組件規定模板文件要以".blade.php"為后綴,文件名要與視圖創建工廠的make()方法中的字符串參數相同
視圖文件 resources/views/welcome.blade.php
~~~
<h3>視圖中顯示學生信息</h3>
學生id: {{$data['id']}}; <br />
學生name: {{$data['name']}}; <br />
學生age: {{$data['age']}}; <br />
~~~
瀏覽器訪問下
- 書列表
- laravel框架關鍵技術
- 第一章 組件化開發與composer使用
- 簡介
- composer
- 添加路由組件
- 添加控制器模塊
- 添加模型組件
- 添加視圖組件
- 第三章 laravel框架中常用的php語法
- 匿名函數
- 文件包含
- 魔術方法
- 魔術常量
- 反射
- 后期靜態綁定
- traits
- 第四章 laravel框架中使用的HTTP協議基礎
- HTTP協議
- 數據庫
- 數據遷移
- 第六章 laravel框架中的設計模式
- IOC模式
- php核心技術與最佳實踐
- 第一章面向對象核心
- 反射
- 簡單ORM
- 異常和錯誤
- 接口
- 第二章,面向對象設計
- 設計原則
- 單一職責
- 接口隔離
- 開放封閉
- 替換原則
- 依賴倒置
- linux是怎么寫的呢?
- 第三章 正則表達
- 認識正則
- 第四章 php網絡技術應用
- HTTP協議詳解
- php和http相關函數
- 垃圾信息防御措施
- 現代操作系統
- 引論
- sql必知必會
- 限制結果
- 按位置排序
- where求職順序
- IN操作符
- like
- 函數
- group by
- 組合查詢
- 插入檢索出的數據
- 視圖
- 高性能mysql
- 第一章節 mysql架構與歷史
- mysql架構邏輯圖
- 連接與管理
- 優化與運行
- 讀寫鎖
- 鎖粒度
- 表鎖(table lock)
- 行級鎖(row lock)
- ACID
- 隔離級別
- 死鎖
- 隱式和顯式鎖定
- 多版本并發控制
- Innodb概覽
- 第四章節 Schema與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯