IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 前端项目规范化 -> 正文阅读

[JavaScript知识库]前端项目规范化

参考视频: https://www.bilibili.com/video/BV1rh411e7E5?vd_source=eee62ea3954ac01bff9e87e2a7b40084

  • prettier代码格式化
  • eslint js语法检查
  • stylellint css样式检查

配置prettier和eslint

  1. 初始化React项目

    npx create-react-app study_react

  2. 安装vscode插件 prettiereslint, 配置vscode
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  3. 安装相关依赖

    yarn add -D prettier eslint
    

    在代码格式化时采用Perttier规则,而我们代码校验使用的是ESLint,如果同一个规则配置不一致,往往就会出现冲突问题;
    比如:字符串单、双引号的配置,eslint后把字符串变成单引号,更新文件代码过后,重新保存(Prettier)又自动格式化后变成双引号,导致代码校验异常。


    解决方案1: 两者配置文件部分配置修改成一致.
    解决方案2: 安装相关插件(Prettier 和 ESLint 冲突解决方案 eslint-config-prettier eslint-plugin-prettier)

    • eslint-config-prettier 禁用 eslint 冲突配置
    • eslint-plugin-prettier Prettier先格式化 (默认是先eslint格式化,再Prettier格式化)
    yarn add -D eslint-config-prettier eslint-plugin-prettier
    
  4. 优雅的提示错误

    “extends”: [“eslint:recommended”, “plugin:react/recommended”], 默认是eslint:recommended,(步骤6后面会看到这个配置)
    https://www.npmjs.com/package/eslint-config-airbnb

    npx install-peerdeps --dev eslint-config-airbnb
    
  5. 初始化.eslintrc.json文件

    npx eslint --init
    如果全局安装了eslint (npm install -g eslint )了, 可以直接使用eslint --init

    根据提示勾选:
    在这里插入图片描述

    安装完成的eslintrc.json文件

    {
      "env": {
        "browser": true,
        "es2021": true
      },
      "extends": ["eslint:recommended", "plugin:react/recommended"],
      "parserOptions": {
        "ecmaFeatures": {
          "jsx": true
        },
        "ecmaVersion": "latest",
        "sourceType": "module"
      },
      "plugins": ["react"],
      "rules": {
        "indent": ["error", "tab"],
        "linebreak-style": ["error", "windows"],
        "quotes": ["error", "double"],
        "semi": ["error", "always"]
      }
    }
    
  6. 修改eslintrc.json优雅提示(也就是步骤4所提到)

      "extends": ["airbnb", "prettier", "plugin:react/recommended"],
      "plugins": ["prettier", "react"],
    
  7. 新建.prettierrc文件

    更多规则: https://www.prettier.cn/docs/options.html

    {
      "singleQuote": false,
      "endOfLine": "lf"
    }
    
  8. 可自行定义eslintrc.json规则

    https://eslint.bootcss.com/docs/rules/

  9. 效果
    在这里插入图片描述

  10. 让提示更细致

    eslintrc.json追加rules, "prettier/prettier": "error",

    在这里插入图片描述

  11. 最终的两个文件的配置

    // eslint
    {
      "env": {
        "browser": true,
        "es2021": true
      },
      "extends": ["airbnb", "prettier", "plugin:react/recommended"],
      "parserOptions": {
        "ecmaFeatures": {
          "jsx": true
        },
        "ecmaVersion": "latest",
        "sourceType": "module"
      },
      "plugins": ["prettier", "react"],
      "rules": {
        "prettier/prettier": "error",
        "indent": ["off", "tab"],
        "linebreak-style": ["off", "windows"],
        "quotes": ["error", "double"],
        "semi": ["error", "always"]
      }
    }
    ===============================================================================
    // prettier
    {
      "singleQuote": false,
      "endOfLine": "lf"
    }
    

