The 10,000-word long article continues to break my record for the length of articles, covering all aspects of front-end development. This article will continue to be updated and improved. Some ideas may be arbitrary or incomplete. Comments and additions are welcome to improve this article. thank you


I’ve been working on the front end alone for a long time, and I’m the norm. As the business expands and some people are added, it’s time to start thinking about collaboration and coding specifications. This article records some of my thoughts when developing the front-end collaboration specification, hoping to help you as well.

A person can go faster, a group of people can go farther, the premise is a unified strategy, but also constant reflection and optimization.


The following is an overview of the table of contents, which shows that this is a lengthy article

  • 1 Workflow Specification
    • 1.1 development
      • 1.1.1 Version specifications
      • 1.1.2 Version control System specifications
      • 1.1.3 Submission Specifications
    • 1.2 Construction Specifications
    • 1.3 Publish workflow specifications
    • 1.4 Continuous Integration
    • 1.5 Task Management
  • Technical stack specification
    • 2.1 Technology Selection
    • 2.2 Embrace new technologies
  • 3 Browser compatibility specifications
    • 3.1 Determining compatibility Policies
    • 3.2 Determining the Browser Classification
    • 3.3 Obtaining Statistics
  • 4 Project organization specifications
    • 4.1 General project organization specifications
    • 4.2 Directory Organization Style
    • 4.3 Scaffolding and project templates
  • 5 Coding Specifications
    • 5.1 Javascript
    • 5.2 HTML
    • 5.3 CSS
    • 5.4 Code Formatting
    • 5.5 integrated
    • 5.6 Framework specific Style Guide
    • 5.7 Code Review
  • 6 Document Specifications
    • 6.1 Establishing the Document Center
    • 6.2 Document Format
    • 6.3 Defining a Document template
    • 6.4 A discussion is a document
    • 6.5 Comments are documents
    • 6.6 Code is documentation
  • 7 UI design specifications
  • 8 Test Specifications
    • 8.1 Test Process
    • 8.2 Unit Testing
  • 9 Exception handling, monitoring, and debugging specifications
    • 9.1 Exception Handling
    • 9.2 log
    • 9.3 Monitoring Exceptions
  • 10 Front – and back-end collaboration specifications
    • 10.1 Collaboration process specification
    • 10.2 Interface Specification
    • 10.3 Interface Document Specifications
    • 10.4 Interface test and Simulation
  • Training/knowledge management/technology precipitation
    • 11.1 New personnel training
    • 11.2 Create technical atmosphere
  • 12 feedback


CHANGELOG

  • 2019.7.28 New technology selection
  • 2019.7.29 Added Obtaining Browser statistics
  • The interview question bank will be added in the section of building the technical atmosphere
  • Updated article series on September 27, 2019


series

  • If I am the Leader of the front-end team, how to develop the front-end collaboration specification? 🔥
  • If I am the Leader of the front end team, how to do the summary design
  • If I am the Leader of the front end team, how to use Kanban for task management?


What is a specification?

Norm, noun: a standard, such as a code of ethics, a technical code, etc, that is clearly prescribed or agreed upon. Verb meaning: refers to the operation in accordance with the requirements of established standards, norms, so that a certain behavior or activity to reach or exceed the prescribed standards, such as: standardized management, standardized operation.


Why is specification needed?

  • Reduce the cost of integrating new members into the team and avoid digging holes to some extent
  • Improve development efficiency, team collaboration efficiency, reduce communication costs
  • Achieve a highly unified code style, easy review, on the other hand can improve the maintainability of the project
  • Specifications are the basis for automation
  • A specification is the direct output of a team’s knowledge sediment


What does the specification contain?

As the title of this article indicates, the front-end collaboration specification does not only refer to the “coding specification”. This specification involves all aspects of the front-end development activities, such as the management of the code base, the front and back end collaboration, the code specification, and the compatibility specification.

It’s not just within the front end team that we need to collaborate, we need to collaborate with the product/design, back end (or native client team), and testing throughout the entire software lifecycle, and we need to cover all of that.


If I were the Leader of a front-end team, how would I make a front-end specification? What should the specification contain?


1 Workflow Specification

1.1 development

1.1.1 Version specifications

The versioning number of a project should be iterated according to certain rules, and the use of a semantic versioning specification is recommended here, which allows users to understand the scope of a versioning change. The rules are as follows:

  • Major version number: When you make an incompatible API change,
  • Sub-release number: When you make backwards compatible functionality additions,
  • Revision number: When you make a backwards compatibility issue fix.


⬆️ Back to top

1.1.2 Version control System specifications

Most teams use Git as a repository, and managing code is a skill. Especially when multiple people collaborate concurrently and need to manage multiple versions of software, well defined repository management practices can make large projects more organized and improve the efficiency of collaboration among members.

A popular Git branching model/workflow is Git-flow, but most teams have their own Git workflow specification, such as our team’s branching specification

Git has a number of workflow methodologies, and the choice of workflow may depend on the size of the project, the type of project, and the structure of the team members.

For example, a simple personal project may not require complex branching. Our changes are committed directly to the Master branch.

For an open source project, other than the core team members, contributors do not have permission to submit, and we also need some means to verify and discuss whether the contributed code is reasonable. So the fork workflow is more suitable for open source projects.

Understanding common workflows can help you organize or create workflows that are appropriate for your team and deliver team collaboration efficiency:

  • Simple centralized
  • Workflow based on function branches
  • Git Flow 🔥
  • Fork/Pull Request workflow


⬆️ Back to top

1.1.3 Submission Specifications

Organized submissions can improve the overall quality of the project. It has at least the following advantages:

  • The submission information in a uniform format helps automate the generation of CHANGELOG
  • A repository is not just a repository of code, it is a development log of the project, and it should be clear what the commit did. These records should help latecomers quickly learn and review your code, and should make it easy for other collaborators to review your code
  • Normalizing submission information encourages committers to submit meaningful, appropriately granular ‘submissions ‘. Committers have to figure out how to describe the commit, which passively encourages them to control the granularity of the commit


One of the most popular submission specifications in the community is the Angular Submission Specification, but these are nice:

  • Atom
  • Ember
  • Eslint
  • JQuery


In addition, these tools can help you verify the commit information and generate CHANGELOG:

  • Conventional – Changelog – Generates changelog and release information from the project submission information
  • Commitlint – Validates the commit information
  • Commitizen – 🔥 simple submission specification and submission help tool, recommended
  • Standard-changelog-angular style commit command line tool


⬆️ Back to top

1.2 Construction Specifications

