單字母函數D、F、S、C、L、A、I 他們都在ThinkPHP核心的ThinkPHP/Mode/Api/functions.php這個文件中定義.
下面我分別說明一下他們的功能:
D() 加載Model類
M() 加載Model類
A() 加載Action類
L() 獲取語言定義
C() 獲取配置值 用法就是 C("這裡填寫在配置文件裡數組的下標")
S() 全局緩存配置 用法S(“這裡相當於一個唯一的標識”)
F() 快速文件數據讀取和保存 針對簡單類型數據 字符串、數組
I() 快速創建一個對象實例
此處附帶:ThinkPHP內置所有函數的原型定義
1 <?php 2 3 /** 4 * Think API模式函數庫 5 */ 6 7 /** 8 * 獲取和設置配置參數 支持批量定義 9 * @param string|array $name 配置變量 10 * @param mixed $value 配置值 11 * @param mixed $default 默認值 12 * @return mixed 13 */ 14 function C($name=null, $value=null,$default=null) {} 15 16 /** 17 * 加載配置文件 支持格式轉換 僅支持一級配置 18 * @param string $file 配置文件名 19 * @param string $parse 配置解析方法 有些格式需要用戶自己解析 20 * @return void 21 */ 22 function load_config($file,$parse=CONF_PARSE) {} 23 24 /** 25 * 拋出異常處理 26 * @param string $msg 異常消息 27 * @param integer $code 異常代碼 默認為0 28 * @return void 29 */ 30 function E($msg, $code=0) {} 31 32 /** 33 * 記錄和統計時間(微秒)和內存使用情況 34 * 使用方法: 35 * <code> 36 * G('begin'); // 記錄開始標記位 37 * // ... 區間運行代碼 38 * G('end'); // 記錄結束標簽位 39 * echo G('begin','end',6); // 統計區間運行時間 精確到小數後6位 40 * echo G('begin','end','m'); // 統計區間內存使用情況 41 * 如果end標記位沒有定義,則會自動以當前作為標記位 42 * 其中統計內存使用需要 MEMORY_LIMIT_ON 常量為true才有效 43 * </code> 44 * @param string $start 開始標簽 45 * @param string $end 結束標簽 46 * @param integer|string $dec 小數位或者m 47 * @return mixed 48 */ 49 function G($start,$end='',$dec=4) {} 50 51 /** 52 * 獲取和設置語言定義(不區分大小寫) 53 * @param string|array $name 語言變量 54 * @param string $value 語言值 55 * @return mixed 56 */ 57 function L($name=null, $value=null) {} 58 59 /** 60 * 添加和獲取頁面Trace記錄 61 * @param string $value 變量 62 * @param string $label 標簽 63 * @param string $level 日志級別 64 * @param boolean $record 是否記錄日志 65 * @return void 66 */ 67 function trace($value='[think]',$label='',$level='DEBUG',$record=false) {} 68 69 /** 70 * 編譯文件 71 * @param string $filename 文件名 72 * @return string 73 */ 74 function compile($filename) {} 75 76 /** 77 * 獲取輸入參數 支持過濾和默認值 78 * 使用方法: 79 * <code> 80 * I('id',0); 獲取id參數 自動判斷get或者post 81 * I('post.name','','htmlspecialchars'); 獲取$_POST['name'] 82 * I('get.'); 獲取$_GET 83 * </code> 84 * @param string $name 變量的名稱 支持指定類型 85 * @param mixed $default 不存在的時候默認值 86 * @param mixed $filter 參數過濾方法 87 * @return mixed 88 */ 89 function I($name,$default='',$filter=null) {} 90 91 /** 92 * 設置和獲取統計數據 93 * 使用方法: 94 * <code> 95 * N('db',1); // 記錄數據庫操作次數 96 * N('read',1); // 記錄讀取次數 97 * echo N('db'); // 獲取當前頁面數據庫的所有操作次數 98 * echo N('read'); // 獲取當前頁面讀取次數 99 * </code> 100 * @param string $key 標識位置 101 * @param integer $step 步進值 102 * @return mixed 103 */ 104 function N($key, $step=0,$save=false) {} 105 106 /** 107 * 字符串命名風格轉換 108 * type 0 將Java風格轉換為C的風格 1 將C風格轉換為Java的風格 109 * @param string $name 字符串 110 * @param integer $type 轉換類型 111 * @return string 112 */ 113 function parse_name($name, $type=0) {} 114 115 /** 116 * 優化的require_once 117 * @param string $filename 文件地址 118 * @return boolean 119 */ 120 function require_cache($filename) {} 121 122 /** 123 * 區分大小寫的文件存在判斷 124 * @param string $filename 文件地址 125 * @return boolean 126 */ 127 function file_exists_case($filename) {} 128 129 /** 130 * 導入所需的類庫 同java的Import 本函數有緩存功能 131 * @param string $class 類庫命名空間字符串 132 * @param string $baseUrl 起始路徑 133 * @param string $ext 導入的文件擴展名 134 * @return boolean 135 */ 136 function import($class, $baseUrl = '', $ext=EXT) {} 137 138 /** 139 * 基於命名空間方式導入函數庫 140 * load('@.Util.Array') 141 * @param string $name 函數庫命名空間字符串 142 * @param string $baseUrl 起始路徑 143 * @param string $ext 導入的文件擴展名 144 * @return void 145 */ 146 function load($name, $baseUrl='', $ext='.php') {} 147 148 /** 149 * 快速導入第三方框架類庫 所有第三方框架的類庫文件統一放到 系統的Vendor目錄下面 150 * @param string $class 類庫 151 * @param string $baseUrl 基礎目錄 152 * @param string $ext 類庫後綴 153 * @return boolean 154 */ 155 function vendor($class, $baseUrl = '', $ext='.php') {} 156 157 /** 158 * D函數用於實例化模型類 格式 [資源://][模塊/]模型 159 * @param string $name 資源地址 160 * @param string $layer 模型層名稱 161 * @return Model 162 */ 163 function D($name='',$layer='') {} 164 165 /** 166 * M函數用於實例化一個沒有模型文件的Model 167 * @param string $name Model名稱 支持指定基礎模型 例如 MongoModel:User 168 * @param string $tablePrefix 表前綴 169 * @param mixed $connection 數據庫連接信息 170 * @return Model 171 */ 172 function M($name='', $tablePrefix='',$connection='') {} 173 174 /** 175 * 解析資源地址並導入類庫文件 176 * 例如 module/controller addon://module/behavior 177 * @param string $name 資源地址 格式:[擴展://][模塊/]資源名 178 * @param string $layer 分層名稱 179 * @return string 180 */ 181 function parse_res_name($name,$layer,$level=1) {} 182 183 /** 184 * A函數用於實例化控制器 格式:[資源://][模塊/]控制器 185 * @param string $name 資源地址 186 * @param string $layer 控制層名稱 187 * @param integer $level 控制器層次 188 * @return Controller|false 189 */ 190 function A($name,$layer='',$level='') {} 191 192 /** 193 * 遠程調用控制器的操作方法 URL 參數格式 [資源://][模塊/]控制器/操作 194 * @param string $url 調用地址 195 * @param string|array $vars 調用參數 支持字符串和數組 196 * @param string $layer 要調用的控制層名稱 197 * @return mixed 198 */ 199 function R($url,$vars=array(),$layer='') {} 200 201 /** 202 * 執行某個行為 203 * @param string $name 行為名稱 204 * @param Mixed $params 傳入的參數 205 * @return void 206 */ 207 function B($name, &$params=NULL) {} 208 209 /** 210 * 去除代碼中的空白和注釋 211 * @param string $content 代碼內容 212 * @return string 213 */ 214 function strip_whitespace($content) {} 215 216 /** 217 * 浏覽器友好的變量輸出 218 * @param mixed $var 變量 219 * @param boolean $echo 是否輸出 默認為True 如果為false 則返回輸出字符串 220 * @param string $label 標簽 默認為空 221 * @param boolean $strict 是否嚴謹 默認為true 222 * @return void|string 223 */ 224 function dump($var, $echo=true, $label=null, $strict=true) {} 225 226 /** 227 * URL重定向 228 * @param string $url 重定向的URL地址 229 * @param integer $time 重定向的等待時間(秒) 230 * @param string $msg 重定向前的提示信息 231 * @return void 232 */ 233 function redirect($url, $time=0, $msg='') {} 234 235 /** 236 * 緩存管理 237 * @param mixed $name 緩存名稱,如果為數組表示進行緩存設置 238 * @param mixed $value 緩存值 239 * @param mixed $options 緩存參數 240 * @return mixed 241 */ 242 function S($name,$value='',$options=null) {} 243 244 /** 245 * 快速文件數據讀取和保存 針對簡單類型數據 字符串、數組 246 * @param string $name 緩存名稱 247 * @param mixed $value 緩存值 248 * @param string $path 緩存路徑 249 * @return mixed 250 */ 251 function F($name, $value='', $path=DATA_PATH) {} 252 253 /** 254 * 根據PHP各種類型變量生成唯一標識號 255 * @param mixed $mix 變量 256 * @return string 257 */ 258 function to_guid_string($mix) {} 259 260 /** 261 * XML編碼 262 * @param mixed $data 數據 263 * @param string $root 根節點名 264 * @param string $item 數字索引的子節點名 265 * @param string $attr 根節點屬性 266 * @param string $id 數字索引子節點key轉換的屬性名 267 * @param string $encoding 數據編碼 268 * @return string 269 */ 270 function xml_encode($data, $root='think', $item='item', $attr='', $id='id', $encoding='utf-8') {} 271 272 /** 273 * 數據XML編碼 274 * @param mixed $data 數據 275 * @param string $item 數字索引時的節點名稱 276 * @param string $id 數字索引key轉換為的屬性名 277 * @return string 278 */ 279 function data_to_xml($data, $item='item', $id='id') {} 280 281 /** 282 * session管理函數 283 * @param string|array $name session名稱 如果為數組則表示進行session設置 284 * @param mixed $value session值 285 * @return mixed 286 */ 287 function session($name,$value='') {} 288 /** 289 * Cookie 設置、獲取、刪除 290 * @param string $name cookie名稱 291 * @param mixed $value cookie值 292 * @param mixed $options cookie參數 293 * @return mixed 294 */ 295 function cookie($name, $value='', $option=null) {} 296 297 /** 298 * 加載動態擴展文件 299 * @return void 300 */ 301 function load_ext_file($path) {} 302 /** 303 * 獲取客戶端IP地址 304 * @param integer $type 返回類型 0 返回IP地址 1 返回IPV4地址數字 305 * @return mixed 306 */ 307 function get_client_ip($type = 0) {} 308 309 /** 310 * 發送HTTP狀態 311 * @param integer $code 狀態碼 312 * @return void 313 */ 314 function send_http_status($code) {} 315 316 // 過濾表單中的表達式 317 function filter_exp(&$value) {} 318 319 // 不區分大小寫的in_array實現 320 function in_array_case($value,$array) {}