PageRenderTime 24ms CodeModel.GetById 16ms app.highlight 5ms RepoModel.GetById 1ms app.codeStats 0ms

/ThinkPHP/Library/Think/View.class.php

https://gitlab.com/yoage/thinkphp
PHP | 229 lines | 110 code | 13 blank | 106 comment | 22 complexity | cc442a36ebdeaaec107f784aa626c518 MD5 | raw file
  1<?php
  2// +----------------------------------------------------------------------
  3// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
  4// +----------------------------------------------------------------------
  5// | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.
  6// +----------------------------------------------------------------------
  7// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
  8// +----------------------------------------------------------------------
  9// | Author: liu21st <liu21st@gmail.com>
 10// +----------------------------------------------------------------------
 11namespace Think;
 12/**
 13 * ThinkPHP 视图类
 14 */
 15class View {
 16    /**
 17     * 模板输出变量
 18     * @var tVar
 19     * @access protected
 20     */ 
 21    protected $tVar     =   array();
 22
 23    /**
 24     * 模板主题
 25     * @var theme
 26     * @access protected
 27     */ 
 28    protected $theme    =   '';
 29
 30    /**
 31     * 模板变量赋值
 32     * @access public
 33     * @param mixed $name
 34     * @param mixed $value
 35     */
 36    public function assign($name,$value=''){
 37        if(is_array($name)) {
 38            $this->tVar   =  array_merge($this->tVar,$name);
 39        }else {
 40            $this->tVar[$name] = $value;
 41        }
 42    }
 43
 44    /**
 45     * 取得模板变量的值
 46     * @access public
 47     * @param string $name
 48     * @return mixed
 49     */
 50    public function get($name=''){
 51        if('' === $name) {
 52            return $this->tVar;
 53        }
 54        return isset($this->tVar[$name])?$this->tVar[$name]:false;
 55    }
 56
 57    /**
 58     * 加载模板和页面输出 可以返回输出内容
 59     * @access public
 60     * @param string $templateFile 模板文件名
 61     * @param string $charset 模板输出字符集
 62     * @param string $contentType 输出类型
 63     * @param string $content 模板输出内容
 64     * @param string $prefix 模板缓存前缀
 65     * @return mixed
 66     */
 67    public function display($templateFile='',$charset='',$contentType='',$content='',$prefix='') {
 68        G('viewStartTime');
 69        // 视图开始标签
 70        Hook::listen('view_begin',$templateFile);
 71        // 解析并获取模板内容
 72        $content = $this->fetch($templateFile,$content,$prefix);
 73        // 输出模板内容
 74        $this->render($content,$charset,$contentType);
 75        // 视图结束标签
 76        Hook::listen('view_end');
 77    }
 78
 79    /**
 80     * 输出内容文本可以包括Html
 81     * @access private
 82     * @param string $content 输出内容
 83     * @param string $charset 模板输出字符集
 84     * @param string $contentType 输出类型
 85     * @return mixed
 86     */
 87    private function render($content,$charset='',$contentType=''){
 88        if(empty($charset))  $charset = C('DEFAULT_CHARSET');
 89        if(empty($contentType)) $contentType = C('TMPL_CONTENT_TYPE');
 90        // 网页字符编码
 91        header('Content-Type:'.$contentType.'; charset='.$charset);
 92        header('Cache-control: '.C('HTTP_CACHE_CONTROL'));  // 页面缓存控制
 93        header('X-Powered-By:ThinkPHP');
 94        // 输出模板文件
 95        echo $content;
 96    }
 97
 98    /**
 99     * 解析和获取模板内容 用于输出
100     * @access public
101     * @param string $templateFile 模板文件名
102     * @param string $content 模板输出内容
103     * @param string $prefix 模板缓存前缀
104     * @return string
105     */
106    public function fetch($templateFile='',$content='',$prefix='') {
107        if(empty($content)) {
108            $templateFile   =   $this->parseTemplate($templateFile);
109            // 模板文件不存在直接返回
110            if(!is_file($templateFile)) E(L('_TEMPLATE_NOT_EXIST_').':'.$templateFile);
111        }else{
112            defined('THEME_PATH') or    define('THEME_PATH', $this->getThemePath());
113        }
114        // 页面缓存
115        ob_start();
116        ob_implicit_flush(0);
117        if('php' == strtolower(C('TMPL_ENGINE_TYPE'))) { // 使用PHP原生模板
118            $_content   =   $content;
119            // 模板阵列变量分解成为独立变量
120            extract($this->tVar, EXTR_OVERWRITE);
121            // 直接载入PHP模板
122            empty($_content)?include $templateFile:eval('?>'.$_content);
123        }else{
124            // 视图解析标签
125            $params = array('var'=>$this->tVar,'file'=>$templateFile,'content'=>$content,'prefix'=>$prefix);
126            Hook::listen('view_parse',$params);
127        }
128        // 获取并清空缓存
129        $content = ob_get_clean();
130        // 内容过滤标签
131        Hook::listen('view_filter',$content);
132        // 输出模板文件
133        return $content;
134    }
135
136    /**
137     * 自动定位模板文件
138     * @access protected
139     * @param string $template 模板文件规则
140     * @return string
141     */
142    public function parseTemplate($template='') {
143        if(is_file($template)) {
144            return $template;
145        }
146        $depr       =   C('TMPL_FILE_DEPR');
147        $template   =   str_replace(':', $depr, $template);
148
149        // 获取当前模块
150        $module   =  MODULE_NAME;
151        if(strpos($template,'@')){ // 跨模块调用模版文件
152            list($module,$template)  =   explode('@',$template);
153        }
154        // 获取当前主题的模版路径
155        defined('THEME_PATH') or    define('THEME_PATH', $this->getThemePath($module));
156
157        // 分析模板文件规则
158        if('' == $template) {
159            // 如果模板文件名为空 按照默认规则定位
160            $template = CONTROLLER_NAME . $depr . ACTION_NAME;
161        }elseif(false === strpos($template, $depr)){
162            $template = CONTROLLER_NAME . $depr . $template;
163        }
164        $file   =   THEME_PATH.$template.C('TMPL_TEMPLATE_SUFFIX');
165        if(C('TMPL_LOAD_DEFAULTTHEME') && THEME_NAME != C('DEFAULT_THEME') && !is_file($file)){
166            // 找不到当前主题模板的时候定位默认主题中的模板
167            $file   =   dirname(THEME_PATH).'/'.C('DEFAULT_THEME').'/'.$template.C('TMPL_TEMPLATE_SUFFIX');
168        }
169        return $file;
170    }
171
172    /**
173     * 获取当前的模板路径
174     * @access protected
175     * @param  string $module 模块名
176     * @return string
177     */
178    protected function getThemePath($module=MODULE_NAME){
179        // 获取当前主题名称
180        $theme = $this->getTemplateTheme();
181        // 获取当前主题的模版路径
182        $tmplPath   =   C('VIEW_PATH'); // 模块设置独立的视图目录
183        if(!$tmplPath){ 
184            // 定义TMPL_PATH 则改变全局的视图目录到模块之外
185            $tmplPath   =   defined('TMPL_PATH')? TMPL_PATH.$module.'/' : APP_PATH.$module.'/'.C('DEFAULT_V_LAYER').'/';
186        }
187        return $tmplPath.$theme;
188    }
189
190    /**
191     * 设置当前输出的模板主题
192     * @access public
193     * @param  mixed $theme 主题名称
194     * @return View
195     */
196    public function theme($theme){
197        $this->theme = $theme;
198        return $this;
199    }
200
201    /**
202     * 获取当前的模板主题
203     * @access private
204     * @return string
205     */
206    private function getTemplateTheme() {
207        if($this->theme) { // 指定模板主题
208            $theme = $this->theme;
209        }else{
210            /* 获取模板主题名称 */
211            $theme =  C('DEFAULT_THEME');
212            if(C('TMPL_DETECT_THEME')) {// 自动侦测模板主题
213                $t = C('VAR_TEMPLATE');
214                if (isset($_GET[$t])){
215                    $theme = $_GET[$t];
216                }elseif(cookie('think_template')){
217                    $theme = cookie('think_template');
218                }
219                if(!in_array($theme,explode(',',C('THEME_LIST')))){
220                    $theme =  C('DEFAULT_THEME');
221                }
222                cookie('think_template',$theme,864000);
223            }
224        }
225        defined('THEME_NAME') || define('THEME_NAME',   $theme);                  // 当前模板主题名称
226        return $theme?$theme . '/':'';
227    }
228
229}