For teams or projects that need to maintain multiple scenarios, it is important to have a unified build toolchain that emphasizes “engagement over configuration” and allows developers to focus on the business. Why use Vue-cli3? > < p style = “max-width: 100%; clear: both; min-height: 1em;

  • The first is that these tools advocate ‘convention over configuration’. That is, according to their specifications, you can achieve out of the box, rapid development of business. This is important in team collaboration, and we don’t recommend that team members care about long webPack build configurations
  • Vue-cli3 removes the CLI Service layer and updates the tool chain independently. This means that the project’s build scripts and configurations are maintained in a separate service project, rather than having WebPack configurations and dependencies in each project directory as before. The benefit of doing this is to upgrade the entire build chain independently and simply
  • Flexible plug-in mechanism. Custom builds for teams should be wrapped into plug-ins so that they can be updated independently.

We can choose a third-party CLI, and of course we can customize our own build chain, which should have the following features as described above:

  • Strong agreement, reflect the norms of the team. First, it should prevent team members from caring about or changing the configuration details of the build, exposing the minimal configuration interface.Also, a build tool is not just about building, it usually integrates code inspection, testing, and so on.
  • Easy to upgrade. In particular, it makes sense for teams to maintain multiple project scenarios

Here are some of the most popular build tools in the community. Of course, you can develop your own CLI for your own team, but the following tools are still useful:

  • Create-react-app-🔥 Start react development with zero configuration
  • Vue-cli-🔥 Zero-configured, progressively enhanced project build CLI
  • Parcel – Zero – configured Web application packaging tool
  • Fusebox – Fast and easy to use packaging tool
  • Microbundle – zero configuration, based on Rollup, suitable for packaging ‘libraries’


⬆️ Back to top

1.3 Publish workflow specifications

A release workflow is a set of processes for releasing ‘finished software’ to the public (such as testing or production), which can be normalized and then automated.

For example, a typical publishing workflow looks like this:

  • Code changes
  • Commit code changes to a remote repository
  • Program passes CI tests (e.g. Travis turns green)
  • Upgrade the version in package.json
  • Generate the CHANGELOG
  • Submit package.json and changelog. md files
  • On the Tag
  • push

If you follow the above specification, then you can automate the process using existing tools in the community. These tools include:

  • conventional-changelog-cli
  • conventional-github-releaser
  • It’s actually not particularly difficult to develop one yourself.


⬆️ Back to top

1.4 Continuous Integration

Once the complete development workflow has been identified, continuous integration services can be used to automate the entire process. For example, a typical CI process:

What is continuous integration and what does it mean?

We need to break continuous integration down into two separate words to understand, what is continuous? What is integration?

Continuous, “Continuous,” can be interpreted as’ frequent ‘or’ Continuous’. Whether it is continuous integration, agile development thinking, kanban, they all believe that ‘continuity’ is the foundation of them.

A common example is code review. A ‘continuous’ code review is a review of code as soon as it is changed (such as save, or IDE live review, or commit to the repository), whereas a’ non-continuous’ code review is a review after all code has been written. Comparing the two, it can be found that continuous code review can find errors earlier and easier to understand and deal with, whereas non-continuous code review may find a bunch of errors, and a small miss can lead to a big mistake.

The concept of ‘continuity’, which can be applied to all aspects of software development, is essentially the breaking up of the traditional waterfall software development process into smaller development loops that continuously output products, while the products continue to feedback and correct upstream.

So what is’ integration ‘? The narrow definition of integration can be simply referred to as’ integration testing ‘. Integration tests can be static testing of code, unit testing, integration testing after passing unit tests, running E2E tests in a simulated environment after the application is assembled, and so on. That is, a series of automated tests are performed here to validate the software system.

Continuous integration services, in a broad sense, are not just testing. They also give rise to many concepts, such as continuous delivery and continuous deployment, as shown below

OK, to summarize why continuous integration is beneficial:

  • Catch mistakes early and try and error quickly. The earlier errors are discovered, the lower the cost of handling them
  • Automate workflow to reduce human intervention. Humans make more mistakes than machines, and machines are good at doing repetitive things


For continuous integration specifications, these are typically defined:

  • The execution environment, such as container, Node version, operating system, and so on
  • Trigger conditions. What branch will trigger, what tasks will trigger, and so on
  • Tasks performed
  • Divide the stages of continuous integration. Such as
    • Checking: this includes unit tests and code Lint. All code pushed into the repository runs through this phase. It is generally possible to skip this phase by including [CI skip] in the submit title
    • Build: Build the front-end project. Only commit or release branches with a version tag will run the build task
    • Release: Deliver/publish the results of the front-end build. Only commit or release branches with a version tag run the release task after a successful build
  • Define the continuous integration script template


Common CI services:

  • Github
    • Travis CI
    • CircleCI
    • A complete list
  • GitLab: Gitlab-CI
  • general
    • Jenkins


extension

  • What is continuous integration


⬆️ Back to top

1.5 Task Management

Being a front-end Leader involves task management. Kanban is the most popular task management tool, which can help us understand the progress of the project, the allocation of resources, and restore the development site.

In the first year after graduation, I worked in a small outsourcing company. I even tried to sell Kanban and Agile project management to my boss. I wanted to improve the inefficiency of project management.

At that time, I drafted a “Kanban implementation rules”, so I have learned a lot about task management.

Let’s talk about some useful tools:

  • Issue-based Kanban – You can do task management based on the Gitlab or Github issues, both of which support Kanban. Geek, recommended
  • Tower – Kanban task management. A small team is more than enough. We use this product right now
  • Teambition – similar to Tower, not used in depth
  • Trello – High level of appearance.


⬆️ Back to top


Technical stack specification

My current company had a very messy front-end stack, with Vue, React, and AngularJS all in very different styles. I just wanted to pick up the package and leave. As for what happens when technology stacks are not regulated, refer to Indian planes: “Why do Indian planes get crashed so often?” >

Very few people can master all three frameworks, let alone a team.

Like programming languages, each of the three frameworks has its own design philosophy, unlike libraries, which are cheap to replace; And behind the framework is a framework, an ecology. Behind each framework are development thinking, ecosystems, supporting tools, best practices, and performance tuning. The cost of mastery and proficiency in a framework is high.

So the team’s development efficiency is based on a stable and skilled technology stack. Stable technical stack specifications facilitate team collaboration and communication; In addition, if the team is well versed in the technology stack, it will be relatively easy when problems arise or deeper tuning is needed.

Front-end technology stack specifications include the following types:

  • Programming language – Typescript or Javascript
  • The UI framework and its ecosystem, as well as alternatives. The ecology behind it is huge:
    • UI framework
    • routing
    • State management
    • Component library
    • internationalization
    • animation
    • Server-side rendering
    • Scaffolding and CLI tools
    • Component test
  • Styles. This includes naming conventions, preprocessors, methodologies, and more
  • Animation engine
  • Qa. includes testing, Lint, formatting tools, monitoring
  • Project build tool flow. For example, webpack and vue-cli
  • Package manager. NPM, yarn
  • Project management tools
  • Time processing. For example, my Moment. Js
  • A template engine
  • The development tools
  • Backend development framework
  • Tool library
  • Development/debugging tools
  • , etc.

