This is the 126th original article without water, if you want to get more original good articles, please search the public account to follow us. This article was first published in the front blog of the Political Research Cloud: how to write the front-end technical solution document in the political research cloud

preface

Baidu Encyclopedia defines computer Software as: “Computer Software (also known as Software) refers to the program and its documents in the computer system. The program is the description of the processing object and processing rules of the computing task. Documentation is the illustrative information needed to understand the program. Programs have to be loaded into the machine to work, and documents are generally for people to see, not necessarily loaded into the machine.

The concept of “documentation” means that writing documentation is an essential part of the software development process. If the documentation is not well written, the software is not good.

But for the average software developer, writing code is much easier than writing words. A lot of times we see the same thing, the project is done, the design document is not there; When others asked why a certain function was designed so, temporarily speechless; There is no comment in the project code, for a long time, I have forgotten why the code was written so; When working on someone else’s project, you can only read line by line of code to troubleshoot a problem, and the only documentation is the readme.md automatically generated with the scaffolding. All of these are problems we may encounter in normal development. Why? In fact, because there is no habit of writing documents at ordinary times, the text has not been retained, only by memory, a long time really can not remember.

The following would like to discuss with you why the front end to write technical solutions, how to write the front end technical solutions.

Write the purpose of the technical proposal

Before I tell you why I wrote a front-end solution document, LET me tell you a story about my good friend Xiao Ming.

Ming is also a front-end. When he receives a requirement, he looks at the requirements document and sees nothing wrong with it. Then he looks at the interactive and visual pages and starts writing code.

Create a new file, write a template, write a style, write interaction logic, all in one go. The need for new modules is Xiao Ming’s favorite, because there is no need to understand the logic of other functions, but it is necessary to maintain the historical code in the work. Xiao Ming is very smart, he found that a function with a parameter to pass to make a logical judgment can be achieved, so he did so.

After the development, Xiao Ming felt very satisfied, because soon realized the requirements, the code in the brain logic is relatively clear, there may be some places to write inappropriate, but it doesn’t matter. It’s not globally optimal, but it’s locally optimal.

After the release, QA started to bug Mindy for various border issues and extreme scenarios. For example, the input box submitted interface error after entering emoji, the button clicked continuously triggered multiple requests, the page display of buyer role is normal but the display of supplier role is wrong…

In the process of changing the bug, Xiao Ming gradually took the mask of pain, the code logic was changed to fragmentation, had to make all kinds of patches for the code, method parameters added one after another, the condition judgment in the logic added again. By this point Ming’s development motivation had worn off and he began to question the bugs raised by QA, avoiding code changes by saying things like “that’s how it was designed” and “this problem is not part of the requirements this time”.

Some time later, Xiao Ming received a demand to add some functions to the module developed last time. When he opened the code, Xiao Ming fell apart. The logic of the previous code has long forgotten, in the face of their own have not understand the code, began to torture their soul “what is the use of this method? Why does this method have so many arguments? Why is the logic so complicated?” “, “What is the logic of code jumping from page to page and almost identical code?” “, “Why are there so many identifiers, so many magic numbers, what are they?” . Comments don’t exist, and even if they do, they don’t understand what they’re talking about.

When he first took over the project, Xiao Ming kept teasing the previous developers for not writing documents and notes. Before long, Xiao Ming also became the “him” in other people’s eyes.

The above story is based on true events.

I think writing technical solution documents can solve part of Xiao Ming’s problems. “Think before you act, think before you act” is all about this truth. Of course, documentation isn’t everything. If you look at the back end, they do the schematic design before they write the code, as if there’s a lot of development time on the back end or the technical solutions on the front end aren’t worth mentioning? Definitely not. Scheme design is a best practice in software engineering. Usually, the overall architecture of the software will be reflected in the process of making a technical scheme. When the core process is sorted out, it can be basically implemented in the code. That is to say, a good technical solution can reflect the logic of the final code, and you can know how to write the code by looking at the solution. This prevents the messy structure of the code that you end up making changes as you go along.

How to write the technical proposal

If we follow the back-end methodology and template to do front-end solution design and find that nothing can be written, then we need to re-examine the formula of solution design to find the differences between the front and back ends.

The business model may be consistent on both the front and back ends, since we are all solving the same business problem. There is a slight difference, however, in that some of the data on the front end doesn’t come from the back end, or doesn’t have to come from the back end, which we need to take into account when designing. For example, the same H5 page needs to display different theme colors in the wechat public number and the nail nail.

