VS Code 扩展巡礼

Wesley13
• 阅读 1126

本篇文章中介绍的扩展是 vscode-phpcs,用于项目开发中 PHP 代码的编码规范。

Github 库地址 vscode-phpcs[1].,使用这个扩展依赖于一个前置条件,系统需要安装 PHP_CodeSniffer[2]

VS Code 扩展巡礼

phpcs.png

官方是这么介绍这个扩展的https://github.com/shevaua/vscode-phpcs\[3\]

认识 PHP_CodeSniffer

PHP_CodeSniffer is an essential development tool that ensures your code remains clean and consistent.

在众多的第三方组织和相关的代码规范推荐中,PHP_CodeSniffer 是一款代码检查工具,用于规范团队开发中的类名,注释,参数等各个方面,帮助团队成员形成统一的编码风格。它本身可以与很多 IDE 结合,也提供了修改和指定自定义代码规范的功能。

PHP_CodeSniffer 包地址 PHP_CodeSniffer[4]Github 库地址 PHP_CodeSniffer[5]

PHP_CodeSniffer 安装

根据操作平台不同,PHP_CodeSniffer 有不同的安装 方式,集中于 Pear,Composer,和 Brew。

Linux 安装方式

pear install PHP_CodeSniffer

Brew 安装

Mac 下采用以下命令安装,最为方便

brew install php-code-sniffer

安装路径

/usr/local/Cellar/php-code-sniffer

/usr/local/Cellar/php-code-sniffer/3.4.1/bin

Composer 方式

composer global require squizlabs/php_codesniffer

安装路径

/Users/name/.composer/vendor/squizlabs/php_codesniffer/

ls

/Users/name/.composer/vendor/bin

文件夹下有两个文件 phpcbf phpcs

运行

./phpcs --version

可以查看版本号