Refer to our team’s technology stack specification


⬆️ Back to top

2.1 Technology Selection

How do you spec, or select, a team’s technology stack from zero? For example, to determine the options, are you going to choose Vue or React(a potentially controversial topic)?

Just a few days ago the SegmentFault answered a question: < When to use vue and when to use React? > < p style = “max-width: 100%; clear: both; min-height: 1em; :


The article “Talk about the DOS and don ‘ts of technology selection” is very well written and gave me some inspiration. Using the examples of the responses above, let’s talk about some of the ways in which the technology is selected (scoring items):

  • Choose the technology you are most familiar with. As mentioned above, if the team is familiar with the technology, it can better control the risk of using it and make it easier to tune the application. So the familiarity of the members, or at least the Leader, is one of the scoring items in technology selection.

    One of the reasons our team finally chose React was that we were familiar with it and it had already worked well in several existing applications, so React + 1

  • Choose open source technologies with strong ecology and community support. Having a strong ecology and community means you don’t have to build wheels over and over again, or problems can be solved quickly, and there are more options. At the corporate level, it is also easier to hire people using active technology.

    The example above also mentions this, a few years ago React ecology was stronger than Vue, so React + 1

  • Choose growth-stage technologies. There is a sentence in “Talk about the Considerations of technology selection” : ‘The minimum criteria for selecting a technology is that the life cycle of the technology must be significantly longer than the life cycle of the project.’

    The basic principle of selection is that the technology we choose should be forward looking and future-oriented. This is why we tend not to choose ‘obsolete’ technologies such as AngularJS(1.x), Backbone. Because there are better options out there and you don’t have to be too conservative.

    ‘Moving forward’ also means being able to anticipate where the technology will go in the future. There are many factors to look at, such as the support of dafang, current community activity, development activity, and so on

    React, Vue, etc. React Hook, ConcurrentMode, Async Rendering, etc. I think Vue and React are even on that score

  • API stability. A typical example is Angular and Python, where API instability can split the community and cause projects to become expensive to upgrade or unable to upgrade, resulting in technical debt.

    Fortunately, with so many lessons from history, open source projects are cautious about making API changes right now.

    React and Vue are still even on this score

  • Infrastructure coordination. A technology often does not exist in isolation, it needs to cooperate with other technologies, and the degree of integration between these technologies also needs to be considered.

    It depends on how the team uses it. For example, our team uses Typescript all the time. It’s not ideal to use Vue with Typescript, so React + 1

  • Business Considerations one of the things mentioned in “Talk about technology Selection considerations” is’ learn to think from the business side ‘. This means that the selection requires a full understanding of the business, user needs, the primary problems to be solved, and the possible risks, and then the objectives are decomposed to carry out specific technical selection, model design, and architecture design.

    A typical example is Rails, which became popular around the world 10 years ago. Is it Rails or Java/C#/PHP? A lot of startups (Github, Gitlab, Twitter) go for the former. They need to prototype fast and hit the market fast. Rails is cool and fast.

    So the front end seems a little far away from the business? As the ‘big front’ grows, the impact of our work on our business will only grow.

    Take React Native as mentioned above for example. At that time, we considered applying React Native technology in mobile terminal to realize cross-platform client, which is the business impact. Is React going to be plus 1 again? Similarly, what about server-side rendering, Serverless, etc., expect the front end to become more prominent

In summary, React won out in this case.

Extension:


⬆️ Back to top

2.2 Embrace new technologies

Of course, teams should also be encouraged to learn new technologies and eliminate old technology stacks. Because in general, new technologies or solutions are created for greater productivity. When a team accommodates a new technology selection, consider the following:

  • Cost of learning. Consider the receptivity of team members. If the cost is less than the benefit, there will be more resistance to implementing estimates within the team
  • Earnings. Whether we can solve some of the current pain points
  • Consider the risks. Generally we cannot use an experimental technology in a production environment

As far as our team is concerned, each member has his or her own interested direction and field, so we can work together, explore our respective fields, and then share the results. If it is reliable, we can test it in experimental projects first, and then extend it to other projects at last.


⬆️ Back to top


3 Browser compatibility specifications

The front end team should write their own browser compatibility specifications in the application manual, based on the user profile, type of application, development cost, browser market statistics, and so on.

With browser compatibility specifications, front-end development and compatibility testing can be justified to avoid disputes; It is also a statement by the front end team that the front end developer can ignore browsers that do not comply with the browser compatibility specifications unless specifically requested.


3.1 Determining compatibility Policies

Progressive enhancement versus elegant degradation. These are two different strategies: progressive enhancement ensures the experience of older browsers, while providing a slightly better experience for newer browsers that support new features; Elegant downgrading is the opposite, providing the best experience for modern browsers, while older browsers are relegated to the next best thing, with roughly the same functionality.

Choosing a different strategy can have a significant impact on front-end development, but the developer has no choice. Determining which compatibility strategy to use should depend on user weight, with elegant degradation if most users use modern browsers and progressive enhancement if not.


⬆️ Back to top

3.2 Determining the Browser Classification

YUI introduced the browser grading principle, which is still true today. Simply put, the browser is divided into multiple levels, with different levels representing different levels of support. For example, our team has divided browsers into three levels:

  • Full compatibility: guarantee 100% normal function
  • Partial compatibility: Only ensure that the function, style and requirements are roughly the same. Some bugs that do not affect the principal’s requirements and functionality will be prioritized or not addressed at all.
  • Incompatible: Compatibility is not considered

In general, browsers are ranked based on market distribution, user share, development cost, and other factors.

As an example, here are our compatibility specifications for management systems:


⬆️ Back to top

3.3 Obtaining Statistics


Baidu Statistics is the most widely used, free traffic analysis platform for Chinese websites. As shown in the figure above, you can get the real browser usage of the terminal through these statistical platforms. Click to see the example.

If your company has not developed its own monitoring service, it is recommended to use one of these free, big-vendor supported monitoring tools:


Common browser statistics can be obtained from:

  • Baidu flow research institute: mainly provide domestic browser statistics
  • Statcounter: International browser statistics
  • Browser release year statistics


Determine if the browser supports a feature:

  • caniuse
  • MDN


⬆️ Back to top


4 Project organization specifications

Project organization specifications define how to organize a front-end project, such as project naming, project file structure, version numbering specifications, and so on. Especially for open source projects, formal project organization is even more important.

4.1 General project organization specifications

