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

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

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

瀏覽:322日期: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久久,三上悠亚国产精品一区二区三区
亚洲精品乱码| 午夜久久影院| 亚洲免费福利一区| 亚洲精品系列| 国产精品久久久久久久久免费高清| 日韩激情一二三区| 亚洲午夜国产成人| 蜜桃视频一区二区| 综合国产精品| 欧美黄页在线免费观看| 精品久久亚洲| 日韩三区在线| 天堂av在线一区| 国产乱码精品一区二区亚洲| **爰片久久毛片| 福利在线一区| 玖玖精品视频| 精品视频自拍| 国产伊人精品| 国产精品视频首页| 不卡在线一区| 国产欧美久久一区二区三区| 精品视频免费| 蜜臀精品一区二区三区在线观看| 国产麻豆精品| 久久中文字幕二区| 国产精品资源| 99热精品久久| 欧美91在线|欧美| 蜜臀91精品国产高清在线观看| 爽好久久久欧美精品| 国产精品成人自拍| 性一交一乱一区二区洋洋av| 久久免费视频66| 亚洲精品第一| 99精品小视频| 国产一区二区视频在线看| 99xxxx成人网| 欧美日韩在线网站| 国精品产品一区| 国产亚洲欧美日韩精品一区二区三区 | 精品日韩在线| 另类中文字幕国产精品| 日本亚洲视频在线| 日韩精品高清不卡| 欧美精品国产| 久久精品资源| 色一区二区三区| 国产精品99久久免费| 91精品一区二区三区综合在线爱 | 日韩精品一区二区三区免费观影 | 欧洲一级精品| 国产精品第一| 国产亚洲精品美女久久久久久久久久| 国产精品97| 精品一区三区| jiujiure精品视频播放| 亚洲午夜av| av中文资源在线资源免费观看| 日韩精品国产欧美| 青青草国产成人99久久| 日韩精品高清不卡| 欧美日韩一区自拍| 久久国产乱子精品免费女| 欧美日韩一区二区三区在线电影| 日韩欧美2区| 日本91福利区| 国产精品115| 成人国产综合| 久久婷婷一区| 三级在线观看一区二区 | 久久最新视频| 亚洲精品护士| 欧美日韩亚洲一区在线观看| 国产精品久久久久久模特| 精品一区二区三区中文字幕视频 | 亚洲人亚洲人色久| 日韩黄色免费网站| 日韩不卡一二三区| 国产精品一线| 日本在线高清| 玖玖玖国产精品| 麻豆国产一区| 九九在线精品| 欧美日韩1区| 91精品蜜臀一区二区三区在线| 视频在线观看91| 卡一卡二国产精品| 午夜精品影院| 国产精品久久| 亚洲精品888| 麻豆一区二区三区| 欧美日韩第一| 91成人在线网站| 999国产精品| 国产精品一区三区在线观看| 激情综合激情| 欧美激情aⅴ一区二区三区| 自拍日韩欧美| 高清久久一区| 91成人在线网站| 在线亚洲国产精品网站| 精品一区二区三区的国产在线观看| 午夜精品一区二区三区国产| 国产欧美三级| 爽好多水快深点欧美视频| 最近高清中文在线字幕在线观看1| 亚洲网址在线观看| 久久久久国产精品一区三寸| 国产精品手机在线播放| 亚洲日产国产精品| 日韩午夜黄色| 99热精品久久| 一区二区三区四区日本视频| 国产精品一区二区精品视频观看 | 国产亚洲一区二区手机在线观看 | 久久在线91| 嫩呦国产一区二区三区av| 在线精品一区二区| 91精品国产自产在线丝袜啪| 日韩av资源网| 国产精品一区二区精品视频观看| 精品中文字幕一区二区三区av| 成人影视亚洲图片在线| 国产亚洲电影| 亚洲精品免费观看| 成人免费电影网址| 国产麻豆一区| 丝袜美腿一区二区三区| 国产综合亚洲精品一区二| 国产另类在线| 欧美日韩18| 欧美黑人巨大videos精品| 久久精品97| 麻豆国产91在线播放| 日韩不卡一区二区| 国产一区一一区高清不卡| 免费成人在线影院| 99久久亚洲精品蜜臀| 久久女人天堂| 欧美三级网址| 激情五月综合| 亚洲丝袜啪啪| 国产欧美综合一区二区三区| 国产精品一区亚洲| 日本欧美一区二区在线观看| 国产亚洲精品美女久久| 精品九九久久| 欧美.日韩.国产.一区.二区| 视频一区视频二区中文字幕| 亚洲三级av| 久久这里只有精品一区二区| 波多野结衣久久精品| 99pao成人国产永久免费视频| 中文亚洲欧美| 久久xxx视频| 亚洲大全视频| 国产情侣久久| 亚洲国产一区二区三区在线播放 | 亚洲伊人精品酒店| 国产欧美一区二区三区米奇| 91欧美在线| 蜜桃久久久久久久| 久久精品国产成人一区二区三区| 久久久国产精品一区二区中文| 国产毛片一区| 国产精品xxx在线观看| 亚洲欧美伊人| 国产乱码精品一区二区亚洲| 亚洲午夜91| 精品国产三区在线| 久久亚洲电影| 久久精品主播| 国产欧美高清| 久久最新视频| 丝袜美腿诱惑一区二区三区| 青青国产精品| 国产精品社区| 亚洲精品一区三区三区在线观看| 欧美一区91| 国产精品普通话对白| 日韩在线二区| 国产一区福利| 欧美精品二区| 欧美三级第一页| 日产欧产美韩系列久久99| 久久香蕉国产| 久久九九99| 九九九精品视频| 欧美午夜精彩| 亚洲高清不卡| 久久av免费| 嫩草伊人久久精品少妇av杨幂| 国产日韩精品视频一区二区三区| 亚洲va久久| 欧美一区二区三区久久精品| 国产欧美一区二区精品久久久| 日本h片久久| 久久久久久久欧美精品| 国产精品1区在线|