For the back end, the core process is the generation, circulation and consumption of data. However, when it comes to the process, in the front end, it is more about page circulation, component interaction and user operation. The same thing is completely two things on the front and back end, such as saving a piece of data. The back end may be concerned with how to verify, store, index, and associate the same thing. However, the front end should pay attention to the input and output parameters of the verification interface, how to display the verification results, whether to jump, overwrite or popup, and how to adapt to different screens and devices.

The back end focuses more on logical architecture and deployment diagrams because it needs to be servified and the boundaries between services need to be clearly and concretely defined. Front end with the corresponding service, should be components, component coverage range is too wide, however, from a button to a page can call components, even more hot now micro front-end application of a child can also become a component, so the front-end components need to be divided into pages, module, control units with different levels of packaging, etc. In the process of this partition, the logical architecture naturally emerges. At the same time, the front end solves different problems, resulting in different concerns. The front end needs to pay attention to the restoration of the page, such as how to abstract the elements of the page, how to reuse the style, which is not considered by the back end.

Interfaces can be more than JUST HTTP requests; any logic that interacts with other modules should specify its input and output parameters. The back end needs to pay attention to the exposed Dubbo or HTTP interface because it represents the logic of the interaction between the systems. For the front end, the interaction logic between individual modules or pages should also be defined, so these “interfaces” need to be defined.

In terms of implementation, the concerns of the front and back end are also slightly different, with the back end more concerned with integration between systems and compatibility of old data. What the front end should care about is the difference between desktop devices and mobile devices, or the integration of different channels such as wechat and Alipay.

After the comparison, the context of the front-end technical scheme is gradually clear. Combined with the above methodology, the following on the actual case.

Cases of technical solutions

In the R&D process of the production and research team of the Zhengzhoucloud, the front-end scheme design is the intermediate node between the requirement stage and development stage after the requirement and interaction review and before the test review and formal development. At this point, the functions and user interaction scenarios of the requirements have been basically determined, and the feasibility, overall architecture and specific implementation of the requirements are clearly described between the front-end and back-end technical schemes. It also helps QA comb through test highlights and use case scenarios prior to test analysis.

** Chapter 1, Overview. ** generally briefly describes the background and value of the project. The meaning or motivation of doing something is very important, which can be summarized in the requirements document. Then explain some proper nouns that will be used in the rest of the document. It is important to reach a consensus on some nouns.

** Chapter 2, related documents. ** Collect documentation related to version development, so that all documents can be found through this one front-end technical solution document during development, sometimes I also organize these pages into a browser bookmark folder.

** Chapter 3, Task Disassembly. ** Mainly describes the development task attribution, estimated working hours, and milestones.

Estimation is based on the page dimension, split the main functions of the page, time estimation, time estimation according to static demo and JS interaction to evaluate separately will be more accurate. Then multiply the time by a factor of 1.3 (because there are different meetings and communication takes up time each week).

When evaluating time, take some time to list it locally as shown below – the advantage is that it is easy to count and compare it to see if there are any omissions; Second, if we give the assessed time to the business side and PM, we will be recognized professionally — we will think that such granularity and time of assessment are accurate and you are reliable. In addition, the fine-grained dimension is also convenient for the business side to find the longest path of requirements, and it is also convenient to make judgments based on requirements or iterations.

** Chapter four, overall design. ** Lists the development specifications, as well as the logical architecture. A picture is worth a thousand words, and the logic of timing strongly recommends diagrams instead. Flow charts, sequence diagrams, and status diagrams make your technical solution document clear and clear.

The following figure is the page hopping logic diagram. If there is any missing interaction, the front-end technical solution can fill in the bits

** Chapter 5, Detailed design. ** This chapter is the focus of the whole technical solution, including function description, process description, module detailed design, external dependence and other four sections.

The perfect state, as shown in the picture below, is when this section is finished and the code is on the page.

You can also paste some code appropriately, which is good for explaining changes during technical analysis

The following figure shows the timing sequence diagram of card coupon selection in the ordering process. The complexity of timing logic is beyond words, and timing diagrams make interaction clearer

The figure below is a case of front-end component input design, open source component library is good, you can refer to it directly.

The last three chapters may include a Checklist of technical analysis, test data and remaining problems

Finally, attached is the front end technical solution template of the front end team of zhengzhengyun, stamp here. Of course, you can also add and delete content according to their own situation.

Finally, two useful drawing tools are recommended:

  • Plantuml: Draw UML diagrams using simple text descriptions
  • Drawio: Online icon drawing site