A typical project organization is as follows:

  • Readme. md: Project description, this is the most important. This is where you must provide key information about the project or access to relevant information. Usually contains the following information:

    • Brief description, main features of the project
    • Runtime environment/dependencies, installation and build, test guide
    • Simple sample code
    • Document or document entry, other version or related resource entry
    • Contact information, discussion groups
    • Licensing, contribution/development guidelines
  • Changelog. md: Place the changes for each version, usually describing what changed for each version. It is convenient for users to determine which version should be used. For the CHANGELOG specification, see Keep a CHANGELOG

  • Package. json: Front-end projects must. Describes the current version, available commands, package names, dependencies, environment constraints, and project configurations.

  • .gitignore: Ignore unnecessary files to avoid committing automatically generated files to the repository

  • .gitattributes: Git configuration. There are some cross-platform differences in behavior that may need to be configured here, such as newline rules

  • Docs /: Detailed documentation of the project, optional.

  • Examples /: Example code for the project, optional.

  • Build: The project tool class script is placed here and is not required. If you use the Unified build tool, there is no such directory

  • Dist /: Output directory of project build results

  • SRC /: source directory

  • Tests /: unit test directory. According to the Jest specification, the __tests__ directory is usually in the same parent directory as the module being tested, for example:

    /src
      __tests__/
        index.ts
        a.ts
      index.ts
      a.ts
    Copy the code
  • Tests: a global test directory, usually containing use cases such as application integration tests or E2E tests

  • .env*: We often use environment variables in projects to influence the behavior of applications in different runtime environments. DotEnv allows you to read environment variables from a file. There are usually three files:

    • .envCommon environment variables
    • .env.developmentEnvironment variables for the development environment
    • .env.productionGenerate environment variables for the environment

    Basically, these files are changed infrequently, and team members should not make random changes to avoid affecting other members. The.env.*.local file is usually used to override the above configuration, and the repository is set to ignore the *.local file.


For open source projects, these directories are often included:

  • LICENSE: indicates the project permission
  • .github: Open source contribution specifications and guidelines
    • CONTRIBUTING: Contribution guidelines, which typically provide input specifications, as well as basic organization, architecture, and other information about the project
    • CODE_OF_CONDUCT: Code of conduct
    • COMMIT_CONVENTION: COMMIT_CONVENTION, as mentioned above
    • ISSUE_TEMPLATE: Issue template. Github can automatically identify this template
    • PULL_REQUEST_TEMPLATE: PR template

Any good open source project is your teacher, such as React, Vue…


⬆️ Back to top

4.2 Directory Organization Style

The above is just a general project organization specification. How the specific source code is organized depends on the technology stack you use and the preferences of your team. There are many tutorials on how to organize the XX project. To summarize, there are three main styles of project organization:

  • Rails style: divided into different directories according to the file type, e.g. components, constants, typings, views. This comes from the Ruby-on-Rails framework. It divides the different directory types according to the MVC architecture. The typical directory structure is as follows:

    Appmodels # Views # Controllers # Helpers # Assets # Static resources config # Configure applic.rb database.yml Routes. rb # Routing control locales # Internationalize configuration environments/ db # database relatedCopy the code
  • Domain-style: Creates a separate directory based on a function or service. This directory contains multiple types of files or directories nearby. For example, in a typical Redux project, all the project files are located in the same directory nearby:

    Users/
    Home/
      components/
      actions.js
      actionTypes.js
      constants.js
      index.js
      model.js
      reducer.js
      selectors.js
      style.css
    index.js
    rootReducer.js
    Copy the code
  • Ducks style: Advantages Similar to domain-style, but more thorough, it usually defines associated elements under a file. Vue’s single file component is a good example, but Vuex also uses this style:

    <template> <div id="app"> <h1>My Todo App! </h1> <TodoList/> </div> </template> <script> import TodoList from './components/TodoList.vue' export default { components: { TodoList } } </script> <style lang="scss"> @import './variables.scss'; / *... */ </style>Copy the code


For the most part, we use a hybrid directory structure, such as:

SRC/components/ # 🔴 project generic 'display component' Button/ index.tsx # Component entry, # load.svg # Static resource style.css # Component style... Containers / # 🔴 contains' container components' and 'page components' LoginPage/ # page components, such as login Components / # page level display components, which cannot be reused with other page components. The button. TSX # component is not necessarily a directory, but can be a single file for a simple component. Ts # redux reduces useLogin. Ts # (optional) Type.ts # typescript type declaration style.css logo.png message.ts constants.ts index.tsx HomePage/... Hooks / # 🔴 hooks uselist.ts usePromise. Ts... Ts # redux Stores contants. Ts # Global constantCopy the code


Framework officials rarely intervene in the way projects are organized. Readers can use the following resources to establish their own project organization norms:

  • Redux FAQ: Code structure
  • react-boilerplate
  • Vuex project structure
  • React Component Design Practice Summary 02 – Component organization


⬆️ Back to top

4.3 Scaffolding and project templates

Once the project structure specification has been finalized, you can create your own scaffolding tool or project template to quickly initialize a project or code template.

Related resources:

  • Yeoman – old project scaffolding tools
  • Plop – Code generation assisted CLI
  • Hygen – Similar to plop
  • Generact – Generate the React component. Most components have a similar file structure. This tool helps you generate the repeated code
  • Babel -code- Generator – Utilizes Babel for more advanced code editing and automatic generation


⬆️ Back to top


5 Coding Specifications

Most ‘front-end specifications’ on the network refer to coding specifications, which are’ narrow ‘front-end specifications.

A unified coding specification is useful for the long-term maintenance of a team project. Consistent code specifications can enhance team development collaboration, improve code quality, and reduce legacy system maintenance burdens.

The immediate benefit is to avoid writing bad code. Bad code has little to do with novices and veterans, and I have seen the benefit of “senior” engineers who have worked for many years writing bad code. Such code can become unmanageable over the iterations of the project.

Modern Lint tools are so advanced that they can constrain almost any coding behavior. Such as restricting the length of a file, function complexity, naming conventions, annotation conventions, interface blacklists, deadcodes, checking for simple logic errors…

Every programmer has his own idea of “good code”, and a unified code specification can avoid unnecessary controversies and disputes just like qin Shihuang unified the Warring States.


In fact, rather than build your own front-end coding specifications, the author recommends that you choose the community’s settled specifications. There are many resources in this area, so this article does not arbitrarily put forward its own recommendations. The following resources are recommended:


5.1 Javascript

  • Lint tools
    • Eslint-🔥 is currently the community’s most popular, general-purpose Javascript Lint tool, the Babel of the Lint world. Customized plug-ins and preset are supported. If you don’t want to mess around, you can select some of its predefined configurations
    • TSLint – Typescript Lint tool. ESLint is recommended because it is almost obsolete
  • specification
    • JavaScript Standard Style – 🔥 Zero-configured, ‘Standard’ JavaScript coding specification. The underlying layer is based on Eslint. Typescript is not currently supported
    • Airbnb JavaScript Style Guide – Airbnb code specification, industry benchmark
  • Type checking. I’ll put them here for now because they belong together’Static testing’
    • Typescript-🔥 a superset of the Javascript language, which is a ‘new’ language rather than a simple type checker. However, it also supports native Javascript type checking
    • Flow – A Type checker from Facebook with syntax similar to Typescript. Personally, I recommend using Typescript


