“代码规范”这样做【高级前端必备软技能之一】

news2025/1/16 10:57:34

✨在前端开发领域,良好的代码规范是团队协作、项目可维护性的基石。最近在梳理我们团队关于代码规范相关的一些文档,顺便给大家分享一下我们是从哪些方面入手来从一个草台班子,到开发规范的高效团队。
✨本文旨在提供一份详尽的前端代码规范指南,覆盖文件命名、组件编写、路由设计及代码风格等方面,帮助开发者建立清晰、一致的开发准则,进而提升项目质量与开发效率。

🚀1.文件命名规范 src下文件目录命名规范

  1. api 通用接口请求管理,子文件夹按模块划分,使用单英文单词命名。
方法名使用当前接口模块名+方法名,驼峰命名规则
例如:
url: "/contract/template/list"
方法名为templateList
  1. assets:静态资源css,image,js,scss
  • css,scss文件命名规则:_+模块名.css
  • img文件命名规则:英文单词命名,多单词以_连接
  • js文件命名规则:以第三方引入的js文件名为准,不允许修改
  1. common:公共模块(业务相关的公共模块)
  • config:全局配置文件
  • fetch:axios封装
  • message:全局消息提示
  • mixins:混入组件
  • storage:本地储存封装
  • plugins:业务相关的全局方法
  1. components:基础组件;组件命名必须为多单词,用驼峰命名规范,首字母大写,基础组件内不处理业务逻辑,仅向外部传输数据

  2. directives:指令 文件命名规则小驼峰命名规范;该文件夹仅需一个index入口文件,其他方法需要放在modules文件夹

  3. filter:过滤器 文件命名规则小驼峰命名规范,该文件夹仅需一个index入口文件,其他方法需要放在modules文件夹

  4. pages:公用页面,英文单词命名,小驼峰命名规范,该文件夹导出一个index.js的路由文件,任意子模块必须引入此文件,保持公用页面的name统一性

  5. utils:全局公用方法,与业务无关,改文件夹导出一个index.js,暴露一个 install方法,使用Vue.use方法注册到全局

  6. stroe:全局状态管理,

  • getter.js Vuex暴露出口,属性名使用驼峰命名
  • modules 模块文件夹,各模块包含state,actions,mutations
  • state属性使用驼峰命名
  • action属性使用set_+state属性名,例如:set_token
  • mutations属性使用SET_+state属性名全大写命名规则,例如:SET_TOKEN
  1. hooks 钩子函数方法,index.js统一暴露出所有方法
  2. libs:全局常量
  • const.js 常量

