日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

CSS代碼檢查工具stylelint的使用方法詳解

瀏覽:319日期:2022-06-02 17:15:36

CSS不能算是嚴格意義的編程語言,但是在前端體系中卻不能小覷。 CSS 是以描述為主的樣式表,如果描述得混亂、沒有規則,對于其他開發者一定是一個定時炸彈,特別是有強迫癥的人群。CSS 看似簡單,想要寫出漂亮的 CSS 還是相當困難。所以校驗 CSS 規則的行動迫在眉睫。stylelint是一個強大的現代 CSS 檢測器,可以讓開發者在樣式表中遵循一致的約定和避免錯誤。本文將詳細介紹CSS代碼檢查工具stylelint

概述

stylelint擁有超過150條的規則,包括捕捉錯誤、最佳實踐、控制可以使用的語言特性和強制代碼風格規范。它支持最新的CSS語法,并且靈活可配置

Vue

下面在Vue框架下安裝使用stylelint

1、安裝stylelint、stylint-config-standard和stylelint-order

npm install stylelint --save-devnpm install stylelint-config-standard --save-devnpm install stylelint-order --save-dev

其中,stylelint是運行工具,stylelint-config-standard是stylelint的推薦配置,stylelint-order是CSS屬性排序插件

安裝完成后,package.json文件中會自動添加如下字段

"stylelint": "^9.1.3","stylelint-config-standard": "^18.2.0","stylelint-order": "^0.8.1",

2、在根目錄下創建.stylelintrc配置文件

{ "extends": "stylelint-config-standard", "plugins": ["stylelint-order"],"rules": {"order/order": ["declarations","custom-properties","dollar-variables","rules","at-rules"],"order/properties-order": ["position","z-index",   "top","bottom","left",     "right","float","clear","columns","columns-width","columns-count","column-rule","column-rule-width","column-rule-style","column-rule-color","column-fill","column-span","column-gap",   "display","grid","grid-template-rows","grid-template-columns","grid-template-areas","grid-auto-rows","grid-auto-columns","grid-auto-flow","grid-column-gap","grid-row-gap","grid-template","grid-template-rows","grid-template-columns","grid-template-areas","grid-gap","grid-row-gap","grid-column-gap","grid-area","grid-row-start","grid-row-end","grid-column-start","grid-column-end","grid-column","grid-column-start","grid-column-end","grid-row","grid-row-start","grid-row-end",   "flex","flex-grow","flex-shrink","flex-basis","flex-flow","flex-direction","flex-wrap","justify-content","align-content","align-items","align-self","order","table-layout","empty-cells","caption-side","border-collapse","border-spacing","list-style","list-style-type","list-style-position","list-style-image","ruby-align","ruby-merge","ruby-position","box-sizing","width","min-width","max-width","height","min-height","max-height","padding","padding-top","padding-right","padding-bottom","padding-left","margin","margin-top","margin-right","margin-bottom","margin-left",   "border","border-width","border-top-width","border-right-width","border-bottom-width","border-left-width","border-style","border-top-style","border-right-style","border-bottom-style","border-left-style","border-color","border-top-color","border-right-color","border-bottom-color","border-left-color","border-image","border-image-source","border-image-slice","border-image-width","border-image-outset","border-image-repeat","border-top","border-top-width","border-top-style","border-top-color","border-top","border-right-width","border-right-style","border-right-color","border-bottom","border-bottom-width","border-bottom-style","border-bottom-color","border-left","border-left-width","border-left-style","border-left-color","border-radius","border-top-right-radius","border-bottom-right-radius","border-bottom-left-radius","border-top-left-radius","outline","outline-width","outline-color","outline-style","outline-offset","overflow","overflow-x","overflow-y","resize","visibility","font","font-style","font-variant","font-weight","font-stretch","font-size","font-family","font-synthesis","font-size-adjust","font-kerning",    "line-height","text-align","text-align-last","vertical-align",   "text-overflow","text-justify","text-transform","text-indent","text-emphasis","text-emphasis-style","text-emphasis-color","text-emphasis-position","text-decoration","text-decoration-color","text-decoration-style","text-decoration-line","text-underline-position","text-shadow",   "white-space","overflow-wrap","word-wrap","word-break","line-break","hyphens","letter-spacing","word-spacing","quotes","tab-size","orphans","writing-mode","text-combine-upright","unicode-bidi","text-orientation","direction","text-rendering","font-feature-settings","font-language-override","image-rendering","image-orientation","image-resolution","shape-image-threshold","shape-outside","shape-margin","color","background","background-image","background-position","background-size","background-repeat","background-origin","background-clip","background-attachment","background-color","background-blend-mode","isolation","clip-path","mask","mask-image","mask-mode","mask-position","mask-size","mask-repeat","mask-origin","mask-clip","mask-composite","mask-type","filter","box-shadow","opacity","transform-style","transform","transform-box","transform-origin","perspective","perspective-origin","backface-visibility","transition","transition-property","transition-duration","transition-timing-function","transition-delay","animation","animation-name","animation-duration","animation-timing-function","animation-delay","animation-iteration-count","animation-direction","animation-fill-mode","animation-play-state","scroll-behavior","scroll-snap-type","scroll-snap-destination","scroll-snap-coordinate","cursor","touch-action","caret-color","ime-mode","object-fit","object-position","content","counter-reset","counter-increment","will-change","pointer-events","all","page-break-before","page-break-after","page-break-inside","widows"],  "no-empty-source": null,"property-no-vendor-prefix": [true, {"ignoreProperties": ["background-clip"]}],"number-leading-zero": "never","number-no-trailing-zeros": true,"length-zero-no-unit": true,"value-list-comma-space-after": "always","declaration-colon-space-after": "always","value-list-max-empty-lines": 0,"shorthand-property-no-redundant-values": true,"declaration-block-no-duplicate-properties": true,"declaration-block-no-redundant-longhand-properties": true,"declaration-block-semicolon-newline-after": "always","block-closing-brace-newline-after": "always","media-feature-colon-space-after": "always","media-feature-range-operator-space-after": "always","at-rule-name-space-after": "always","indentation": 2,"no-eol-whitespace": true,"string-no-newline": null}}

