在電腦科學中,文法糖(syntactic sugar)是指程式設計語言中可以更容易的表達一個操作的文法,它可以使程式員更加容易去使用這門語言:操作可以變得更加清晰、方便,或者更加符合程式員的編程習慣。
類型
Boolean
String
Array
全域變數
時間長不用總會忘記重新整理一下加深下印象
$_SERVER
SERVER_ADDR IP地址 127.0.0.1
SERVER_NAME 主機名稱 localhost
SERVER_SOFTWARE 伺服器類型 nginx
REMOTE_ADDR 用戶端IP. 127.0.0.1
s
$_FILES
$_FILES['file']['name'] 圖片原名稱
$_FILES['file']['type'] 圖片MIME類型
$_FILES['file']['size'] 圖片大小
$_FILES['file']['tmp_name'] 伺服器端臨時名稱
常量
const DEBUG = true;
運算子
echo $a <=> $b;/*當 $a < $b 時, 運算式返回 -1當 $a = $b 時, 表達是返回 0當 $a > $b 時, 運算式返回 1*/
$name = $_POST['name'] ?? ''; //如果前面的值不為null,則返回本身,否則返回後面的值
$name = $_POST['name'] ?: ''; ////如果前面的值不為null,則返回本身,否則返回後面的值
流程式控制制
操作符可以用來跳轉到程式中的另一位置。該目標位置可以用目標名稱加上冒號來標記,而跳轉指令是 goto 之後接上目標位置的標記。PHP 中的 goto 有一定限制,目標位置只能位於同一個檔案和範圍,也就是說無法跳出一個函數或類方法,也無法跳入到另一個函數。也無法跳入到任何迴圈或者 switch 結構中。可以跳出迴圈或者 switch,通常的用法是用 goto 代替多層的 break。
goto a;echo 'Foo';a:echo 'Bar';//輸出 Bar
函數
function dosum(...$arr){ $sum = 0; foreach($arr as $v){ $sum += $v; } return $sum;}$arr = [1, 2, 3, 4, 5];echo dosum(...$arr); // 輸出15echo dosum(1,2,3,4,5,6); //輸出21//TODO/**這個文法,我最近總在用。感覺還比較簡單。不過要注意伺服器版本。。最近入了一個坑。*/
也叫閉包函數,在JS中很常見。為了防止汙染全域範圍。5.3 以後PHP也支援了這種寫法
$test = function($name='Li'){ echo 'My name is '.$name;};$test();
如果想要從父範圍中繼承變數怎麼辦
//這裡定義一個預設的輸出名字的方式$tpl = 'My name is ';//使用 use() 來引用父級的變數,最後輸出結果與上邊一致 $test = function($name='Li') use($tpl) { echo $tpl.$name;};$test();
需要注意的是,閉包函數的父範圍,是定義它的範圍,不是調用的範圍
類和對象
namespace Foo{ class test{ } echo test::class; // 輸出 FOO\test, 在使用命名空間的情況非常有用}
1.trait 和 class 是相似的概念,但不能被執行個體化
2.一個類可以使用多個trait,優先順序是 class > trait > 父類繼承的方法
3.使用insteadof 來解決 tarit 衝突
4.使用as,來修改方法的存取控制
5.在trait中也可以使用tarit。和在class中用法一致
trait A { public function say(){ echo 'trait A'; }}trait B { public function say(){ echo 'trait B'; } public function walk(){ echo 'walk B'; }}class Person { use A, B{ B :: say insteadof A; // 使用B的say方法代替了A的say方法 walk as protected; // 將walk 設定為受保護的 }}$obj = new Person;$obj->say(); // echo trait A;$obj->walk(); // 提示不能訪問一個受保護的方法
6.在trait中使用, 屬性、靜態屬性、靜態方法、抽象類別都是被允許的。
trait Test { public static $obj; public $name = 1; static function createObj(){ return empty(self::$obj) ? new self : self::$obj; }}class son { use Test;}$obj = son::createObj();echo $obj->name; // echo 1echo $obj === $obj1 ? 0 : 1; // echo 1
該功能從語言內部角度考慮被命名為”後期靜態繫結”。”後期綁定”的意思是說,static:: 不再被解析為定義當前方法所在的類,而是在實際運行時計算的。也可以稱之為”靜態繫結”,因為它可以用於(但不限於)靜態方法的調用
乍一看,好像什麼也沒看懂。看看具體的代碼吧。
class A { public static function who() { echo __CLASS__; } public static function test() { self::who(); }}class B extends A { public static function who() { echo __CLASS__; }}B::test(); // echo A;// 上面是一個正常的調用, 輸出了 A// 當我們把 class A 的 test 方法修改一下。 將 self 改成 static 後class A { public static function who() { echo __CLASS__; } public static function test() { static::who(); }}class B extends A { public static function who() { echo __CLASS__; }}B::test(); // echo B;
總結:PHP5.3新增加了一類關鍵字,static 可以在調用函數的方法。用這個關鍵字,來實現了後期靜態繫結。
異常處理
比較簡單記錄一下
try{ throw new Execption('拋出異常');} catch (Execption $e){ //擷取異常 $error = $e->getMessage();}echo $error; //拋出異常