<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Compiler Related on arjenzhou</title><link>/categories/compiler-related/</link><description>Recent content in Compiler Related on arjenzhou</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Wed, 03 Jul 2019 00:00:00 +0000</lastBuildDate><atom:link href="/categories/compiler-related/feed.xml" rel="self" type="application/rss+xml"/><item><title>The analysis and modification of rules of ESLint</title><link>/article/2019/07/the-analysis-and-modification-of-eslint-rules/</link><pubDate>Wed, 03 Jul 2019 00:00:00 +0000</pubDate><guid>/article/2019/07/the-analysis-and-modification-of-eslint-rules/</guid><description>&lt;blockquote&gt;
&lt;p&gt;每个互联网大厂都有自己的编码规范，而对规范审查需要有代码扫描平台来对工程师的能力进行评估。在实习的两个月中，我负责的工作的一部分包括代码规范扫描方向，其中对 ESLint 以及 fecs 规则的修改及调整也包括在内。ESLint 在内部保留了一个仓库用于 JS 的规范检查，由于内部代码规范的问题，不可能直接将外部的拿来直接使用。对很少接触 JS 的我来说，npm 的包管理方式冗杂而烦乱，同时该模块是被集成在整个扫描平台中的，所以很少有有效的文档用来参考，通过不断地测试最后终于解决了该部分问题。&lt;/p&gt;
&lt;/blockquote&gt;
&lt;p&gt;规则 &lt;strong&gt;no-new&lt;/strong&gt; 要求 使用 &lt;strong&gt;new&lt;/strong&gt; 关键字必须将其赋值给一个变量，如:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"&gt;&lt;code class="language-JS" data-lang="JS"&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#66d9ef"&gt;var&lt;/span&gt; &lt;span style="color:#a6e22e"&gt;Vue&lt;/span&gt; &lt;span style="color:#f92672"&gt;=&lt;/span&gt; &lt;span style="color:#66d9ef"&gt;new&lt;/span&gt; &lt;span style="color:#a6e22e"&gt;Vue&lt;/span&gt;({})
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;而内部规范在 &lt;strong&gt;Vue&lt;/strong&gt; 中可以不赋值&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"&gt;&lt;code class="language-JS" data-lang="JS"&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#66d9ef"&gt;new&lt;/span&gt; &lt;span style="color:#a6e22e"&gt;Vue&lt;/span&gt;({})
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;所以考虑对 &lt;strong&gt;ESLint&lt;/strong&gt; 进行一些定制化配置。&lt;/p&gt;
&lt;p&gt;查看官方文档无果之后，考虑找到开发人员，以下为交流过程：&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;arjenzhou:
Hi, because I customized the rules, so I want to build and run eslint locally, what should I do?&lt;/p&gt;
&lt;p&gt;platinumazure:
@arjenzhou You should be able to install ESLint locally with npm install &amp;ndash;save-dev eslint, and then run with ./node_modules/.bin/eslint. Am I missing something?&lt;/p&gt;</description></item></channel></rss>