🚀2.组件代码规范

  1. props命名规范

    props: {
        status: {
            type: String,
            required: true,
            validator: function (value. {
                return [
                    'syncing',
                    'synced',
                    'version-conflict',
                    'error'
                ].indexOf(value. !== -1
            }
        }
    }
    
  2. data书写规范

    data: function () {
        return {
            foo: 'bar'
        }
    }
    
  3. css 组件内的css必须使用scoped标签

  4. 模板内复杂表达式必须使用计算属性

  5. 生命周期函数按生命周期顺序书写

  6. 页面初始化在mothods添加onload方法

  7. 添加使用add+模块名 例如 addUser

  8. 编辑使用edit+模块名 例如 editUser

  9. 点击按钮打开某个弹框使用方法名示例:openDialogByUser

  10. 删除方法示例 removeUser

  11. 路由跳转方法示例 linkTo + 路由名(route信息的name字段)

  12. boolean类型的变量使用is或has开头

🚀3.路由命名规范

  1. 路由对象约定
    {
        path: '/user-mgt',  // 路由path和使用的文件名一致,以-连接
        name: 'UserMgt',    // path的大驼峰连接
        component: () => import("@/views/user-mgt/index.vue"),    // 使用import按需加载组件
        meta: {
          title: "用户列表",  // 页面描述
          icon: 'icon-a-icon-xuqiuguanlisvg', // icon
          roles: ['UserMgt'] // 当前模块权限
        },
        children: [
          path: '',  // 路由path和使用的文件名一致,以-连接
          name: 'UserMgtList', // path的大驼峰连接
          component: () => import("@/views/user-mgt/list/index.vue"),    // 使用import按需加载组件
          meta: {
            title: "用户管理-列表",  // 页面描述
            activeRouter: "UserMgt", // 如果是子路由,必需设置改项,当前激活菜单
            moduleRoles: ['user_page'] // 当前模块权限
          },
        ]
    }
    

🚀4.Views 文件夹命名规范

务必于路由保持一直,采用树形结构
在这里插入图片描述

  • list 存放对应的列表页面,如果有多个sheet,按照模块区分
  • detail 中存放对应的详情页面
  • dialog 存放该模块下的所有相关弹框
  • components 存放该模块下的业务组件

🚀5.代码风格

  1. 代码风格使用standard无需配置的代码风格管理
  2. js代码规范:https://standardjs.com/readme-zhcn.html
  3. 项目开发使用vscode进行开发
  4. vscode插件安装: StandardJS、ESLint、Prettier-Standard
  5. vscode配置文件
    {
        "editor.tabSize": 2,
        "editor.fontSize": 14,
        "[jsonc]": {
            "editor.defaultFormatter": "vscode.json-language-features"
        },
        "[json]": {
            "editor.defaultFormatter": "vscode.json-language-features"
        },
        "[javascript]": {
            "editor.defaultFormatter": "vscode.typescript-language-features"
        },
        "[javascriptreact]": {
            "editor.defaultFormatter": "vscode.typescript-language-features"
        },
        "[css]": {
            "editor.defaultFormatter": "esbenp.prettier-vscode"
        },
        "[scss]": {
            "editor.defaultFormatter": "esbenp.prettier-vscode"
        },
        "[html]": {
            "editor.defaultFormatter": "vscode.html-language-features"
        },
        "[script]": {
            "editor.defaultFormatter": "esbenp.prettier-vscode"
        },
        "[typescript]": {
            "editor.defaultFormatter": "vscode.typescript-language-features"
        },
        "[vue]": {
            "editor.defaultFormatter": "esbenp.prettier-vscode"
        },
        "[typescriptreact]": {
            "editor.defaultFormatter": "esbenp.prettier-vscode"
        },
        "[markdown]": {
            "editor.defaultFormatter": "yzhang.markdown-all-in-one"
        },
        "prettier.bracketSameLine": true,
        // 函数前面加个空格
        "javascript.format.insertSpaceBeforeFunctionParenthesis": true,
        // 去掉代码结尾的分号
        "prettier.singleQuote": true,
        // 使用带引号替代双引号
        "prettier.semi": false,
    }
    

🔥 结论

遵循上述规范,不仅可以提升代码的可读性和可维护性,还能加速团队成员之间的协作,减少因个人习惯差异带来的代码审查和维护成本。规范化的代码结构和风格,是每一个高质量前端项目不可或缺的基础。通过持续优化和遵循这些准则,我们能够构建出更加健壮、易维护的前端应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1862005.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux的免交互

交互:我们发出指令控制程序的运行,程序在接收到指令之后按照指令的效果做出对应的反应。 免交互:间接的通过第三方的方式把指令传送给程序,不用直接的下达指令。 1、here document免交互 ere document免交互:是命令…

Studying-代码随想录训练营day20| 235.二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作、450.删除二叉搜索树中的节点

第二十天,二叉树part07,二叉树搜索树加油加油💪 目录 235.二叉搜索树的最近公共祖先 701.二叉搜索树中的插入操作 450.删除二叉搜索树中的节点 拓展:普通二叉树的删除方式 总结 235.二叉搜索树的最近公共祖先 文档讲解&…

在FlowUs息流,让知识库为你所用|如何打造个人知识库|如何打造企业知识库

🎉 在 FlowUs 的世界中,知识绽放出无限的可能!🚀 在当今信息爆炸的时代,知识的更新换代速度极快,我们每天都面临着海量的信息冲击。拥有一个属于自己的知识库变得至关重要。 首先,打造自己的知…

Linux_应用篇(27) CMake 入门与进阶

在前面章节内容中,我们编写了很多示例程序,但这些示例程序都只有一个.c 源文件,非常简单。 所以,编译这些示例代码其实都非常简单,直接使用 GCC 编译器编译即可,连 Makefile 都不需要。但是,在实…

解决IMX6ULL GPIO扩展板PWM7/8中的pwm0/period后卡死问题

前言 本篇文章主要是记录解决百问网论坛上面设置 IMX6ULL GPIO扩展板PWM7/8中的pwm0/period后卡死问题,如下图: 一、查看原理图,找出对应引脚 在这里我们如何确定哪个扩展口中的引脚输出PWM波呢?我们可以通过查看原理图。 查看…

【Java】解决Java报错:IllegalMonitorStateException in Synchronization

文章目录 引言一、IllegalMonitorStateException的定义与概述1. 什么是IllegalMonitorStateException?2. IllegalMonitorStateException的常见触发场景3. 示例代码 二、解决方案1. 确保在同步代码块或方法中调用wait()、notify()和notifyAll()2. 使用同步方法3. 使用…

办公人导航-上网导航,找网站,下软件,找资源!

办公人导航是一个专门为办公人员设计的实用导航网站,旨在帮助用户高效地找到各种优质的办公资源和工具。无论是需要查找办公软件、学习资源还是娱乐工具,在办公人导航上都能找到你需要的内容。 办公人导航-实用的办公生活导航网站!https://ww…

Linux内核测试技术

Linux 内核是Linux操作系统的核心部分,负责管理硬件资源和提供系统调用接口。随着 Linux 内核的不断发展和更新,其复杂性和代码规模也在不断增加。因此,确保内核的稳定性和可靠性变得尤为重要。内核测试技术是实现这一目标的关键手段。本文将…

Java使用Graphics2D画图,画圆,矩形,透明度等实现

背景 如上图,需要使用Java生成一个图片, 并以base64编码的形式返回给前端展示。 使用Graphics2D类,来进行画图,其中需要画方框、原型、插入图标、写入文字等,同时需要设置透明度等细节点 环境:Jdk17,springboot2.7.13 代码如下 有详细的注释 package com.demo;import c…

白帽子的海外第一单,750刀

国际惯例,给兄弟们看图 这是我们师傅挖国外SRC的部分赏金截图 就问你!挖国外漏洞赚美金香不香! 现在国内SRC越来越卷了,越来越多的白帽子开始挖海外漏洞赚美金。海外SRC真的比国内赏金高很多,不说高危漏洞&#xff0…

自编码器笔记

编码器解码器自编码器 先压缩特征,再通过特征还原。 判断还原的和原来的是否相等 encode data 在一个“潜在空间”里。它的用途是“深度学习”的核心-学习数据的特征并简化数据表示形式以寻找模式。 变分自编码器: 1. 首先、假设输入数据是符合正态分布…

《mnist_model.h5》在flask中加载mnist模型

一、在tensorflow中新建及保存模型 启动Jupyter Notebook 新建Notebook 代码 from flask import Flask, request, jsonify # type: ignore import numpy as np # type: ignore import tensorflow as tf # type: ignore import json from PIL import Image # type: i…

bigtop gradle 任务依赖关系

./gradlew deb 会编译ubuntu的所有deb包 任务deb会依赖17个任务,它们会按字母排序执行,如下: alluxio-deb bigtop-groovy-deb bigtop-jsvc-deb bigtop-utils-deb flink-deb hadoop-deb hbase-deb hive-deb kafka-deb livy-deb phoenix-deb …

React 19 新特性集合

前言:https://juejin.cn/post/7337207433868197915 新 React 版本信息 伴随 React v19 Beta 的发布,React v18.3 也一并发布。 React v18.3相比最后一个 React v18 的版本 v18.2 ,v18.3 添加了一些警告提示,便于尽早发现问题&a…

51单片机STC89C52RC——8.1 8*8 LED点阵模块(点亮一个LED)

目录 目的/效果 一,STC单片机模块 二,8*8 LED点阵模块 2.1 电路图 2.1.1 8*8 点阵模块电路图 2.1.2 74HC595(串转并)模块 电路图 2.1.3 芯片引脚 2.2 引脚电平分析 2.3 74HC595 串转并模块 2.3.1 装弹(移位…

强化学习专题:强化学习知识梳理(一)

2024/6/23: 前段时间有幸完成了大学期间的第一篇论文。在面试之前复盘一下关于自己论文中DQN的一些相关点。 浅谈主要区别(在线 or 离线) 首先,一切的开始是强化学习中时序差分方程,这体现了强化学习方法的优化策略。在…

【MySQL进阶之路 | 高级篇】MySQL8.0索引新特性->降序索引与隐藏索引

1. 支持降序索引 降序索引以降序存储键值.虽然在语法上,从MySQL4版本已经支持降序索引的语法了,但实际上该DESC定义是被忽略的.知道MySQL8.x版本才开始真正支持降序索引.(仅限于InnoDB存储引擎). MySQL在8.0版本前创建的仍然是升序索引,使用…

PADS系列:如何导入元件库新建元件

对于普通的原理图,位置的摆放是比较随意的,并且也没有一些特殊的或者元件库里面没有的元件,相对来说绘制会比较简单。但是如果碰上复杂一点的电路,要绘制起来就会比较麻烦,需要一些新的PADS使用技巧,最基础…

云计算考试题

Cloud ❀ 云计算-虚拟化常见的两种架构_裸金属架构和宿主型架构的区别-CSDN博客 为啥要成2 11 bcd 16 acd abcd BCD NAS为啥支持文件存储的协议 选BCD 什么是网络文件系统 选bcd 错题 选abc 选bcd 选 abd

NetSuite Account Merge 科目合并功能分析

最近项目中,客户有提到过能否将不用的Account与新建的Account进行合并,即我们所说的Merge功能~可以,但是该功能有使用的限制,比如最直接的一点需要注意,不同类型的Account是不可以使用Merge功能的&#xff…