⬆️ Back to top

5.2 HTML

  • Lint tools
    • HTMLHint
    • bootlint
  • specification
    • Code Guide


⬆️ Back to top

5.3 CSS

  • Lint tools
    • Stylelint-🔥 Is a general CSS coding check tool that supports the latest CSS syntax, css-in-JS, and other CSS syntax classes (such as SCSS, Less). It also has a predefined configuration and is recommended
  • specification
    • Airbnb CSS / Sass Styleguide
    • Code Guide
    • More and more
  • methodology
    • BEM – 🔥 BEM naming convention
    • OOCSS
    • smacss


For CSS, Bootstrap is a traditional UI framework that is well organized and worth learning


⬆️ Back to top

5.4 Code Formatting

  • Prettier – 🔥 Leave everything about code formatting to it!

Basically, an Prettier can do all the formatting work for an Prettier, and then use Eslint to override semantically related checks


⬆️ Back to top

5.5 integrated

  • Isobar front-end code specification and best practices
  • Convex laboratory code specification
  • Baidu FEX specification
  • Old NEC spec. – A little old


⬆️ Back to top

5.6 Framework specific Style Guide

  • vue-style-guide
  • Airbnb React/JSX Style Guide
  • React Component design Practice summary – self-recommendation of the author wrote React component design related practice


⬆️ Back to top

5.7 Code Review

The Lint tools and type checkers described above can constrain code styles and avoid low-level syntax errors. But even with the above Lint and type checking, code may not necessarily be ‘good’.

Many code design ‘best practices’ cannot be covered by visualized automated tools or documentation, where’ experience ‘or’ wisdom of crowds’ can come in handy. For example, the Code Review phase checks for these things:

  • Programming principles, design ideas. For example, conforms to the SOLID principle? Is it DRY enough? Whether the interface design is simple and easy to extend,
  • Module coupling, code duplication
  • Code robustness. Whether there are memory leaks, whether there are thread safety, whether there are potential performance issues and exceptions, and whether errors are handled
  • Code performance and efficiency.
  • Is there a scenario that you have considered?

If you’re doing Code Review for the first time, set up a checklist and check against it. After proficiency, the heart naturally no code.


Code Review has many benefits, such as:

  • Code Review allows other members to familiarize themselves with the Code. This ensures that others can pick up your work quickly or help you solve problems
  • Improve code quality. There’s no doubt about itThe initiativeFor example, if your code needs to be reviewed, you will consciously try to improve the quality of your code. On the other hand, other members can check the quality of the committer’s code
  • Review or improve the programming skills of new members. When we train new people, because we don’t trust the code they submit, we do a Review to see if the code passes. On the other hand, this is a real case, which can improve their ability quickly


There are two ways to Review Code: one is committed and one is timed:

  • When submittingMost open source projects take this approach. Colloquially, this is a Pull Request. Code can only be added to the official repository if it has passed tests and reviews by other members. This approach is also known as’ blocking ‘code checking and is commonly used in conjunction with GitFlow.
  • timingAt the end of the project, at a project milestone, or at a fixed time (daily, weekly…) Team members get together to review the code they have written and let other members review it

Code Review is difficult to implement, but it also depends on the situation of your team. The team with less money and more work needs less time to take care of other members’ Code immediately. This is where regular Review is more useful, as it seems more ‘time-saving’.

Review at submission can be for new people, if you don’t trust their code or want to help them improve their coding skills.


Related resources:

  • Code Review Best practices
  • Should we do Code Review? Thoughts after arguing with BAT senior architects
  • Some Code Review tools


⬆️ Back to top


6 Document Specifications

Documentation is essential for project development and maintenance, learning, refactoring, and knowledge management.

Like writing tests, most developers find writing documentation a pain, but only time will tell. For example, for a company with a large turnover of people, if there is a standardized documentation system, the transition will be very easy to change.

In a broad sense, a document does not simply refer to the ‘specification document’ itself. It has many forms, sources and carriers, and can describe a knowledge and the process of knowledge formation and iteration. Examples include repository code commit records, code comments, decision and discussion records, CHANGELOG, sample code, specifications, traditional documents, and so on


6.1 Establishing the Document Center

Our company is an IM company, so we used to share documents by using our own communication tool first, which had a big problem:

  1. If you don’t have the habit of archiving (such as back-end API documentation, which is generally not actively archived because it is maintained by the back end), documents can be lost, and communication tools won’t keep your documents permanently. When a file is lost, it needs to be re-requested by the document maintainer
  2. Unfortunately, the document maintainer also manually archived the document locally, which led to the problem that if the work was transferred, it would take some time for other developers to find it. Lost is lost
  3. It is troublesome to send a new copy every time the document is updated, and it may be missed, resulting in inconsistency.
  4. Records of knowledge learning and meaningful discussions are not archived.

This is a very primitive form of document sharing that many small teams do.

The document for the project itself is recommended to be placed in the associated project repository and iterated with the project code, which is most convenient when we are retrieving or tracking the history of the document.

However, many applications span multiple teams, and each team has its own documentation output (such as requirements documents, system design documents, API documents, configuration documents, and so on), often not in a repository. At this point, the documents are scattered. So a unified documentation center is necessary.

Our company’s current solution is Git+Markdown, which means that all documents are placed under a Git repository. I also considered commercial solutions, such as graphite documents and Tencent documents, but the management did not trust these services.

The general organization of git projects is as follows:

Specification/A application/product/design/API documentation/Testing/Other/B application /Copy the code

Git repositories (such as Gitlab) have many advantages, such as history tracking, versioning, issue discussion (issues can be associated, or submitted), multi-person collaboration, search, rights management (permissions for different people for different repositories or groups), and so on.

Git+Markdown meets most of the developer’s needs. But Git is best at working with plain text files and has little to do with binaries, and there is no way to preview and edit these types of documents online.

Therefore, Git+Markdown cannot meet various document processing needs, such as mind map, chart, table, PPT, whiteboard and so on. After all, it is not a professional document processing tool. Therefore, for rich document requirements scenarios such as products and designers, documentation is often managed in a traditional manner or with more professional tools.


⬆️ Back to top

6.2 Document Format

Without a doubt, Markdown is the most suitable and versatile document format for developers. Support for online repository preview and change history tracking.

The following tools can improve Markdown development efficiency:

  • Visual editor
    • Visual Code: Most Code editing supports Markdown editing and previewing
    • Mou: The old editor for Mac
    • Typora: Cross-platform Markdown editor, recommended
  • Markdownlint: Code inspector
  • Extensions (Visual Studio Code):
    • Markdown All in One: All you need to write Markdown (keyboard shortcuts, table of contents, auto preview and more)
    • Markdown TOC: Generates the Markdown directory, my most commonly used Markdown plugin
  • Chart drawing tool:
    • Drawio’s web-based charting tool also has an offline client
    • KeyNote/PPT temporary drawing is also good