Both of the above tools have corresponding vscode extensions. (Processon is also useful, but the free version can only store 9 charts.)

conclusion

Let’s start with the fact that writing a document can be as laborious as writing, and it can take a long time to draw a flow chart or weigh a word. Secondly, the document needs to be updated continuously. Instead of sealing the version after the technical review, visual review, test analysis review and subsequent iterations may affect the technical solution, which requires real-time follow-up. If we can integrate the technical solution documents of each version of the product, we can even get the whole picture of the technical solution of the whole product.

Haste makes waste. Many people think that the technical solution is to extend the development cycle. In fact, in the landing process of the political cloud, it is found that the more detailed the technical solution design, the quality improvement, and the maintenance cost reduction effect is obvious, open a long cycle, is to accelerate the iteration cycle

In the preface of Top of the Wave, Kaifu Lee said, “I know a lot of top engineers, but I know very few excellent engineers with strong narrative ability.” Presentation is one of the most important soft skills of software development engineers. As a best practice of software engineering, solution design is still very necessary in the front-end development process. So why has the front-end field paid little attention to this for a long time?

  • Solution design depends on technical capabilities, and the front-end technology stack changes so fast that today’s design routine may be ineffective tomorrow;
  • The front-end business changes so fast that after half a year of iteration, the first version of the solution may not reflect any code logic;
  • The front-end business process and interactive process are too complex than the back-end, and have poor reusability. They need a lot of time to think and sort out, and have high requirements on abstraction ability.
  • Front-end development is efficient, with no historical baggage, and sometimes a direct rewrite is more efficient;
  • Back end on the language andIDERefactoring support is much better than the front end;
  • The back-end is more mature, like the usualmvcLayering is almost a convention, whether the front end wants it or notmodelLayer, yes or noserviceLayers are all up for discussion, whether or notredux.reduxSave what data, everyone’s understanding is not the same;
  • The abstract thinking and engineering ability of front-end personnel are generally weaker than that of back-end;

However, these reasons are not the reason why we do not do scheme design. Scheme design is a process of structured thinking, which can not only make the project better executed, but also improve the architectural ability and macro awareness of developers. We need to show what we’re doing, not only to our peers, but maybe to other people in other positions, and even to users. If all we can do is write programs and not properly and elegantly describe our ideas in a document, then we are truly code-farmers.

Therefore, the students in the peacetime development of the time to think about how to do design.

Subsequent forecast

Part of the technical solution is implemented with the backend. Is the back-end technical solution developed by each person reasonable or inconsistent? Is there a better best practice? After long-term practice and summary, Zhengcaiyun has developed the front and back end technical scheme agreement, the example is as follows, please look forward to it.

Recommended reading

  • Sketch Plug-in Development Guide
  • Why is index not recommended as key in Vue
  • Brief analysis of Web screen recording technology scheme and implementation

Open source works

  • Political cloud front-end tabloid

Open source address www.zoo.team/openweekly/ (wechat communication group on the official website of tabloid)

  • Item selection SKU plug-in

Open source addressGithub.com/zcy-inc/sku…

, recruiting

ZooTeam, a young passionate and creative front-end team, belongs to the PRODUCT R&D department of ZooTeam, based in picturesque Hangzhou. The team now has more than 60 front-end partners, with an average age of 27, and nearly 40% of them are full-stack engineers, no problem in the youth storm group. The members consist of “old” soldiers from Alibaba and netease, as well as fresh graduates from Zhejiang University, University of Science and Technology of China, Hangzhou Electric And other universities. In addition to daily business docking, the team also carried out technical exploration and practice in material system, engineering platform, building platform, performance experience, cloud application, data analysis and visualization, promoted and implemented a series of internal technical products, and continued to explore the new boundary of front-end technology system.

If you want to change what’s been bothering you, you want to start bothering you. If you want to change, you’ve been told you need more ideas, but you don’t have a solution. If you want change, you have the power to make it happen, but you don’t need it. If you want to change what you want to accomplish, you need a team to support you, but you don’t have the position to lead people. If you want to change the pace, it will be “5 years and 3 years of experience”; If you want to change the original savvy is good, but there is always a layer of fuzzy window… If you believe in the power of believing, believing that ordinary people can achieve extraordinary things, believing that you can meet a better version of yourself. If you want to be a part of the process of growing a front end team with deep business understanding, sound technology systems, technology value creation, and impact spillover as your business takes off, I think we should talk. Any time, waiting for you to write something and send it to [email protected]