天天看點

現在寫 PHP,你應該知道這些現在寫 PHP,你應該知道這些

現在寫 PHP,你應該知道這些

2015-10-21    分類:

WEB開發

程式設計開發 首頁精華 2人評論

     來源:

Scholer's Blog

分享到:

更多 3

首先你應該是在用 PHP 5.3 以上的版本,如果 PHP 版本在這之下,是時候該更新了。我建議如果有條件,最好使用最新的版本。

你應該看過 

PHP The Right Way

,這篇文章包含了很多内容,而且還能再擴充開。大部分的名詞和概念你都需要了解。

現在寫 PHP,你應該知道這些現在寫 PHP,你應該知道這些

1. PSR

The idea behind the group is for project representatives to talk about the commonalities between our projects and find ways we can work together.

在之前的文章中以及跟同僚交流的過程中我多次提到過 PSR(PHP Standard Recommendation)。很多人以為 PSR 隻是做一些規範代碼風格等無關痛癢的事情,但其實遠不止此。

PSR 的一系列标準文檔由 

php-fig

 (PHP Framework Interop Group)起草和投票決議,投票成員中有一些主流架構和擴充的作者,包括 Laravel、Symfony、Yii等等。

按照其官網的說法,這個組織的目的并不是告訴你你應該怎麼做,隻是一些主流的架構之間互相協商和約定。但是我相信這些架構和擴充中總會有你用到的。

PSR 目前通過的共有 6 份文檔:

  • 0:自動加載(主要是針對 PHP 5.3 以前沒有命名空間的版本)
  • 1:編碼規範
  • 2:編碼風格推薦
  • 3:Log 結果
  • 4:自動加載更細(在出現命名空間後有很大的改變)
  • 7:HTTP 消息接口

目前在起草(Draft)中的還有 PSR-5(PHPDoc Standard)、PSR-6(Cache)等。5 和 6 沒有出現在以上的清單中,是因為還沒有投票通過。

我相信随着标準的不斷更新,你會發現研究這些約定對你也是很有裨益的,雖然未必什麼都要遵守。

Nobody in the group wants to tell you, as a programmer, how to build your application.

2. Composer

Composer is a tool for dependency management in PHP. It allows you to declare the libraries your project depends on and it will manage (install/update) them for you.

composer 和 Pear、Pecl 都不同,它不僅僅是用于安裝擴充,更重要的是定義了一種現代 PHP 架構的實作和擴充管理的方法。類似 node.js 的 npm、Python 的 pip 但又比以上做的更多。

composer 的核心是實作擴充的标準安裝和類的自動加載。通過 

packagist.org

 這個平台,無數的擴充元件可以被很友善的引入,目前比較知名的 PHP 擴充都可以通過 composer 安裝了。而調用僅僅隻需要加載一個 autoload.php 的檔案即可。

composer 是通過 spl_autoload_register 方法注冊一個自動加載方法實作擴充類和檔案的加載的,當然這中間 composer 也做了一個優化。

我們都知道 PHP 引入檔案要通過 include 和 require 實作,這其實寫起來并不好看。 PHP 5.3 提供了命名空間,這本來和檔案引入也不相幹。但是 composer 實作了 PSR-4(在老版本的 PHP 上是 PSR-0),使用use 時通過調用 spl_autoload_register 實作的方法在調用時加載所需要的類,在寫法上類似 Python 的 import,既美觀也起到了按需加載、延遲加載的作用。

3. php-cs-fixer

The PHP Coding Standards Fixer tool fixes most issues in your code when you want to follow the PHP coding standards as defined in the PSR-1 and PSR-2 documents.

這個工具的作用是按照 PSR-1 和 PSR-2 的規範格式化你的代碼,還有一些可選的編碼風格是 Symfony 的規範。

這個其實本來并沒有那麼值得一說,隻是最近在幾個開源架構中都看到了 .php_cs 的檔案,一時好奇,深究下去才發現了這個項目。

項目位址:

https://github.com/FriendsOfPHP/PHP-CS-Fixer

具體的使用和配置方法在其項目首頁上都有介紹。這個組織的名字也很有趣:

FriendsOfPHP