⬆️ Back to top

6.3 Defining a Document template

As for how to write a good document, it is difficult to be constrained by standards or specifications, because it is relatively subjective. A good document depends on the editor’s logical summary ability, expression ability, and whether he or she thinks from the perspective of the reader.

So, in most cases, we can provide a template for different types of documents, using the template to explain what a document needs to contain, and to guide the writer of the document.

For example, an API document might require the following:

  • Index of the interface
  • Version and change record of the interface
  • Usage and overall description, authentication and authentication, etc
  • Describes the specific interface
    • Functional specifications
    • Method name or URI
    • Parameter and return value definitions
    • Invoke the sample
    • Notes and so on

The specifications vary from team to team, but I’ll stop there.


Extension:

  • Writing specification of Chinese technical documents
  • The React RFC template


⬆️ Back to top

6.4 A discussion is a document

In general, Issues are an important source of information for an open source project in addition to official documentation. In the Issue, we can get other developers’ problems and solutions, give official feedback/votes, follow official updates, brainstorm with other developers, and more.

Therefore, I recommend the Issue communication mode more than IM, because it is convenient for archiving, indexing and searching. The IM discussion, like water, is gone forever.

Of course, the application scenarios of the two tools are different. If you use the Issue in the same way you use IM, the Issue will become very watery. The Issue is good for meaningful, purposeful discussions. So blame the developers for flooding the Github Issue.

There are so many useful things about issues that I recommend reading this article < How to Use the Issue Management Software Project? >

Now that many open source projects have introduced the RFC(Request for comment) process (see React’s adoption of the new RFC process, and Vue’s Darkest Day), developers can feel like “serfs in their own right”, and anyone can participate in the decision making of an open source project’s major events. Each RFC explains the motivation, detailed design, and strengths and weaknesses of the decision. In addition to the official documentation, these RFCS are valuable learning materials.

In my opinion, if there are no secrets involved, the team should involve more people in the design and decision-making of the project. The novice can learn a lot, while the initiator may be ill-considered.

Is Issue useful for enterprise application development?

Sure. For example, we can move the topic from IM to Issue:

  • Design scheme
  • Decision/Suggestion
    • Introduction of new functions and technologies
    • refactoring
    • Performance optimization
    • specification
  • discussion
  • Significant events
  • Planning or progress tracking
  • .


In addition, issues are usually classified by tags for easy organization and retrieval:


⬆️ Back to top

6.5 Comments are documents

The necessary and appropriate amount of comments is a road sign for the person reading the source code and can save many detources.

The Alibaba Java Development Manual summarizes some of the guidelines for annotations very well and recommends building annotation specifications based on them. In addition, annotations can be regulated to a certain extent through ESlint.


⬆️ Back to top

6.6 Code is documentation

There are a variety of tools that support parsing and generating documentation from code, which can simplify a lot of documentation maintenance for developers.

For example, it is often the case that you have changed the code, but the document forgot to synchronize. The ‘code as documentation’ approach at least keeps the documentation and code up-to-date; In addition, many tools analyze the data types of the code and automatically generate parameter and return value definitions for us, which can also reduce a lot of documentation and error rates.

For example, a component document can be generated using the following comment:

import * as React from 'react';
import { Component } from 'react';

/** * Props */
export interface ColumnProps extends React.HTMLAttributes<any> {
  /** prop1 description */prop1? : string;/** prop2 description */
  prop2: number;
  /** * prop3 description */
  prop3: (a)= > void;
  /** prop4 description */
  prop4: 'option1' | 'option2' | 'option3';
}

/** * Annotate the component */
export class Column extends Component<ColumnProps.{}> {
  render() {
    return <div>Column</div>; }}Copy the code


Related tools are:

  • The API documentation
    • Typescript
      • Tsdoc The official annotation documentation standard for Typescript
      • Typedoc is a document generator based on the TSDOC standard
    • Javascript
      • Jsdoc Javascript document annotation standard and generator
  • Back-end interface documentation
    • Swagger Restful interface documentation specification
    • GraphQL: This has many tools, such as GraphiQL, which integrates Playground with documentation, very advanced
    • Easy Mock is a visualized service that can quickly generate simulated data
  • Component document
    • StoryBook is a universal tool for developing, testing, and documenting components
    • React
      • Docz
      • Styleguidist
    • Vue
      • vue-styleguidist
      • Let me know in the comments if there are better tools


⬆️ Back to top


7 UI design specifications

This is a specification type that is easily overlooked. The author suffered from it. In the early days of our company, the UI was not professional and there was no so-called design specification. As a result, the products they designed were all borrowed from one another, and the components between multiple applications could not be reused. We had to waste time writing custom styles and components to pay for their unprofessionalism.

Readers interested in the importance of UI design specifications can check out the article “How hard is it to communicate between Development and design? – You only need one design specification >.

A quick summary of what UI design specifications mean:

  • Provide team collaboration efficiency (product and development)
  • Improve component reuse. A unified component specification makes components easier to manage
  • Maintain brand consistency throughout product iterations

Establishing a well-defined design specification requires a close collaboration between UI design and development, which can sometimes be driven by our front end.

For example, many open source UI frameworks are invented by developers at first without design involvement. Later, component libraries are gradually formed and UI designers are involved in the specification.

If your team does not intend to develop its own UI design specifications, it is recommended to use a ready-made open source component library:

  • Ant Design
  • Material-UI
  • Element UI
  • WeUI
  • Microsoft Fabric

These open source component libraries are well designed and developed, and come with well-established design principles, best practices, and design resource documents (Sketch and Axure) to help businesses quickly design high quality prototypes.


⬆️ Back to top


8 Test Specifications

Testing is an important way to ensure code quality, but few people want to spend much time on it.

As an author, I rarely write unit tests for business code and components unless I have very little confidence in the code, and I believe that writing tests is better than writing simpler code, such as breaking a function into smaller functions with a single responsibility.

However, it is necessary to test some low-level, shared code modules.

I don’t know what to test? In the article, there are some types of testing and common sense that developers need to pay attention to. If you break it down by phase, it looks something like this:


There are several types of tests that front-end developers need to focus on:

  • Unit testing: Tests independent software modules
    • UI component testing: Includes Snapshot testing
  • Integration testing: Based on unit testing, modules are grouped together to test their composability
  • E2E test: Test the application by simulating real users in a complete and real running environment. The main test front end and back end coordination
  • Compatibility testing: The browser compatibility specification is mentioned above, and you need to ensure that your version meets the compatibility requirements before submitting it to test/release
  • Performance testing: Tests and analyzes for performance problems
  • other:
    • Security testing
    • SEO test

Because the entire software development process may be less standardized for a small company, such as the difficulty of building a complete end-to-end test environment, which is not within the scope of the front end team, automated testing can be difficult to implement. However, it can be carried out gradually according to the team and business situation.

