浠?鍒?鎻愰珮浠g爜鐨勫仴澹€э紝閬垮厤鍥犱唬鐮佷笉瑙勮寖鑰屽鑷村簲鐢ㄥ嚭鐜癰ug鐨勫彲鑳芥€с€傝鍒欐槸鍏嶈垂鐨勶紝浣犲彲浠ヨ缃€傜敤浜庤嚜宸卞唴閮ㄥ洟闃熺殑瑙勫垯锛屼篃鍙互鐩存帴浣跨敤寮€婧愮ぞ鍖烘祦琛岀殑瑙勫垯闆嗭紝姣斿airbnb銆乪slint-plugin-vue绛夈€?.閰嶇疆鎵嬪啓涔嬪墠eslint鐨勮鍒欙紝璁╂垜浠噸鍐欒鎴戜滑鏉ョ湅鐪媏slint鐨勯厤缃€傞€氬父鎴戜滑浣跨敤.eslintrc.js鏉ラ厤缃甧slint锛屼篃鍙互鐩存帴鍦╬ackage.json涓畾涔塭slintConfig鐨勫睘鎬с€備笂鍥炬槸eslint鐨勪富瑕侀厤缃€備笅闈㈢畝鍗曞洖椤句竴涓嬫瘡涓厤缃儗鍚庣殑鍐呭鍚箟1.1parseparse鐢ㄤ簬瀹氫箟eslint浣跨敤鐨勮В鏋愬櫒銆傞粯璁ゆ槸浣跨敤Espree馃敆銆傝В鏋愬櫒鐨勪綔鐢ㄦ槸灏嗕唬鐮佷唬鐮佽浆鎹㈡垚AST鎶借薄璇硶鏍戙€傚湪eslint涓О涓篍STree銆備綘鍙互鐞嗚В涓哄皢浠g爜缈昏瘧鎴愮悊瑙SLint鐨勮瘽锛屽彲浠ュ弬鑰冧笅闈㈠叧浜嶦spree鐨勪緥瀛愶紝甯哥敤鐨勮В鏋愬櫒鏈夊涓婨sprima锛氫笂闈㈣浜唀spree鏄湪Esprima鍩虹涓婃敼杩涚殑Babel-esLint锛欱abel瑙f瀽鍣ㄧ殑鍖呫€傚綋浣犲湪椤圭洰涓娇鐢˙abel鏃躲€侭abel鐨勮В鏋愬櫒浼氭妸浣犵殑浠g爜杞垚AST锛岀劧鍚庤В鏋愬櫒浼氳浆鎴怑SLint鍙互鐞嗚В鐨凟STree銆傝繖涓洰鍓嶆垜浠敤鐨勬瘮杈冨锛岀洰鍓嶅凡缁忎笉鍐嶇淮鎶ゆ洿鏂颁簡銆傚崌绾т负@babel/eslint-parser@typescript-eslint/parser锛氬皢TypeScript杞崲鎴愬吋瀹筫stree鐨勫舰寮忓湪ESLint涓娇鐢ㄣ€傚浜嶢ST鐨勬ā鎷熺敓鎴愶紝鏈夊叴瓒g殑鍚屽鍙互浣跨敤astexplorer鍦ㄧ嚎灏濊瘯鎬荤粨锛氭棤璁轰綘浣跨敤鍝瑙f瀽鍣紝鏈川閮芥槸灏嗕唬鐮佽浆鎹㈡垚ESLint鍙互璇诲彇鐨勮瑷€ESTree馃敆1.2parseOptionparserOptions鍙傛暟鐢ㄤ簬鎺у埗parseparsing涓昏鍖呮嫭浠ヤ笅鍑犱釜灞炴€ю煈囷紝鎴戜滑閲嶇偣鍏虫敞ecmaVersion锛氱敤浜庢寚瀹氫綘瑕佷娇鐢ㄧ殑ECMAScript鐗堟湰锛岄粯璁よ缃负5锛屼緥濡傦細ESLint榛樿鏀寔ECMAScript5璇硶锛屼絾鏄鏋滀綘鎯宠eslint浣跨敤es6鐗规€ф敮鎸侊紝鍙互淇敼parserOptions涓殑鈥渆cmaVersion鈥濓細61.3rulesrules鏄痚slint鐨勮鍒欙紝鍙互鏍规嵁涓嶅悓鍦烘櫙涓嶅悓瑙勬牸鍦╮ules閰嶇疆涓坊鍔犺嚜瀹氫箟瑙勫垯1.4extends锛堟墿灞曪級寰堝鏄撲笌鎻掍欢锛坧lug-in锛夋墿灞曞拰鎻掍欢銆傚叾瀹炶川鏄姞寮篹slint鐨勬墿灞曟€э紝璁╂垜浠彲浠ョ洿鎺ヤ娇鐢ㄥ埆浜哄啓濂界殑eslint瑙勫垯锛屾柟渚垮揩鎹风殑搴旂敤鍒伴」鐩腑銆傛瘮濡備綘鐢╡xtends鏉ユ墿灞晎"extends":["eslint:recommended","plugin:react/recommended","eslint-config-standard",]}浣嗘槸濡傛灉浣犳兂鐢╬lugins锛屽叾瀹炴槸绛変环鐨則o{"plugin":['react','standard']}鈴版俯棣ㄦ彁绀猴細瀹樻柟瑙勫畾npm鍖呯殑鎵╁睍蹇呴』浠slint-config-寮€澶达紝浣跨敤鏃跺彲浠ョ渷鐣ャ€傚湪涓婇潰鐨勪緥瀛愪腑锛宔slint-config-standard鍙互鐩存帴绠€鍐欎负standard銆傚悓鏍凤紝濡傛灉浣犺寮€鍙戜竴涓猠slint鎻掍欢锛屼綘涔熼渶瑕佷互杩欑褰㈠紡鍛藉悕銆備笅涓€鑺傚皢涓烘垜浠粙缁嶄笂鍥俱€傞€氳繃涓婇潰鐨勯厤缃緥瀛愶紝鎴戜滑鍙互鐪嬪嚭瑕佷箞鏄痯lugins:[]锛岃涔堟槸extends:[]锛屼笌閰嶇疆1鐩告瘮锛屼笂鍥句腑鐨勯厤缃?灏戜簡parser銆乸arserOptions鍜宲lugins绛変俊鎭厤缃紝浣嗘槸鍏跺疄杩欎袱涓厤缃殑鏈€缁堢粨鏋滄槸涓€鑷寸殑锛屽洜涓洪厤缃?涓畾涔夌殑extends:plugin:@typescript-eslint/recommended浼氳嚜鍔ㄥ姞杞戒笂闈㈡彁鍒扮殑鍏朵粬閰嶇疆淇℃伅2寮€鍙慹slint鎻掍欢閫氳繃瀵筫slint閰嶇疆鐨勭悊瑙d笂涓€鑺傦紝鎴戜滑鏉ョ湅鐪嬪浣曚粠0鍒?寮€鍙戜竴涓猠slint鎻掍欢銆?.1eslint鎻掍欢鍒濆鍖朎SLint瀹樻柟鎻愪緵浜嗕娇鐢╕eoman鑴氭墜鏋剁殑妯℃澘锛坓enerator-eslint馃敆锛夛紝鏂逛究寮€鍙戣€呬娇鐢ㄣ€傝繖鏍锋垜浠氨鍙互閫氳繃鑴氭墜鏋舵媺鍙杄slint鎻掍欢妯℃澘浜嗐€傚叧浜嶻eoman鐨勬洿澶氫俊鎭彲浠ラ槄璇火煂茶垝姹熺殑鍓嶇宸ョ▼-yeomanStep1:installnpminstall-gyogenerator-eslintStep2:CreateafileFolder鐒跺悗閫氳繃鍒濆鍖朎SLint鎻掍欢鐨勫伐绋嬬粨鏋勫懡浠よyoeslint:plugin绗笁姝ワ細瀹屾垚鎻掍欢鍒濆鍖栧垱寤?.2鍒涘缓瑙勫垯瑙勫垯瀹屾垚鎻掍欢宸ョ▼缁撴瀯鍒濆鍖栧垱寤哄悗锛屽紑濮嬬敓鎴怑SLint鎻掍欢涓殑鍏蜂綋瑙勫垯锛屽湪ESLint鎻掍欢宸ョ▼涓墽琛屽懡浠よyoeslint:rule鐢熸垚eslint瑙勫垯鐨勬ā鏉裤€傚疄闄呮晥鏋滃涓嬨€傚垱寤烘垚鍔熷悗锛屾垜浠湅涓€涓嬫渶缁堢殑鐩綍缁撴瀯docs锛氱敤鏂囨。鏉ユ弿杩颁綘鍐欑殑瑙勫垯銆俵ib/rules鐩綍锛氳鍒欏紑鍙戞簮鐮佹枃浠讹紙濡俷o-extra-semi.js锛塼ests/lib/rules鐩綍锛氬崟鍏冩祴璇曟枃浠讹紙濡俷o-extra-semi.js锛?.3缂栧啓瑙勫垯瀹屾垚鍚庝互涓婁竴绯诲垪鎿嶄綔锛宔slint鎻掍欢妯℃澘鍒濇瀹屾垚锛屾帴涓嬫潵锛屾垜浠壘鍒扮洰褰曚笅鐨刲ib/rules锛屽紑鍙戞柊鍒涘缓鐨勮鍒欏亣璁炬垜浠湁涓€涓満鏅紝鎴戜滑瑕佸垱寤轰竴涓鍒欐潵鍒ゆ柇鏄惁鏈変唬鐮佷腑鏄console鏂规硶鐨勮皟鐢紝棣栧厛鍥炲埌绗竴鑺傛彁鍒扮殑parse瑙f瀽鍣紝鏈川涓婃槸閫氳繃璇嗗埆Espree杩斿洖鐨勬娊璞¤娉曫煂叉潵鍒ゆ柇瑙勫垯鐨勯€昏緫锛屽畾涔変簡鍚勭妫€鏌ユ柟娉曠被鍨嬨€傚湪鍐欎唬鐮佷箣鍓嶏紝鎴戜滑鍏堢湅鐪嬫帶鍒跺彴杩斿洖鐨凙ST闀夸粈涔堟牱瀛愩€備粠涓婂浘涓垜浠彲浠ユ竻妤氱殑鐪嬪嚭console.log()灞炰簬ExpressionStatement锛堣〃杈惧紡璇彞锛変腑鐨凜allExpression锛堣皟鐢ㄨ鍙ワ級銆傚彲浠ラ€氳繃callee灞炴€т腑鐨勫璞℃潵鍒ゆ柇鏄惁鏄痗onsole锛屼篃鍙互浣跨敤瀹冪殑property灞炴€с€傚垽鏂摢涓柟娉曟槸console锛屾瘮濡俵og锛宨nfo绛塻o~鎴戜滑寮€濮嬪仛鐜╁叿浜嗐€傛垜浠湪create杩斿洖鐨勫璞′腑瀹氫箟浜嗕竴涓狢allExpression鏂规硶銆傚綋ESLint寮€濮嬮亶鍘唀sTree鏃讹紝閫氳繃鐩戝惉call璇彞锛屾潵鍒ゆ柇call璇彞鏄惁涓篶onsole璋冪敤锛屼唬鐮佸涓嬸煈囨瘡鏉ule閮芥槸涓€涓猲ode妯″潡锛屼富瑕佺敱meta鍜宑reate涓ら儴鍒嗙粍鎴愩€傞噸鐐瑰叧娉ㄤ笅闈袱涓煈噈eta锛氫唬琛ㄨ繖鏉¤鍒欑殑鍏冩暟鎹紝鍖呮嫭Category銆乨ocument銆佸彲鎺ュ彈鍙傛暟鐨剆chema绛夛紝鍏朵腑涓昏鎻愬埌浜唖chema銆傚鏋滄寚瀹氫簡璇ラ€夐」锛孍SLint鍙互浼犻€掕瘑鍒嚭鐨勫弬鏁帮紝閬垮厤鏃犳晥鐨勮鍒欓厤缃紙鎺掗櫎鏍¢獙锛夈€傚彲浠ュ弬鑰冧笅鑺備粙缁嶇殑鍗曞厓娴嬭瘯optionscontext.report()浼犲叆锛氱敤浜庡彂鍑鸿鍛婃垨閿欒锛堝彇鍐充簬浣犱娇鐢ㄧ殑閰嶇疆锛夝煂叉帹鑽愰槄璇伙細Eslint-WorkingwithRules2.4unittestingWheneslit鎻掍欢寮€鍙戝畬鎴愶紝鎴戜滑闇€瑕佸寮€鍙戝畬鎴愮殑鎻掍欢杩涜楠岃瘉锛屼互淇濊瘉瑙勫垯楠岃瘉鍔熻兘鐨勬甯镐娇鐢ㄣ€傚湪eslint鎻掍欢寮€鍙戦」鐩粨鏋勪腑锛岄粯璁や娇鐢╩ocha浣滀负鍗曞厓娴嬭瘯妗嗘灦銆傛垜浠慨鏀箃ests/rules/treegogo.js鍗曞厓娴嬭瘯鏂囦欢锛屽畾涔夋棤鏁堝拰鏈夋晥鐨勪笉鍚屼緥瀛愶紝鏈€鍚庢墽琛?.5銆傚叧浜庡彂甯冨彂甯冧箣鍓嶏紝闇€瑕佺紪杈憄ackjson涓昏瀹氫箟鍏ュ彛鏂囦欢鏄痩ib/index.js锛屾毚闇茶鍒欏拰閰嶇疆馃懆鈥嶐煄撻樋瀹斤細閭f垜鎬庝箞瀹氫箟涓€涓寘鍚厤缃殑闆嗗悎鍛紵鏄殑锛屽畼鏂规枃妗f弿杩帮細鎮ㄥ彲浠ュ湪configs閿笅鐨勬彃浠朵腑鎸囧畾鎵撳寘鐨勯厤缃€傚綋鎮ㄤ笉浠呰鎻愪緵浠g爜椋庢牸锛岃繕瑕佹彁渚涗竴浜涜嚜瀹氫箟瑙勫垯鏉ユ敮鎸佸畠鏃跺緢鏈夌敤銆傛瘡涓猵lugin閮芥敮鎸佸绉嶉厤缃紝浣跨敤鐨勬椂鍊欏彲浠ヤ娇鐢╜{"extends":["plugin:tree-eslint/myConfig"]},`杩欎釜鍖呮嫭棰勮瑙勫垯閰嶇疆锛屾渶鍚巒pm鍙戝竷npmpulish2.6濡備綍閫氳繃绗竴鑺傞厤缃殑浠嬬粛锛屾垜浠渶瑕佷竴涓?eslintrc鏂囦欢銆傚鏋滆鐩綍娌$敤锛屽彲浠ラ€氳繃鍛戒护琛宔slint-init杩涜鍒濆鍖栥€傞厤缃畬鎴愬悗瀹夎鏂版墦寮€鐨別slint鎻掍欢閰嶇疆涓€鍙互閰嶇疆鎴戜滑寮€鍙戠殑瑙勫垯锛歟rror銆亀arn銆乷ff銆傚鏋滈渶瑕佹帓闄ゆ煇浜涢儴鍒嗭紝娣诲姞閫夐」锛屾垨鑰呭彲浠ュ弬鑰冮厤缃箣绫荤殑棰勮鎵╁睍2.浣犲ソ锛屾垜鏄煂叉爲閰憋紝璇峰枬涓€鏉煃佃浣忎笁杩瀪1.鐪嬪畬璁板緱鐐硅禐锛屼綘鏈夝煈嶅姩鍔?.鍏虫敞閭d簺鍓嶇鐨勮叮浜嬪叕浼楀彿锛屽拰浣犺亰鑱婂墠绔殑瓒d簨3.鏂囩珷鏀跺綍鍦℅ithubfrontendThings璋㈣阿Star鉁?/p>
