PageRenderTime 24ms CodeModel.GetById 12ms app.highlight 9ms RepoModel.GetById 1ms app.codeStats 0ms

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

https://github.com/wujingke/thinkphp
PHP | 218 lines | 108 code | 12 blank | 98 comment | 23 complexity | ac906b677f0ee217e4660c486e9aa4fa 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        }
112        // 页面缓存
113        ob_start();
114        ob_implicit_flush(0);
115        if('php' == strtolower(C('TMPL_ENGINE_TYPE'))) { // 使用PHP原生模板
116            $_content   =   $content;
117            // 模板阵列变量分解成为独立变量
118            extract($this->tVar, EXTR_OVERWRITE);
119            // 直接载入PHP模板
120            empty($_content)?include $templateFile:eval('?>'.$_content);
121        }else{
122            // 视图解析标签
123            $params = array('var'=>$this->tVar,'file'=>$templateFile,'content'=>$content,'prefix'=>$prefix);
124            Hook::listen('view_parse',$params);
125        }
126        // 获取并清空缓存
127        $content = ob_get_clean();
128        // 内容过滤标签
129        Hook::listen('view_filter',$content);
130        // 输出模板文件
131        return $content;
132    }
133
134    /**
135     * 自动定位模板文件
136     * @access protected
137     * @param string $template 模板文件规则
138     * @return string
139     */
140    public function parseTemplate($template='') {
141        if(is_file($template)) {
142            return $template;
143        }
144        $depr       =   C('TMPL_FILE_DEPR');
145        $template   =   str_replace(':', $depr, $template);
146        // 获取当前主题名称
147        $theme = $this->getTemplateTheme();
148
149        // 获取当前模块
150        $module   =  MODULE_NAME;
151        if(strpos($template,'@')){ // 跨模块调用模版文件
152            list($module,$template)  =   explode('@',$template);
153        }
154        // 获取当前主题的模版路径
155        if(!defined('THEME_PATH')){
156            if(C('VIEW_PATH')){ // 模块设置独立的视图目录
157                $tmplPath   =   C('VIEW_PATH');
158            }else{  // 定义TMPL_PATH 改变全局的视图目录到模块之外
159                $tmplPath   =   defined('TMPL_PATH')? TMPL_PATH.$module.'/' : APP_PATH.$module.'/'.C('DEFAULT_V_LAYER').'/';
160            }
161            define('THEME_PATH', $tmplPath.$theme);
162        }
163
164        // 分析模板文件规则
165        if('' == $template) {
166            // 如果模板文件名为空 按照默认规则定位
167            $template = CONTROLLER_NAME . $depr . ACTION_NAME;
168        }elseif(false === strpos($template, $depr)){
169            $template = CONTROLLER_NAME . $depr . $template;
170        }
171        $file   =   THEME_PATH.$template.C('TMPL_TEMPLATE_SUFFIX');
172        if(C('TMPL_LOAD_DEFAULTTHEME') && THEME_NAME != C('DEFAULT_THEME') && !is_file($file)){
173            // 找不到当前主题模板的时候定位默认主题中的模板
174            $file   =   dirname(THEME_PATH).'/'.C('DEFAULT_THEME').'/'.$template.C('TMPL_TEMPLATE_SUFFIX');
175        }
176        return $file;
177    }
178
179    /**
180     * 设置当前输出的模板主题
181     * @access public
182     * @param  mixed $theme 主题名称
183     * @return View
184     */
185    public function theme($theme){
186        $this->theme = $theme;
187        return $this;
188    }
189
190    /**
191     * 获取当前的模板主题
192     * @access private
193     * @return string
194     */
195    private function getTemplateTheme() {
196        if($this->theme) { // 指定模板主题
197            $theme = $this->theme;
198        }else{
199            /* 获取模板主题名称 */
200            $theme =  C('DEFAULT_THEME');
201            if(C('TMPL_DETECT_THEME')) {// 自动侦测模板主题
202                $t = C('VAR_TEMPLATE');
203                if (isset($_GET[$t])){
204                    $theme = $_GET[$t];
205                }elseif(cookie('think_template')){
206                    $theme = cookie('think_template');
207                }
208                if(!in_array($theme,explode(',',C('THEME_LIST')))){
209                    $theme =  C('DEFAULT_THEME');
210                }
211                cookie('think_template',$theme,864000);
212            }
213        }
214        defined('THEME_NAME') || define('THEME_NAME',   $theme);                  // 当前模板主题名称
215        return $theme?$theme . '/':'';
216    }
217
218}