PHP_CodeSniffer version 3.4.2 (stable) by Squiz (http://www.squiz.net)

Mac 下推荐使用 brew 安装 其它安装方式参考 Github 库PHP_CodeSniffer[6]

VS Code 中启用 PHP_CodeSniffer

VS Code 中启用 PHP_CodeSniffer 需要安装 phpcs 插件。

Before using this plugin, you must ensure that phpcs is installed on your system,The preferred method is using composer[7] for both system-wide and project-wide installations.

也就是说在 VS Code 中使用 phpcs 插件之前,需要在系统上安装有 phpcs,安装方法是依赖于 composer 方式,并且可以从系统级和项目级两个纬度选择安装。

如果只是在 VS Code 中安装插件,系统级中不安装 phpcs。会出现以下错误

phpcs: Request workspace/configuration failed with message: Unable to locate phpcs. Please add phpcs to your global path or use composer dependency manager to install it in your project locally.

还有一点,phpcs 插件只是 CS Code 中实现 PHP CodeSniffer 中的一个,还有很多其它插件也在做基于 PHP CodeSniiffer 的代码整洁优化工作。比如 EasyCodingStandard[8]

系统级全局安装

composer global require squizlabs/php_codesniffer

Changed current directory to /Users/wmm/.composer Using version ^3.4 for squizlabs/php_codesniffer ./composer.json has been updated Loading composer repositories with package information Updating dependencies (including require-dev) Package operations: 1 install, 0 updates, 0 removals

  • Installing squizlabs/php_codesniffer (3.4.0): Downloading (100%)
    Writing lock file Generating autoload files

项目级别的安装

以下是 VS Code 对于插件 phpcs 的介绍说明,更多参考 https://marketplace.visualstudio.com/items?itemName=ikappas.phpcs Project-wide Installation

The phpcs linter can be installed in your project using the Composer Dependency Manager for PHP.

  1. Install  compose [9].

  2. Require  phpcs package by typing the following at the root of your project in a terminal:

    composer require --dev squizlabs/php_codesniffer

phpcs 与 PHP Sniffer 关系

VS Code 还有另外一个插件 PHP Sniffer。在特性中写着两条

Runs phpcs to lint PHP code. Runs phpcbf to format fixable PHP code validation errors.`

显然可以推断 PHP Sniffer 也是对 PHP_CodeSniffer 的封装。验证后发现,这个插件可以不使用,phpcs 也可以运行的很好。

VS Code 扩展巡礼

VsCode插件巡礼-phpcs-图南科技

VS Code 扩展巡礼

VsCode插件巡礼-phpcs-图南科技-php-sniffer.png

如果同时安装 PHP Sniffer 和 phpcs 插件,但是没有安装 PHP_CodeSniffer 会出现以下错误

phpcs: Unable to locate phpcs. Invalid version string encountered!

PHP_CodeSniffer 典型使用

phpcs 目录下运行以下命令

./phpcs -i

使用规范

1 方法注释 参数,返回值三项用空行分割。

VS Code 扩展巡礼

phpcs.png

2 参数必须有注释,也识别空格,多个参数纵向需要对齐。

VS Code 扩展巡礼

对齐.png

3 每一行的代码长度不能超过一定的长度。

VS Code 扩展巡礼

最大长度.png

Line exceeds 85 characters; contains 98 characters

4 私有方法使用下划线 _ 开始。

Private method name " " must be prefixed with an underscore

关于 PSR

众所周知 PHP 语言是基于开源社区发展起来的,社区可以说又集中又分散,框架,类库数量众多,如何在最大程度上约束代码规范,趋向于统一和标准化,有一个组织在推进这个事情,那就是 FIG Framework Interop Group[10]。

phpcs 这些代码格式化工具也是以 PSR 为理论基础。

The Framework Interop Group[11] has proposed and approved a series of style recommendations.

One recommended way to use namespaces is outlined in PSR-4[12], which aims to provide a standard file, class and namespace convention to allow plug-and-play code.

业界最常用的规范标准成稿是 PSR4,这里 https://phptherightway.com/#code\_style\_guide\[13\] 是一篇关于代码规范的概要介绍,可以深入阅读。

总结

VS Code 中对于插件 phpcs 安装方式的介绍,实际上更多是 PHP_CodeSniffer 工具的安装介绍,插件的作用就是帮助项目与 PHP_CodeSniffer 做关联。

搭配 PHP 智能注释 这个插件 会有更完善的使用体验,自动为方法提供注释,再手动做细节调整。

Code Review 是保证团队代码质量的重要措施之一,而代码规范是 Code Review 的重要一环,代码规范又要借助于有效的工具,phpcs 就是这样的工具。

推动代码整洁,高效开发,培养工程师对于代码整洁度的洁癖和质量交付的严格约束。

VS Code 扩展巡礼

VS Code插件巡礼-phpcs-图南科技-CodeReview


文章已同步到公众号《图南科技》欢迎关注

参考资料

[1]

vscode-phpcs: https://github.com/shevaua/vscode-phpcs

[2]

PHP_CodeSniffer: https://pear.php.net/package/PHP\_CodeSniffer/

[3]

https://github.com/shevaua/vscode-phpcs: https://github.com/shevaua/vscode-phpcs

[4]

PHP_CodeSniffer: https://pear.php.net/package/PHP\_CodeSniffer/

[5]

composer: https://getcomposer.org/

[6]

EasyCodingStandard: https://marketplace.visualstudio.com/items?itemName=azdanov.vscode-easy-coding-standard

[7]

https://getcomposer.org/doc/00-intro.md: https://getcomposer.org/doc/00-intro.md

[8]

Framework Interop Group: https://www.php-fig.org/

[9]

PSR-4: https://www.php-fig.org/psr/psr-4/

[10]

https://phptherightway.com/#code\_style\_guide: https://phptherightway.com/#code\_style\_guide

◆ ◆ ◆ ◆ ◆

推荐阅读:

玩转VS Code

VS Code · 编程开发 · 业界资讯

VS Code 扩展巡礼

本文分享自微信公众号 - 玩转VS Code(vs_code)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
3年前
swap空间的增减方法
(1)增大swap空间去激活swap交换区:swapoff v /dev/vg00/lvswap扩展交换lv:lvextend L 10G /dev/vg00/lvswap重新生成swap交换区:mkswap /dev/vg00/lvswap激活新生成的交换区:swapon v /dev/vg00/lvswap
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Discuz X3.2源码解析 discuz_application类(转自百度)
1.discuz\_application在/source/class/discuz/discuz\_application.php中。!DiscuzX3.2源码解析discuz_application类(https://oscimg.oschina.net/oscnet/99b35d79caf70b7c74ad0838d6
Stella981 Stella981
3年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Wesley13 Wesley13
3年前
35岁是技术人的天花板吗?
35岁是技术人的天花板吗?我非常不认同“35岁现象”,人类没有那么脆弱,人类的智力不会说是35岁之后就停止发展,更不是说35岁之后就没有机会了。马云35岁还在教书,任正非35岁还在工厂上班。为什么技术人员到35岁就应该退役了呢?所以35岁根本就不是一个问题,我今年已经37岁了,我发现我才刚刚找到自己的节奏,刚刚上路。
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这