123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257 |
- <?php
- // +----------------------------------------------------------------------
- // | ThinkPHP [ WE CAN DO IT JUST THINK ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2006~2018 http://thinkphp.cn All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
- // +----------------------------------------------------------------------
- // | Author: liu21st <liu21st@gmail.com>
- // +----------------------------------------------------------------------
-
- namespace think;
-
- class View
- {
- /**
- * 模板引擎实例
- * @var object
- */
- public $engine;
-
- /**
- * 模板变量
- * @var array
- */
- protected $data = [];
-
- /**
- * 内容过滤
- * @var mixed
- */
- protected $filter;
-
- /**
- * 全局模板变量
- * @var array
- */
- protected static $var = [];
-
- /**
- * 初始化
- * @access public
- * @param mixed $engine 模板引擎参数
- * @return $this
- */
- public function init($engine = [])
- {
- // 初始化模板引擎
- $this->engine($engine);
-
- return $this;
- }
-
- public static function __make(Config $config)
- {
- return (new static())->init($config->pull('template'));
- }
-
- /**
- * 模板变量静态赋值
- * @access public
- * @param mixed $name 变量名
- * @param mixed $value 变量值
- * @return $this
- */
- public function share($name, $value = '')
- {
- if (is_array($name)) {
- self::$var = array_merge(self::$var, $name);
- } else {
- self::$var[$name] = $value;
- }
-
- return $this;
- }
-
- /**
- * 清理模板变量
- * @access public
- * @return void
- */
- public function clear()
- {
- self::$var = [];
- $this->data = [];
- }
-
- /**
- * 模板变量赋值
- * @access public
- * @param mixed $name 变量名
- * @param mixed $value 变量值
- * @return $this
- */
- public function assign($name, $value = '')
- {
- if (is_array($name)) {
- $this->data = array_merge($this->data, $name);
- } else {
- $this->data[$name] = $value;
- }
-
- return $this;
- }
-
- /**
- * 设置当前模板解析的引擎
- * @access public
- * @param array|string $options 引擎参数
- * @return $this
- */
- public function engine($options = [])
- {
- if (is_string($options)) {
- $type = $options;
- $options = [];
- } else {
- $type = !empty($options['type']) ? $options['type'] : 'Think';
- }
-
- if (isset($options['type'])) {
- unset($options['type']);
- }
-
- $this->engine = Loader::factory($type, '\\think\\view\\driver\\', $options);
-
- return $this;
- }
-
- /**
- * 配置模板引擎
- * @access public
- * @param string|array $name 参数名
- * @param mixed $value 参数值
- * @return $this
- */
- public function config($name, $value = null)
- {
- $this->engine->config($name, $value);
-
- return $this;
- }
-
- /**
- * 检查模板是否存在
- * @access public
- * @param string|array $name 参数名
- * @return bool
- */
- public function exists($name)
- {
- return $this->engine->exists($name);
- }
-
- /**
- * 视图过滤
- * @access public
- * @param Callable $filter 过滤方法或闭包
- * @return $this
- */
- public function filter($filter)
- {
- if ($filter) {
- $this->filter = $filter;
- }
-
- return $this;
- }
-
- /**
- * 解析和获取模板内容 用于输出
- * @access public
- * @param string $template 模板文件名或者内容
- * @param array $vars 模板输出变量
- * @param array $config 模板参数
- * @param bool $renderContent 是否渲染内容
- * @return string
- * @throws \Exception
- */
- public function fetch($template = '', $vars = [], $config = [], $renderContent = false)
- {
- // 模板变量
- $vars = array_merge(self::$var, $this->data, $vars);
-
- // 页面缓存
- ob_start();
- if (version_compare(PHP_VERSION, '8.0', '>=')) {
- ob_implicit_flush(false);
- } else {
- ob_implicit_flush(0);
- }
-
- // 渲染输出
- try {
- $method = $renderContent ? 'display' : 'fetch';
- $this->engine->$method($template, $vars, $config);
- } catch (\Exception $e) {
- ob_end_clean();
- throw $e;
- }
-
- // 获取并清空缓存
- $content = ob_get_clean();
-
- if ($this->filter) {
- $content = call_user_func_array($this->filter, [$content]);
- }
-
- return $content;
- }
-
- /**
- * 渲染内容输出
- * @access public
- * @param string $content 内容
- * @param array $vars 模板输出变量
- * @param array $config 模板参数
- * @return mixed
- */
- public function display($content, $vars = [], $config = [])
- {
- return $this->fetch($content, $vars, $config, true);
- }
-
- /**
- * 模板变量赋值
- * @access public
- * @param string $name 变量名
- * @param mixed $value 变量值
- */
- public function __set($name, $value)
- {
- $this->data[$name] = $value;
- }
-
- /**
- * 取得模板显示变量的值
- * @access protected
- * @param string $name 模板变量
- * @return mixed
- */
- public function __get($name)
- {
- return $this->data[$name];
- }
-
- /**
- * 检测模板变量是否设置
- * @access public
- * @param string $name 模板变量名
- * @return bool
- */
- public function __isset($name)
- {
- return isset($this->data[$name]);
- }
- }
|