The more implementable, but also simpler, is unit testing, so this article will focus on unit testing as well.


8.1 Test Process

The first step is to define a suitable software test process, which can reduce the cost of communication and collaboration between the development and test teams and improve the test efficiency. For example, the current testing process of our team:


⬆️ Back to top

8.2 Unit Testing

Unit testing has many benefits, such as:

  • Improve confidence, adapt to change and iteration. If the existing code has a well-developed unit test, it can verify that the module is still working when the code is refactoring, and it can also help us quickly locate and fix the errors caused by the changes
  • Unit testing is the foundation of integration testing
  • Tests are documentation. If the documentation doesn’t solve your problem, look at the unit tests before you decide to look at the source code. Through these test cases, the developer can intuitively understand the basic API of the program unit
  • Improve code quality. Code that is easy to test is generally good code


What test?

Business code or business components are more difficult to unit test because they are more volatile and many teams have less energy to maintain unit tests on them. So it is usually only required to test some underlying/underlying component, framework, or service, with or without testing business code as appropriate


Criteria for testing:

  • Petroware’s Unit Testing Guidelines are recommended, which summarize 27 Unit Testing Guidelines and are very useful.
  • In addition, the unit testing guidelines summarized in Alibaba’s Java Development Manual are also good, although the title is Java, the guidelines are general.


Unit test indicators:

Test coverage is generally used for quantification, although there is some debate as to whether coverage can measure the effectiveness of unit tests.

In most cases, it is recommended that coverage be as high as possible, such as statement coverage of 70%; 100% statement coverage and 100% branch coverage for both core modules. Depends on the team

Extension:

  • What is the use of test coverage?


Related tools

  • 1. Headless Browsers are the most important environments for web automation. Often used for functional testing, unit testing, web crawler
    • puppeteer
    • Headless Chromium
  • The test framework
    • Jest🔥Facebook’s unit testing framework. Zero configuration, support component snapshot testing, module Mock, Spy. General scenarios, unit tests to follow the same
      • Component test
        • Testing – library 🔥
        • Enzyme
    • Intern
  • Unit testing
    • AVA
    • Jasmine
    • Mocha
    • Tape
  • Assertions library
    • Chai
    • expect.js
    • should.js
  • Mock/Stubs/Spies
    • sinon.js
  • Code coverage
    • istanbul
  • The benchmark
    • benchmark.js
    • jsperf.com


⬆️ Back to top


9 Exception handling, monitoring, and debugging specifications

Many developers often misuse or neglect exception handling. Proper and effective exception handling can improve the robustness and usability of an application, as well as help developers quickly locate exceptions.

9.1 Exception Handling

The exception handling specifications summarized in Alibaba’s Java Development Manual are also of great reference significance for JavaScript exception handling, such as:

  • Exceptions should not be used for process control, condition control.
  • An exception is caught to handle it, don’t throw it away and do nothing with it. If you don’t want to handle it, throw the exception to its caller. The outermost business consumer must handle the exception and translate it into something the user can understand.
  • When catching, distinguish between stable code and unstable code. Stable code is code that will not fail no matter what. For the catch of unstable code, distinguish the exception type as much as possible, and then do the corresponding exception handling. Do not try-catch large chunks of code
  • .

Then, according to the exception handling characteristics of JavaScript itself, summarize some normative behaviors, such as:

  • Do not throw non-error objects
  • Do not ignore asynchronous exceptions
  • Globally monitor Javascript exceptions
  • .


Resources:

  • Top 10 JavaScript errors from 1000+ projects, and how to avoid them
  • The ‘authoritative’ guide to Javascript exception handling
  • Best practices for handling front-end exceptions


⬆️ Back to top

9.2 log

On the front end, logging is not meaningless (many framework performance optimizations recommend removing console from production). Especially when debugging code on the production site, valuable console logs can help you quickly find clues to exceptions.

You should not put console.log in a React render function, or in a loop. Ddos-like log information doesn’t help you to locate problems, but it can affect performance. Therefore, a specification is needed to constrain log output behavior, such as:

  • Avoid repeatedly printing logs
  • Log carefully and divide log levels. For example, the output of debug logs is disabled in the production environment. Optionally output info logs.
  • Prefixes are used to classify logs, for example:[User] xxxx
  • Record only critical information that will help you diagnose the problem
  • .

Extend resources

  • Debug Applies to The Debug logging tool of Node.js and browsers and supports dynamic log printing
  • VConsole mobile debugger


⬆️ Back to top

9.3 Monitoring Exceptions

Because the application runs in an uncontrolled environment, exception monitoring is very important in the production environment for client applications. It can collect all kinds of unexpected production environment problems and help developers quickly locate exceptions.


Exception monitoring typically collects exception data in three ways:

  1. Global capture. For example, use window.onError, orunhandledrejection
  2. Report it. Active report in the try/catch.
  3. User feedback. Such as pop-ups that let users fill in feedback.

As with logs, not all ‘exceptions’ should be reported to the exception monitoring system, such as expected’ exceptions’ such as user input errors, authentication failures, network errors, and so on. Exception monitoring is used to report unexpected or fatal exceptions.


It’s not easy to do good exception monitoring on the front end, it needs to handle these things:

  • Browser compatibility.
  • Collect the crumbs (breadcrumbs). Collect clues from the ‘disaster’ scene that are important for diagnosing the problem. Such as current user information, version, runtime environment, printed logs, function call stack, and so on
  • Call stack transformation. This call stack is basically unreadable and usually needs to be mapped to the original code via SourceMap. You can use this library: source-map
  • Aggregation of data. The back-end monitoring system needs to analyze and aggregate the information reported by the front-end


Small teams may not be able to develop such a system, so third-party tools are recommended. For example,

  • Sentry 🔥 free is basically enough
  • FunDebug paid enhancement

Extension:

  • Research on front-end exception monitoring solution
  • Build front-end monitoring system


⬆️ Back to top


10 Front – and back-end collaboration specifications

The front end is a niche area of the Web that often cannot exist without the back end. So working with the back end is the longest.

10.1 Collaboration process specification

After long-term cooperation, the front and back end teams can generally conclude a collaboration process that is optimal for the development efficiency of both sides. Put this into practice, and the rest of the team collaborates at this pace.

A typical back-end collaboration process is as follows:

  1. Requirements analysis. Participants typically have front and back ends, tests, and products. Hosted by the product, the requirements are advertised, and feedback from development and testing is received to ensure that everyone has a consistent understanding of the requirements
  2. Front and back development discussions. Discuss the application of some development design, communication technology points, difficulties, and division of labor.
  3. Design the interface document. The front and back ends can be designed together; Or by the backend design, front-end confirm whether meet the requirements
  4. Parallel development. Front and back end parallel development, in this stage, the front end can first achieve static pages; Or Mock the interface against the interface document to emulate the backend interface
  5. Before commissioning, the back-end is required to test the interface
  6. Real environment coordination. The front-end proxy interface requests to the back-end service for real environment debugging.