。主要的成員大概是來自 Symfony 項目中。

可能有人覺得糾結代碼風格的問題其實沒有特别大的必要。要說好處我也說不上來,如果你覺得程式設計不僅僅是一份工作,那這就跟你收拾房間一樣,邋遢的房間不影響你吃飯睡覺,但幹淨的看起來更舒服。如果要和别人合作,那這件事情就更重要了。

4. PsySH

A runtime developer console, interactive debugger and REPL for PHP.
PsySH

 類似 Python 的 IDLE 的一個 PHP 的互動運作環境。這個是我在 Laravel 中發現的,Laravel 5 的artisan tinker 的功能是通過它來實作的。Laravel 4 中用的是另外一個項目:

boris

這個主要是在平時測試一些 php 的簡單的函數和特性的時候可以友善使用。遇到一些不确定的事情、比如empty 的使用等,可以用它來做些測試。

5. 一些架構群組件

架構

我比較喜歡的是 Laravel,目前公司在用的是 Yii2,我關注的有 Symfony 以及 Phalcon (C語言實作)。用什麼不用什麼,主要是喜好,有時候也由不得自己選擇,但研究一下,多一分了解也未嘗不可。

提到 Laravel 很多人都會立馬想到 Ruby on Rails。我想模仿或者抄襲這都不是主要的目的,主要的目的是提供給開發者一個更好的工具。Laravel 好在它有一個不一樣的路由控制(不帶 Action 字尾或字首的),有一個好用的 ORM (Eloquent),好用的模闆引擎 (Blade) 亦或有一個顔值比較高的文檔(社群看到的話)等等。

強大有時候也會被人诟病龐大,但這在于你需要了解自己項目的中長期規劃,項目現在的大小以及未來的大小及承載。

Larval 的核心實作是一個容器(Container)以及 PHP 的反射類(ReflectionClass)(Yii 2 也是一樣)。要了解這些,多看文章和文檔的同時,也可以看看源碼。

Symfony 2 提供了很多元件。

http-kernel

 和 

http-foundation

 在 Laravel 中也有被繼承過來直接使用。它是值得了解和學習的。

CodeIgniter 是一個小巧而強大的架構。雖然 CI 并沒有使用 Composer 元件的方式進行開發,但 3.0 以後的版本也加入了 Composer 的支援(這無非就是多一個 vendor 的目錄,引入 autoload.php)的檔案。

ORM

ORM 亦或 Active Record 我覺得還是需要的。也許有人認為 PHP 就是一個模闆引擎、就應該手寫 SQL 。不要被這些話所困擾。

CodeIgniter 中 Active Record 的實作方式很輕巧,但對于 CI 本身的體量來說,已經是很好用的了。

Laravel 實作的 Eloquent 我是很喜歡的,也可以內建到别的項目中去。Symfony 2 使用的是 

Doctrine

 ,這個項目也值得關注。Yii 2 也有自己的一套實作方式。

模闆引擎

模闆引擎需要做三件事情:

  1. 變量值的輸出(echo),
  2. 條件判斷和循環(if … else、for、foreach、while)
  3. 引入或繼承自其他檔案

Laravel 實作的 Blade 是一個比較輕量好用的模闆引擎。不過目前并不是很好能夠引入到其他架構中。十一的時候閑來無事試圖将其引入到 Yii 2 中,現在還隻是簡單的實作,我希望後面能将 Blade 的解析部分單獨抽取出來做一個輕量的實作。在 Github 上搜一下發現也有人在做同樣的事情。

Yii 2 似乎更推薦就用原生的 PHP 去寫,不過也提供了支援 Smarty 和 Twig 的擴充。Symfony 2 則采用了 Twig。

Twig

 和 Symfony 以及上文提到的 php-cs-fixer 都是 SensioLabs 的作品。

Smarty 是一個古老而頑強的模闆引擎。說實話我并不是太喜歡,其文法過于複雜,變量指派這些事情都有自己的一套做法。現在的版本中更是使用 Lexer 的方式來解析檔案,感覺像是用 PHP 實作了另外一種語言。項目裡面還有一些太長的正規表達式、太複雜的實作,我覺得這是一件很危險很容易出錯的事情。