PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化

這篇文章主要介紹了PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化文章都會(huì)有所收獲,下面我們一起來看看吧。

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、網(wǎng)頁空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、海南網(wǎng)站維護(hù)、網(wǎng)站推廣。

在我們?nèi)粘i_發(fā)中,一定少不了 PHP CS Fixer 來幫我們統(tǒng)一代碼風(fēng)格,但是PHP CS Fixer 不像 ESLint 一樣,可以在 PHPStorm 中在保存時(shí)自動(dòng)執(zhí)行。

PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化

PHPStorm 并沒有為我們提供可執(zhí)行 PHP CS Fixer 的選項(xiàng),「重新格式化代碼」大部分時(shí)都不能滿足我們的需求。

為此我們需要在 PHPStorm 中添加一個(gè) 「File Watcher」來自動(dòng)執(zhí)行代碼格式化。

1.首先全局安裝 PHP CS Fixer

composer global require friendsofphp/php-cs-fixer

2.執(zhí)行

php-cs-fixer

PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化

代表安裝成功了,如果提示命令未找到,那么你需要將全局 composer vendor 目錄添加到全局變量,我用的是 zsh,這里改成你自己的。

echo 'export PATH="$HOME/.composer/vendor/bin:$PATH"' >> ~/.zshrc

3.打開 PHPStorm,添加自定義文件

PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化

程序文件地址,命令行輸入,并填入

which php-cs-fixer

PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化

參數(shù)欄:

fix $FileDir$/$FileName$

到這就搞定了,現(xiàn)在每當(dāng)我們保存時(shí)就會(huì)自動(dòng)執(zhí)行 php-cs-fixer,現(xiàn)在還有一個(gè)問題,是可能每個(gè)項(xiàng)目有不同的 .php-cs.dist 格式化配置文件,以上的配置是使用了全局 php-cs-fixer 配置文件,如果要使用單獨(dú)的配置文件,需要修改配置如下:

fix --config=$ProjectFileDir$/.php-cs.dist $FileDir$/$FileName$

.php-cs.dist 通常放在項(xiàng)目根目錄。

最后附上 .php-cs.dist 配置文件

<?php
$header = <<<'EOF'EOF;$finder =  PhpCsFixer\Finder::create()
            ->exclude('tests/Fixtures')   //排除文件
            ->in(__DIR__);return PhpCsFixer\Config::create()
    ->setRiskyAllowed(true)
    ->setRules([
        '@PSR2'                                 => true,
        '@Symfony:risky'                        => true,
        'array_syntax'                          => ['syntax' => 'short'],
        'combine_consecutive_unsets'            => true,   //多個(gè)unset,合并成一個(gè)
        // one should use PHPUnit methods to set up expected exception instead of annotations
        'general_phpdoc_annotation_remove'      => ['expectedException', 'expectedExceptionMessage', 'expectedExceptionMessageRegExp'], //phpdocs中應(yīng)該省略已經(jīng)配置的注釋
        //'header_comment'                        => array('header' => $header), //添加,替換或者刪除 header 注釋。
        'heredoc_to_nowdoc'                     => true,     //刪除配置中多余的空行和/或者空行。
        'no_extra_consecutive_blank_lines'      => ['break', 'continue', 'extra', 'return', 'throw', 'use', 'parenthesis_brace_block', 'square_brace_block', 'curly_brace_block'],
        'no_unreachable_default_argument_value' => false, //在函數(shù)參數(shù)中,不能有默認(rèn)值在非缺省值之前的參數(shù)。有風(fēng)險(xiǎn)
        'no_useless_else'                       => true,  //刪除無用的eles
        'no_useless_return'                     => true,  //刪除函數(shù)末尾無用的return
        'no_empty_phpdoc'                       => true,  // 刪除空注釋
        'no_empty_statement'                    => true,  //刪除多余的分號(hào)
        'no_leading_namespace_whitespace'       => true,  //刪除namespace聲明行包含前導(dǎo)空格
        'no_spaces_inside_parenthesis'          => true,  //刪除括號(hào)后內(nèi)兩端的空格
        'no_trailing_whitespace'                => true,  //刪除非空白行末尾的空白
        'no_unused_imports'                     => true,  //刪除未使用的use語句
        'no_whitespace_before_comma_in_array'   => true,  //刪除數(shù)組聲明中,每個(gè)逗號(hào)前的空格
        'no_whitespace_in_blank_line'           => true,  //刪除空白行末尾的空白
        'ordered_class_elements'                => false, //class elements排序
        'ordered_imports'                       => false, // use 排序
        'phpdoc_add_missing_param_annotation'   => true,   //添加缺少的 Phpdoc @param參數(shù)
        'phpdoc_trim'                           => true,
        //   'phpdoc_trim_consecutive_blank_line_separation' => true, //刪除在摘要之后和PHPDoc中的描述之后,多余的空行。
        'phpdoc_order'                          => true,
        'psr4'                                  => true,
        // 'strict_comparison'                     => true,   //嚴(yán)格比較,會(huì)修改代碼有風(fēng)險(xiǎn)
        //'strict_param'                          => true,
        'ternary_operator_spaces'               => true,  //標(biāo)準(zhǔn)化三元運(yùn)算的格式
        'ternary_to_null_coalescing'            => true,  //盡可能使用null合并運(yùn)算符??。需要PHP> = 7.0。
        'whitespace_after_comma_in_array'       => true, // 在數(shù)組聲明中,每個(gè)逗號(hào)后必須有一個(gè)空格
        'trim_array_spaces'                     => true,  //刪除數(shù)組首或尾隨單行空格
        'align_multiline_comment'               => [                   //每行多行 DocComments 必須有一個(gè)星號(hào)(PSR-5),并且必須與第一行對(duì)齊。
            'comment_type' => 'phpdocs_only'
        ],
        'array_indentation'                 => true,  //數(shù)組的每個(gè)元素必須縮進(jìn)一次
    ])
    ->setFinder($finder);

關(guān)于“PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站欄目:PHPStorm如何實(shí)現(xiàn)自動(dòng)執(zhí)行代碼格式化
本文路徑:http://muchs.cn/article26/gheejg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營(yíng)銷推廣、微信公眾號(hào)網(wǎng)站內(nèi)鏈、品牌網(wǎng)站設(shè)計(jì)、、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管