如何優雅的使用 phpStorm
按照慣例依然是從百科上復制一條簡介: PhpStorm 是 JetBrains 公司開發的一款商業的 PHP 集成開發工具。PhpStorm可隨時幫助用戶對其編碼進行調整,運行單元測試或者提供可視化debug功能和智能HTML/CSS/JavaScript/PHP編輯、代碼質量分析、版本控制集成(SVN、GIT)、調試和測試等功能。另外,它還是跨平台。在Windows和MacOS下都可以使用。PhpStorm-讓開發更智能,而不是更困難。
聽說phpStorm 10支持php7呃
優點
- 跨平台。
- 對PHP支持refactor功能。
- 自動生成phpdoc的注釋,非常方便進行大型編程。
- 內置支持Zencode。
- 生成類的繼承關系圖,如果有一個類,多次繼承之后,可以通過這個功能查看他所有的父級關系。
- 支持代碼重構,方便修改代碼。
- 擁有本地歷史記錄功能(local history功能)。
- 方便的部署,可以直接將代碼直接upload到服務器。
總之它很牛逼就是了,什么都能干
快捷鍵
phpStorm有非常非常多並且好用的的快捷鍵,我下面就舉一些經常用的的快捷鍵演示,還有一些不常用的就不舉例了,絕對能提高你開發的效力率...
(Windows與Mac類似,只要把command
鍵換成ctrl
)
查詢相關
command + f
查找當前文件command + r
查找替換command + e
打開最近的文件command + shift + o
快速查詢文件command + shift + f
關鍵字查找,更強大的查詢器(機器不好的,最好還是先確定一下目錄)command + shift + r
高級替換command + alt + b
找到當剪類的所有子類alt + shift + c
查找最近修改的文件alt + f7
直接查詢選中的字符ctrl + f7
文件中查詢選中字符command + 鼠標點擊
跳到類或方法或變量等聲明處command + shift + tab
切換tab頁文件command + shift + +,-
展開或縮起command + .
折疊或展開選中的代碼
自動代碼
alt + 回車
導入包,自動修正command + n
快事為每個成員屬性生成 getter 及 setter 方法ctrl + i
快速生成插入魔術方法ctrol + o
復寫父類方法command + alt + l
對當前文件進行格式化排版command + d
復制當剪行command + /
// 注釋command + shift + /
// 注釋
以command + n
舉個例子
我創建了一個Person
類在/Entity/
目錄下,然后我設置一些私有的屬性如下代碼:
namespace Entity;
class Person
{
private $sign = '';
private $name = '';
private $age = 0;
private $work = '';
private $sex = '女';
}
然后咱們使用command + n
在彈出來的窗口選擇"PHPDoc Blocks..." 如下圖:
再再彈出的窗口選擇所有屬性再點"OK":
namespace Entity;
/**
* Class Person
* @package Entity
*/
class Person
{
/**
* @var string
*/
private $sign = '';
/**
* @var string
*/
private $name = '';
/**
* @var int
*/
private $age = 0;
/**
* @var string
*/
private $work = '';
/**
* @var string
*/
private $sex = '女';
}
然后它就對剛剛所選擇屬性加上了注釋...... 是不是灰常神奇。
ok,咱們繼續,再次使用command + n
鍵選擇Contructor...
彈出需要進行傳參賦值的屬性:
/**
* Person constructor.
* @param string $sign
*/
public function __construct($sign)
{
$this->sign = $sign;
}
如果不選擇的話將不需要對成員屬性進行設置。
然后咱們再來看看其他功能,比如"Implement Methods..."這個是快速生成魔術方法。
通常咱們設置、獲取一個成員屬性時最好不要直接使用$person->name = $name
這種方式進行設置參數或取得參數值,建議是對每個屬性都開放一個 getter
跟 setter
方法,這樣可以很方便得對傳進或傳出去的值進行處理,這就是上面我為什么要把成員屬性設置置為私有的原因之一
同樣的command + n
選擇"Getters and Stetters" 然后選擇所有屬性,它就會把所有的屬性設置getter
及setter
方法,這里要注意的是Person
的sign
是唯一的,不可進行修改,所以咱們要把設置sign
的方法去掉。注意: 最好setter
方法設置完后返回當剪對象,這樣的話咱們就可以連寫了並且phpStorm的提示還相當友好下面有例子:
/**
* @return string
*/
public function getSign()
{
return $this->sign;
}
/**
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* @param string $name
* @return $this
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* @return int
*/
public function getAge()
{
return $this->age;
}
/**
* @param int $age
* @return $this
*/
public function setAge($age)
{
$this->age = $age;
return $this;
}
/**
* @return string
*/
public function getWork()
{
return $this->work;
}
/**
* @param string $work
* @return $this
*/
public function setWork($work)
{
$this->work = $work;
return $this;
}
/**
* @var string
*/
private $sex = '女';
/**
* @return string
*/
public function getSex()
{
return $this->sex;
}
/**
* @param string $sex
* @return $this
*/
public function setSex($sex)
{
$this->sex = $sex;
return $this;
}
連寫的例子:
use Entity\Person;
$person = new Person();
$person->setName("蛋蛋")
->setAge(17)
->setWork('student');
最后再演示一個快速復寫被繼承類的功能。咱們新建一個Man
類,然后繼承Person
類,上面的Person類缺省是女性別,所以我們需要重寫它並且加上"中國男人"。同樣的使用command + n
打開快捷窗口選擇 "Override Methods..." 彈出來可被復寫的方法:
然后咱們選擇getSex
跟setSex
方法,然后確定,在Man
方法下生成以下方法。
namespace Entity;
/**
* Class Man
* @package Entity
*/
class Man extends Person
{
/**
* @return string
*/
public function getSex()
{
return parent::getSex(); // TODO: Change the autogenerated stub
}
/**
* @param int $sex
* @return $this
*/
public function setSex($sex)
{
return parent::setSex($sex); // TODO: Change the autogenerated stub
}
}
咱們把return parent::getSex()
跟return parent::setSex( $age )
刪除掉,不需要這樣,然后改成如下模式。
/**
* @return string
*/
public function getSex()
{
if ( ! mb_strpos(parent::getSex(), "中國") )
return "中國".parent::getSex();
return parent::getSex();
}
/**
* @param int $sex
* @return $this
*/
public function setSex($sex)
{
if( ! mb_strpos($sex, "中國") )
$sex = "中國".$sex;
return parent::setSex($sex);
}
碉堡了有木有。
工具類等
看起來好多的樣紙,我懶,不想講可不可以?我就挑幾個好不好?
- 連拉ssh 照着配就行了,很簡單
- composer 這個也很明了吧,不多說了,平時咱們都是通過命令行來實現的
- vagrant 這個phpstorm 10集成了vagrant,介於咱們自己已經搭建好了自己的vagrant環境,就不使用phpstorm所集成的啦
參考: 《使用Virtual Box和Vagrant搭建開發環境》
Database 工具
phpStorm所集成的database工具十分強大,當然它還有單獨的database工具叫做: DataGrip,當然需要獨立購買,咱們phpStorm有集成,就使用它好啦哈哈....(咱們的PhpStorm可是花錢買的,請支持正版)
Database工具一般在右側欄,如果沒有的話搜一下就好了,多簡單的事兒呀...
開始創建一個數據庫連接吧...
選擇如上圖的那個"+"號,然后選擇Data Source
數據來源,再選擇數據庫類型,一般咱們都是使用mysql吧,這次咱們試試新的,比如SQLite
選擇sqlite
數據文件的地址,然后選擇驅動,如果沒有的話得先下載安裝sqlite的驅動插件,這個很簡單,在Driver下有提示,照做就是了...
咱們先看一下mysql的配制吧...
mysql的也非常簡單,如果需要ssh/ssl連接的話,需要在SSH/SSL選項卡上配配地址入連接密碼或sshkey...
配制好了,打開選擇的數據庫:
上圖是連接的數據庫的表及表字段信息... 來演示一下查詢... 點擊那"QL"樣的dos窗口圖標會彈出一個tab頁,咱們可以在這里寫sql語句。
咱們查詢User
表下的所有數據,可以看到會有相當提示,這是相當的好使啊...查詢完成后在下面的Database Console
上會有顯示表數據,可對它進行修改,等等操作增加數據也可以。
快捷鍵command + alt + l
不但對代碼進行格式化,也sql語句也是非常有效的,如上圖。
在"Database Console"欄上點"Output"選項卡可以查看sql語句執行的情況、記錄及所消耗的時間等等信息...
command + 回車
執行sql語句或執行選中的sql語句
關於database工具的用法還有很多很多,我就不一一講解了,大家可以自己慢慢去研究,真的非常好用
CVS 和 Git
command + k
command + shift + k
關於FTP的配制,由於我不推薦使用,所以這里就不多說啦!
都到這了,那咱們就說說在phpStorm上如何使用git工具吧
算了,還是舉一個例子吧,配辣么多太累了,一會我看下有沒有已經配好的,如果有的話一會拉出來截個圖看看就行吧,反正現在svn用得也比較少了,還是git用得爽,分布式嘛,離線嘛,多好...關於svn -> git可以參考我之前寫的一篇文章
從git服務器上把代碼抓到本地
選擇CVS -> Checkout from Version Control -> Git
在彈出的窗口輸入自己的git倉庫信息:
注意 conle 的時間如果沒有設置你的github賬號的話可能會提示你輸入賬號信息,咱們輸入就行了。如果需要修改的話則在設置里面進行修改,咱們可以使用command + ,
打開"Preferences" 然后找到"Version Control"選項目的"GitHub"進行設置,還有"Git"路徑。
從mster創建分支
創建分支以通過命令行進行創建,咱們可以通過phpstrom的窗口進行創建,如下:
這個東西在右下角,"Git:master" 然后彈出上面窗口選擇"New Branch" 然后輸入新分支的名稱就好了,它會自動切換到新分支下。
是不是超級簡單呀...
提交代碼至遠程分支
當咱們修改完代碼后,咱們需要把代碼提交到遠程分支上,使用快捷鍵command + k
提交相當修改后的代碼,雙擊文件可以進行對比。在"Commit Message"寫上修改的東西然后點提交,這時就把代碼提交到本地分支上了。
不使用快捷鍵的話,可以使用"CVS -> Commit Changes"提交,也會彈出下面窗口...
提交到本地分支后,咱們需要把代碼推到遠程分支上,所以需要使用快捷鍵: command + shif + k
提交遠程分支...
也可以使用"CVS -> Git -> Push"進行提交...效果是一樣的
注意svn木有 command + shift + k
這一步
合並分支
分並非常簡單,只要選擇需要合並的分支,然后merge就行了,如下圖:
這樣就合並完成,當然,如果有沖突的話會提交有沖突,並讓你解決,如果沒有的話就直接合並成功了...然后就可以push了......
Compare
是對合並的分支進行對比...
使用svn...
灰常抱歉,我電腦上木有找到相關Svn項目的代碼,就不多說了...
安裝插件
這里講一個javascript 的安裝,使用快捷鍵cmd + ,
打開 Preferances
安裝 JavaScript 插件
Languages & Frameworks
-> Javascript
-> Libraries
選擇add需要的框架
安裝symfony2插件,搜索插件,然后點install
然后重啟phpStorm 就完事了....
注意
- 灰色+波浪線: 變量未使用
- 黃色波浪線: 變量未名單詞拼寫問題
- 紅色波浪線: 變量未定義
- 還有好多我就不一一舉例了,可能是因為我代碼寫得太好,出錯的東西比較少吧...
右邊欄出現紅色,這點是必須要杜絕的,好的代碼不應該出現紅色的任何提示...一旦出現一定要馬上解決,好的代碼不應該出現一個黃、紅色的提示。
TODO 表示待辦事件,當提交到vcs、svn或git的時候,會提示是還有未處理的事件,需要確認提交。
寫得有點多了,想寫的東西比較多,要不分兩篇寫好了?算了,我比較懶,就這樣吧,等我以后想寫了再寫吧,謝謝閱讀
其實有很多東西可以寫的,我只是想偷懶而已......