⬆️ Back to top

10.2 Interface Specification

The first thing that should be finalized is the interface specification. In fact, which interface standard to use is the second, the important thing is to unify, and to meet the development efficiency requirements of the front and back ends.

The author does not recommend that the backend define its own interface standard, but should choose some common, standard defined interface form, such as:

  • RESTful: The most widely used API design specification is based on the mechanism of HTTP itself.

    I personally like the API specification, but I’ve found that many developers don’t really (or have the heart to) understand it and design interfaces that are far from what I’d like. In other words, it’s hard for developers to agree on what RESTful is, and it’s easy for them to disagree.

    Because this is the most widely used form of API, there are many tools available in the community to document, test, and simulate RESTful interfaces.

  • JSONRPC is a very simple and easy to understand interface specification. I recommend this one over RESTful, it’s simple and less divisive, and it’s easy for beginners to accept.

  • GraphQL 🔥 is a more advanced and promising API specification. But it can be difficult to convince the back end to use this standard with you


Points to pay attention to in interface design:

  • Make a clear distinction between normal and exception, strictly following the interface’s exception primitive. All of the above interface forms have explicit exception primitives, such as JSONRPC, that should be returned when an exception occursError objectInstead of returning an error code in the normal body of the response. In addition to normalizing error codes, HTTP response codes are a good learning object
  • Specify data types. Many back-end write interfaces are non-strings and numbers, and if you compromise, the front end needs to do something special for this property, which can be a potential bug
  • Clarify the meaning of null values. For example, if I’m doing an update, does null mean reset or ignore the update?
  • Responses avoid redundant nesting.
  • The interface is versioned to maintain downward compatibility. As we said in the “Semantically versioned specification” above, for the back end, the API is the public interface. Publicly exposed interfaces should have a version number that indicates what changes have been made to the currently described interface and whether it is backward compatible. Now front-end code may be cached on the client side, such as applets. If the back end makes a break change, it will affect this part of the user.


⬆️ Back to top

10.3 Interface Document Specifications

The back-end exposes interface-related information to the front end through interface documents. You usually need to include this information:

  • The version number
  • A document description
  • The entry point of the service, such as the basic path
  • Test server optional
  • Simple Usage Example
  • Security and certification
  • Specific interface definition
    • Method name or URL
    • Methods described
    • Request parameters and their descriptions. Type must be stated (data type, optional, etc.)
    • The response parameters and their descriptions must specify the type (data type, whether optional, etc.)
    • Possible exceptions, error codes, and descriptions
    • Example request, optional

Manual maintenance problems:

As mentioned above in code as documentation, manual maintenance of interface documentation can cause code and documentation to be out of sync.

If you can generate interface documentation from code or from a specification document (such as an API description specification such as OpenAPI), you can resolve implementation and documentation inconsistencies and reduce documentation and maintenance costs.


⬆️ Back to top

10.4 Interface test and Simulation

It is necessary to test and simulate the interface in order to achieve efficient parallel development.

  • The front-end requires that the back-end verify that its interfaces work properly before commissioning. Instead of using the front end as an ‘interface tester’ to block the interface debugging process during the debugging
  • In addition, the front-end needs to write business logic code through interface emulation before the back-end interface is ready.

For interface testing and simulation, there is an ideal model as follows:

Everything starts with a well-defined interface document and generates Mock Servers and Mock Clients. Mock Servers provide Mock data to the front end and Mock Clients assist the back end in testing their interfaces.

Resources:

  • RESTful
    • Swagger This is the solution that comes closest to the ideal model above
    • JSON Server quickly generates JSON mock servers
    • Easy Mock is a visual, online interface to Mock services
  • GraphQl
    • GraphQL Faker
    • graphql-tools
  • Simulation data generation
    • Faker. js 🔥 powerful simulated data generation tool for both Node and browser
    • Mock.js data generation and simulation tool


⬆️ Back to top


Training/knowledge management/technology precipitation

I think the knowledge management of a team is very important. You have to ask a new person what they want when they join a team. A lot of people say ‘learn’ and want to be better at their skills. Money is secondary.

However, the reality is that the current environment in many companies is not like this. Writing business code all day long, working a lot of work, doing the same things every day, working overtime, and not feeling much progress in technology can be very frustrating. This is also true of me.

So to help improve the situation, LET me talk about some of my recent attempts at small teams.

11.1 New personnel training

If your team has a standard training manual for new members, you can save a lot of training time and avoid dictating the same thing every time. The training manual contains the following:

  • Product architecture and organizational structure. Introduce the company background and product. Generally, the organization’s team structure is related to the product structure. Take my company for example, its main product is instant messaging:

  • Product development process: Introduce the processes involved in product development and iteration, and the collaboration between teams, for example:

  • Scope of work: Scope of responsibility for team members

  • Establish resource index: development needs to design resources, such as various document addresses, r & D system entry (such as GitLab, bug tracking system, file sharing, publishing platform, development/test environment, monitoring system), collaboration specifications, etc. Having these resources in place can reduce unnecessary communication costs

  • Specification: The ‘Front-end Collaboration Specification’ is the body of this article. There are norms to follow, can let members with a faster speed to start development, but also reduce training costs.

The training manual will organize the contents that can be documented into documents. Just like the Code Review mentioned above, some things cannot be explained by documents, so we usually have a ‘training tutor’, and during the trial period, one-to-one tutoring.


⬆️ Back to top

11.2 Create technical atmosphere

  • Encourage members to write a tech blog or create their own team column. It is not easy to write a good article

  • Encourage participation in open source projects

  • Establish interview question bank to solve some interview questions or algorithm questions together, deepen the understanding of knowledge points

  • Regular topic sharing. Encourage team members to regularly study and research on special topics, write technical blogs, and share the results of learning with other members. It’s a group learning style designed to help team members learn and grow together.

    For example, experienced developers can share their experience and research deeper technologies. Novices can explore development techniques and new technologies such as CSS Grid, SVG animation, and so on. Recommend that team members have a specific area of study so they can learn more by working together.

    How does the topic come?

    • Project request: You can ask other members to complete the project, such as deep knowledge, you can ask the team to have more experience to learn and share
    • Study summary.
    • Project review
    • To overcome difficulties
    • The project specification
    • Tool use
  • Implement and improve development standards. The specification itself is a direct output of the team’s knowledge sediment

  • Book sharing. Compared to discrete articles or tutorials, books are more systematic in their knowledge, and many classic books are meant to be quietly enjoyed.

  • Encourage refactoring and continuous optimization of your code

  • Abstract a set of basic library or framework, reduce duplication of work, improve work efficiency. Not working overtime starts with improving work efficiency


⬆️ Back to top


12 feedback

If you have anything to add or comment, you can comment below to improve this article, thank you!