配置stylelint

  1. 安装相关依赖
    yarn add stylelint stylelint-config-stardand stylelint-config-prettier stylelint-order -D
    
    - stylelint-config-prettier解决和prettier冲突
    - stylelint-order 排序css属性
    
  2. 新建.stylelint.json文件

    stylelint相关规则: http://stylelint.docschina.org/user-guide/rules/

    {
      "plugins": ["stylelint-order"],
      "extends": ["stylelint-config-standard", "stylelint-config-prettier"],
      "rules": {
        "property-no-unknown": true,
        "comment-no-empty": [
          true,
          {
            "message": "禁止空注释"
          }
        ],
        "order/properties-order": [
          "position",
          "top",
          "right",
          "bottom",
          "left",
          "z-index",
          "display",
          "float",
          "width",
          "height",
          "max-width",
          "max-height",
          "min-width",
          "min-height",
          "padding",
          "padding-top",
          "padding-right",
          "padding-bottom",
          "padding-left",
          "margin",
          "margin-top",
          "margin-right",
          "margin-bottom",
          "margin-left",
          "margin-collapse",
          "margin-top-collapse",
          "margin-right-collapse",
          "margin-bottom-collapse",
          "margin-left-collapse",
          "overflow",
          "overflow-x",
          "overflow-y",
          "clip",
          "clear",
          "font",
          "font-family",
          "font-size",
          "font-smoothing",
          "osx-font-smoothing",
          "font-style",
          "font-weight",
          "hyphens",
          "src",
          "line-height",
          "letter-spacing",
          "word-spacing",
          "color",
          "text-align",
          "text-decoration",
          "text-indent",
          "text-overflow",
          "text-rendering",
          "text-size-adjust",
          "text-shadow",
          "text-transform",
          "word-break",
          "word-wrap",
          "white-space",
          "vertical-align",
          "list-style",
          "list-style-type",
          "list-style-position",
          "list-style-image",
          "pointer-events",
          "cursor",
          "background",
          "background-attachment",
          "background-color",
          "background-image",
          "background-position",
          "background-repeat",
          "background-size",
          "border",
          "border-collapse",
          "border-top",
          "border-right",
          "border-bottom",
          "border-left",
          "border-color",
          "border-image",
          "border-top-color",
          "border-right-color",
          "border-bottom-color",
          "border-left-color",
          "border-spacing",
          "border-style",
          "border-top-style",
          "border-right-style",
          "border-bottom-style",
          "border-left-style",
          "border-width",
          "border-top-width",
          "border-right-width",
          "border-bottom-width",
          "border-left-width",
          "border-radius",
          "border-top-right-radius",
          "border-bottom-right-radius",
          "border-bottom-left-radius",
          "border-top-left-radius",
          "border-radius-topright",
          "border-radius-bottomright",
          "border-radius-bottomleft",
          "border-radius-topleft",
          "content",
          "quotes",
          "outline",
          "outline-offset",
          "opacity",
          "filter",
          "visibility",
          "size",
          "zoom",
          "transform",
          "box-align",
          "box-flex",
          "box-orient",
          "box-pack",
          "box-shadow",
          "box-sizing",
          "table-layout",
          "animation",
          "animation-delay",
          "animation-duration",
          "animation-iteration-count",
          "animation-name",
          "animation-play-state",
          "animation-timing-function",
          "animation-fill-mode",
          "transition",
          "transition-delay",
          "transition-duration",
          "transition-property",
          "transition-timing-function",
          "background-clip",
          "backface-visibility",
          "resize",
          "appearance",
          "user-select",
          "interpolation-mode",
          "direction",
          "marks",
          "page",
          "set-link-source",
          "unicode-bidi",
          "speak"
        ]
      }
    }
    
    
  3. 效果
    在这里插入图片描述

保存自动修复

采用的vscode编辑器, 往setting.json添加配置

"editor.codeActionsOnSave": {
	"source.fixAll.stylelint": true,
	"source.fixAll.eslint": true
},
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-29 18:55:53  更:2022-06-29 18:55:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:47:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码