3、使用stylelint驗證CSS代碼即可,如驗證src目錄下的所有vue文件

react

react中使用styled-components來書寫CSS代碼,stylelint同樣提供了插件來校驗CSS

1、安裝stylelint、stylelint-processor-styled-components、stylelint-config-styled-components、stylelint-config-recommend、stylelint-order

npm install --save-dev stylelint@9.1.3npm install --save-dev stylelint-processor-styled-componentsnpm install --save-dev stylelint-config-styled-componentsnpm install --save-dev stylelint-config-recommendednpm install --save-dev stylelint-order

注意: 由于stylelint更新到9.2版本后,導致styled-components中的CSS代碼無法正常校驗,所以穩妥起見,使用9.1.3版本的

2、在根目錄下新建配置文件.stylelintrc

{"processors": ["stylelint-processor-styled-components"],"extends": ["stylelint-config-recommended","stylelint-config-styled-components"],"plugins": ["stylelint-order"],"rules": {"order/order": ["declarations","custom-properties","dollar-variables","rules","at-rules"],...}

3、同樣地,使用stylelint命令即可校驗

注意事項

1、fix命令

在stylelint的150多條規則中,使用fix命令,可以自動修復一些命令。但是,該fix命令一定要慎用。筆者在使用fix命令后,stylelint將React工程中的所有js文件里的代碼全部清除,只留著了下可以識別的css部分

stylelint "**/*.js" --fix

2、配置scripts

可以在package.json中配置stylelint的快捷方式

"scripts": {"lintcss": "stylelint "src/**/*.js""}

這樣,使用npm run lintcss 命令即可實現相同效果

3、如果提示如下錯誤

Error: No configuration provided for

是因為在根路徑下沒有發現配置文件,如.stylelintrc

更多關于CSS代碼檢查工具stylelint的使用方法請查看下面的相關鏈接

標簽: CSS HTML
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
福利视频一区| 欧美日韩免费观看一区=区三区| 精品国产免费人成网站| 国产色噜噜噜91在线精品| 日韩一区二区久久| 亚洲免费婷婷| 久久精品国产www456c0m| 日产欧产美韩系列久久99| 蜜桃av一区二区三区电影| 免费在线观看一区二区三区| 亲子伦视频一区二区三区| 久久伊人久久| 福利一区视频| 亚洲综合在线电影| 欧美精品九九| 日韩国产欧美在线播放| 91p九色成人| 久久精品免视看国产成人| 蜜臀国产一区| 亚洲制服少妇| 国产精品欧美大片| 亚洲天堂1区| 国产精品日韩久久久| 日韩1区2区日韩1区2区| 国产精品资源| 九九精品调教| 亚洲综合中文| 久久久久久久欧美精品| 午夜久久中文| 一级成人国产| 成人日韩av| 老鸭窝亚洲一区二区三区| 国产精品久久久久久av公交车| 国产精品久久久久久久久妇女| 国产精品91一区二区三区| 国产欧美激情| av成人国产| 国产亚洲字幕| 99成人在线| 精品久久精品| 亚洲三级av| 桃色一区二区| 国产视频一区在线观看一区免费| 97精品国产99久久久久久免费| 91tv亚洲精品香蕉国产一区| 鲁大师成人一区二区三区| 精品久久99| 日韩中文av| 99国产精品久久久久久久| 日韩av在线播放中文字幕| 欧美一区久久久| 国产欧美日韩一级| 亚洲精品国产偷自在线观看| 久久免费福利| 国产精品分类| 91欧美极品| 免费观看在线综合色| 免费精品国产| 久久影院一区| 久久久久美女| 久久国产亚洲| 亚洲大全视频| 欧美福利一区| av一区在线| 播放一区二区| 亚洲四虎影院| 香蕉久久99| 久久免费国产| 久久精品影视| 99成人在线视频| 91精品一区二区三区综合在线爱| 综合日韩av| 日韩不卡在线| 亚洲大片在线| 在线视频免费在线观看一区二区| 久久久久午夜电影| 亚洲爱爱视频| 亚洲免费精品| 亚欧洲精品视频在线观看| 日韩福利视频网| 久久精品国产亚洲aⅴ| 日韩免费一区| 久久一区二区三区电影| 亚洲免费网址| 麻豆国产精品| 欧美成a人免费观看久久| 婷婷成人基地| 亚洲欧美日本日韩| 国产欧美日韩一级| 亚洲黄色免费看| 精品三级在线| 国产高清久久| 欧美日韩一区二区高清| 毛片在线网站| 亚洲精品乱码久久久久久蜜桃麻豆 | 成人高清一区| 99视频在线精品国自产拍免费观看| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品综合| 影院欧美亚洲| 狠狠久久伊人| 一区二区国产精品| 在线一区av| 日韩福利在线观看| 国产精品7m凸凹视频分类| 国产日韩中文在线中文字幕| 久久久精品日韩| 日韩一区二区三区免费视频| 久久久免费人体| 亚洲精品三级| 中文久久精品| 色在线中文字幕| 国产精品久久久久久妇女 | 欧美日韩亚洲国产精品| 美女少妇全过程你懂的久久| 日本va欧美va欧美va精品| 一级欧洲+日本+国产| 国产在线观看www| 国产精品伦一区二区| 日韩精品久久久久久| 黄页网站一区| 国精品产品一区| 精品国产网站| 国产精品免费大片| 欧美一区成人| 欧美午夜三级| 国产探花一区| 国产精品最新| 国产激情精品一区二区三区| 日韩精品视频在线看| 综合视频一区| 日韩一区精品| 欧美一区在线观看视频| 91亚洲精品视频在线观看 | 日韩中文字幕视频网| 久久国产精品亚洲77777| 欧美在线影院| 一区免费视频| 亚洲一区二区小说| 日韩高清一级| 麻豆91精品视频| 国产乱码午夜在线视频| 欧美国产91| 亚洲欧美日韩视频二区| 欧美亚洲日本精品| 国产91一区| 亚洲欧美在线综合| 欧美一区影院| 精品国产99| 中文字幕在线看片| 亚洲成人va| 亚洲欧美日本国产| 麻豆一区二区在线| 久久精品1区| 亚洲资源网站| 精品99在线| 亚洲一区区二区| 欧美精品aa| 免费av一区二区三区四区| 综合亚洲自拍| 在线天堂中文资源最新版| 国产精品三上| av日韩中文| 日韩精品视频中文字幕| 日韩国产精品久久久久久亚洲| 国产日韩免费| 女同性一区二区三区人了人一| 国产欧美日韩| 日韩精品一级二级 | 欧美日韩尤物久久| 亚洲精品麻豆| 国产精品字幕| 国产日本久久| 国产一区二区精品| 激情视频网站在线播放色| 亚洲精品人人| 日韩久久视频| 久久久国产精品入口麻豆| 最新亚洲激情| 国产白浆在线免费观看| 日本午夜精品视频在线观看| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 九九九精品视频| 视频一区日韩| 国产精品三上| 天堂av在线| 精品免费在线| 精品一区av| 国产图片一区| 国产欧美日韩| 国产日产一区| 日本中文字幕不卡| 欧美天堂视频| 婷婷成人综合| 国产欧美高清视频在线| 福利一区和二区| 国际精品欧美精品| 免费亚洲一区| 麻豆免费精品视频| 国产精品1区|