## 模板渲染
在控制器里面模板渲染,可以使用基類封裝好的 fetch 方法;
> ThinkCT 設置的模板文件名分隔符是`/`,模板后綴名為`html`
常見 fetch 調用方法如下:
1.不帶任何參數:
~~~
return $this->fetch();
~~~
系統會按照默認規則自動定位模板文件,其規則是:
~~~
當前主題目錄/當前應用/當前控制器(小寫+下劃線)/當前操作(小寫)+.html
~~~
2.指定渲染當前控制器下的某個模板文件
~~~
return $this->fetch('edit');
~~~
模板定位規則是:
~~~
當前主題目錄/當前應用/當前控制器(小寫+下劃線)/edit.html
~~~
3.指定渲染某個控制器下的某個模板文件
~~~
return $this->fetch('UserArticle/list');
~~~
模板定位規則是:
~~~
當前主題目錄/當前應用/user_article/list.html
~~~
4.跨模塊渲染模板(非特殊情況下這種方法在 thinkct 中不推薦使用)
~~~
return $this->fetch('portal@UserArticle/list');
~~~
模板定位規則是:
~~~
當前主題目錄/portal/user_article/list.html
~~~
5.從視圖根目錄開始讀取模板
~~~
return $this->fetch('/list');
~~~
或
~~~
return $this->fetch(':list');
~~~
模板定位規則是:
~~~
當前主題目錄/當前應用/list.html
~~~
> 注:以上調用方式,控制器和操作并不要求有實際對應的控制器和操作,它只是目錄名稱和文件名稱而已;
6.渲染實際存在的模板文件
~~~
return $this->fetch('./themes/home/index.html');
~~~
## 內容渲染
有時你的模板內容可能存在數據庫或者其它地方,需要直接解析內容,而不用通過模板文件,這時就可以使用控制器的`display`方法
~~~
$content='你的模板內容';
return $this->display($content);
~~~
> 注:渲染的內容中一樣可以使用模板引擎的相關標簽。
- 序言
- 基礎
- 功能介紹
- 目錄結構
- 正版申明
- 安裝教程
- 狀態參數
- 第三方接口
- 店鋪狀態
- 控制器
- 控制器定義
- 控制器模板賦值
- 控制器模板渲染
- 前臺控制器
- 前臺用戶控制器
- 后臺控制器
- 跳轉,AJAX返回和重定向
- URL生成
- 請求
- 請求信息
- 輸入變量
- 請求類型
- 獲取請求頭信息
- 偽靜態
- 更多
- 系統函數
- user_info 用戶數據信息
- add_payment 創建支付訂單
- 系統預覽
- 前臺預覽
- 后臺預覽
- 數據庫
- 數據庫配置
- 添加數據
- 更新數據
- 查詢數據
- 刪除數據
- 事務操作
- 更多數據庫操作
- 模型
- 模型定義
- 添加數據
- 更新數據
- 查詢數據
- 刪除數據
- API
- 站點接口
- 滾動幻燈
- 商品列表
- 商品信息
- 購買商品
- 用戶接口
- 個人信息
- 用戶登錄
- 用戶注冊
- 用戶退出
- 充值接口
- 在線充值
- 支付回調
- 訂單接口
- 訂單列表
- 其他接口
- 規范
- 狀態碼說明
- 版本號
- API路由
- 模板標簽
- 模板常量
- 普通標簽
- 變量輸出
- 系統變量
- 請求參數
- 使用函數
- 使用默認值
- 使用運算符
- 三元運算
- 原樣輸出
- 模板注釋
- 模板目錄
- 包含文件
- 模板布局
- 系統標簽
- 全局標簽
- 源碼標簽
- 服務標簽
- 網站標簽
- 域名標簽
- 任務標簽
- 需求標簽
- 推廣標簽
- 菜單標簽
- 內置標簽
- 循環輸出標簽
- 比較標簽
- 條件判斷
- 標簽嵌套
- 原生PHP
- 定義標簽
- 專題
- 緩存
- Session
- Cookie
- 分頁
- 驗證碼
- 文件上傳
- 第三方擴展
- Swoole
- 擴展插件
- 社會化登錄