The front end early chat conference, and nuggets jointly held. Add Codingdreamer into the conference technology group, win at the new starting line.


30th | front end interface before and after the special BFF – play, live all day 7 to 17, 9 lecturer, registration on the live 👉) :

All the previous period has the full recording, the beginning of the annual ticket to unlock all at one time


The text is as follows

This article is the 21st – front-end early chat set up special, but also early chat 148, from the man – Kun Ming share.

preface

Hello everyone, MY name is Wang Kunming. I am currently working in the front end team of Manbon Group, mainly responsible for the two departments of infrastructure and marketing team. Today I mainly share, how to design and implement H5 marketing page building system of high expansion ability, mainly around the code is how to achieve to introduce.

directory

Through the following aspects to make an introduction:

  • The first piece is code. What is code? This piece I will pass some diagrams or demonstrations, let you intuitively understand the code is what kind of thing.
  • In the second block, I will briefly introduce the core components of the code, including the technology stack and core functions.
  • In the third part, I will talk about how the operation personnel and research and development personnel on the code platform cooperate, how to improve the efficiency, and what the whole working process is.
  • The fourth part will talk about how we design high scalability to meet the workflow, and then make a brief summary.

What is code good

First of all, what is code good?

Code good is a high expansion of the web building platform, it is for operation, but also for research and development. Code can be done on the mobile end of the page, but also to do PC large screen pages, the whole code platform through the basic components, scripts, animation, template these modules, to the whole functional area to do some perfect, to facilitate the support of some of the above things. Code platform is an open source project, all its functions are external open source, can be convenient for everyone to build and learn. The bottom right corner of the image is the official website, which you can visit at your leisure.

You can have a simple and intuitive look at the situation of the whole platform, this is the operation staff in the code platform to see the interface. On the far left it has a base component library and some pages for base components, and then in the middle is the Build area, which you can drag and drop, and on the far right is some properties Settings, which is a pretty basic build platform feature.

Then for senior operators or developers, we offer a different view. For example, there will be a finer level of control for some components, and there will be a finer level of animation control panel that can control all the animations on your page by frame. You can also add scripts to a component and use the scripts to extend the component to achieve more functionality.

This is a developer view in the code platform, we first intuitively understand, will be introduced in detail.

Take a look at this component first. We can add multiple scripts to a component. Each script is actually a JS object. This object can expose some methods to the component in the editor, making it easier for operations to fill in, as described in more detail later.

Another is the code platform, it can also do PC big screen things.

The whole platform has a view switch, we can provide different views for operation, design and development, so that everyone in the whole platform will have a more friendly operation experience. Then the code platform can support PC, which can switch the canvas resolution, you can do data large screen.

We also officially have a widget store for the entire platform, which will have a lot of commonly used components, including buttons, charts, shares and so on. Mall inside each component of the code is open, you can go to learn or directly use it. Of course, we also hope that other people can work together to build the ecology.

Good code

The whole system of code is composed of three parts, and then these three pieces we have done open source.

  • The first part is a server, written mainly in Node.
  • The second module is the management background, mainly to manage the code platform inside all the pages, including some data analysis;
  • The core is the core editor and renderer built.

These three pieces can go to the corresponding Github to see the corresponding source code.

We also provide basic source code deployment, which is convenient for those who need to build and iterate their own internal projects to use, or Docker deployment. You can quickly build and then experience the core functions of the code. Overall, it is more convenient to learn and use.

The core target

What is the core goal of the platform? Internally, we hope that the code can be good for our full bang group of marketing scenarios to do. In internal use, in fact, we precipitated a lot of components, scripts and templates, will be introduced later, and so far has invested more than 6000 pages, the whole code platform for our marketing scene is very obvious, the r & D involvement rate is almost only about 10%, saving a lot of R & D resources. For the outside world, we hope that the code project can make some open source contributions, and we also hope that people can submit their own components in the component store.

The core of

Next, introduce the core composition of code.

A simple building system, in fact, can not escape these blocks. The first is basic services. Basic services we use node.js Egg framework, do the most basic underlying data storage and reading support. There will be a management background, the core is to manage all the pages and resources, derived around the page management module, such as page group management, we have a project dimension to manage, and then the project dimension group, we have team management and a corresponding authority management. Then the page derived, including some data analysis of the page, some historical records and basic information of the page will have, will be in the management platform.

For resources, all the building systems can not escape, such as the most basic components, design resources, audio, video, and pictures, and a series of resources will be in the management background.

The core is the editor, and the editor, as you saw earlier, can also switch between different views, such as the design view, the operation view. Everyone sees different modules under each view, and all of these modules are actually here. We’ve made some abstractions, including components, composite components, script editing, template pages, which we’ll focus on later.

In addition to the editor, the most important part is the renderer, which we will parse the edited things in the editor, and finally carry out the output of the page. In the renderer, we also made some micro front-end acceleration and simple adaptation of multiple ends. On top of this basic management and editing display, we scaffolding components to create and publish components, all of which are published to the CDN. So the overall functional module and structure looks something like this.

The working process

What is the workflow inside the code platform? Let me just share a little bit.

In all the research and development, he will develop many components, including images, text forms, such as the most basic components, any building system can not escape these things, this is the most basic components. Here we add that the reason why maliang platform has high scalability cannot escape this part of the script, which will be introduced later.

That is, the R&D side will develop components, develop scripts, and then do some integration between components and scripts, and you can quickly produce composite components. For example, by adding a buried script to a text component, it can quickly produce a buried text component. So you can make a lot of composite components by combining components and scripts in pairs, and then developers can quickly turn those composite components into a page template. Multiple components can also be combined to precipitate the page template.

Because there are more and richer page templates, the operation can choose the existing template, quickly published online. This is r & D in the code platform to do, develop components, develop scripts and then combine components, and finally do template pages, put into the market for easy operation and use. Operating in this platform, if it is a simple page, he can use components or use composite components to quickly build the page, or after building the page to generate templates for next use. Finally, select and publish the page.

As you can see in the whole process, for developers, it requires the ability to customize and expand the system, which we will achieve through components and scripts. For operators, they need a rich template library that can be easily modified and quickly published. So the operation personnel can quickly use the combination of components in the code platform, or use templates, pages, to quickly build online. The entire code platform creates a bridge for operations to quickly publish an active page without code development, while allowing developers to compose, develop, and provide a rich library of components in a low-code form.

This is the entire workflow of a coding platform, and the iterative cycle results in a large number of scripts, composite components, and template pages that improve operations.

Core competency Design

How do we design components, scripts, and composite components to allow operations and r&d to work together in this way? Here I introduce the core capability design of the whole code platform.

Data structure design

The first piece is the data structure aspect, as you can see this is a page built by the code platform. If we abstract the page, we can see that the page is actually made up of a series of components, such as images, step bars, lists, and buttons, which may have some buried points or jump scripts, we can abstract its data.

As you can see, this data is actually a JSON object, and each node is actually a component, and each node contains some key information, including the type and so on. Different components can have different types, as well as the style information of the location of the component, and some parameters passed in by the component. These parameters are transmitted to the inside after the operation is set in the link panel, which is convenient for the component to parse.

The other is its child element, where components can be nested. So a page as a whole is a nested JSON. In addition to these basic data, we also have some other data, this piece is a relatively complete description of a component information.

In addition to the most basic types we started with, there are other attributes, such as the Id attribute, whose value is a unique component number, which allows you to retrieve tags in your code or dynamically render them. Another attribute is Animate. You can see that our web platform has an editable animation panel, and its information is stored here. In addition to these, there is an important extension Script, described in more detail later. The extension information for each component is in here.

A brief summary of the description of the whole page: the page is composed of countless nested components, each component is actually described by a JSON, and then the whole code good building system around how to edit JSON, how to render JSON, to do a whole system design. In addition to the overall data, how do we design each component?

Component design

Here’s a look at the process from build to load, and then to render.

First we will talk about component creation, in the code platform, all components are created by scaffolding. The scaffold provides the corresponding command to quickly create a project, this is to create a good project, create good after the project, can undertake the development of the components of the project, you can also in the process of development of component development an attribute editor panel, develop good after packaging, and then released into the CDN, All of our component libraries and corresponding editors are also in the CDN, there is a detailed help document in the lower right corner, you can have a look.

A simple demonstration of the creation process. There will be a command line here to quickly create a component, and then the creation of the corresponding information will appear some selection type and a classification, it will prompt you to create the corresponding property editor, after the creation of a project. He actually divided the project into three parts, with preview, component code and editor.

You can take a look at the project you’ve created. First, it has a preview, which when it runs is actually a container for displaying components and editing panels, providing a context for it.

In addition there is a core component of the project editor code, this block is responsible for the components of the display, also has an attribute editor, its corresponding attribute editor code inside the editor, and then we carried out on the component package after a series of development, after the packed, it will generate the corresponding component code to index. The js, The editor code will then be generated in editor.js, and we will publish the packaged code to the CDN through the code scaffolding.

In this case, there are corresponding component codes in the CDN, such as Echart. After Posting to the CDN, we will provide a default access link, which can read js. For example, 2761 is the group ID of each component, echart is the name of the component, followed by the version of the component. There are also index and Editor files.

Then we can take a look at the main contents of the packaged JS. You can see that this is a UMD module, and we’re basically exposing a global object on the window object by naming it so that we can get the component’s code and edit the component’s corresponding editor code,

Once the logic of a component is developed and published to the CDN, how do we load it? In fact, the logic is very simple, we dynamically create a script, and then load in the script, after the window object through the standard naming rules to get the component object, this is complete load action, after the load will do the entire page rendering.

When rendering a page, you recurse to each node, then load the corresponding JS logic through the configuration information of the node, and create the object. When an object is created, it is rendered to the page by the dynamic component feature. Everyone see, the below is a recursive structure of the core, we can see each component it is be a div wrapped, when we are recursively to the current node, we will set the style of the current node information to package container, so the location of the package container determines the current component size and other information.

Internally, we will render dynamically through a dynamic component with the component ID as key, bind the parameters of the component during rendering, and finally recursively traverse its child elements to render recursively. This is the core logic for recursing all of the JSON across the page, one by one, and then rendering it.

What about the registration and rendering process for each component?

First, when the traverse all the nodes to which one, need to create a node object, first of all, you need to get object logic code, through the load corresponding to the component of js mentioned above, then can get the corresponding objects on the global window object, take after the specified object, traverses object configuration script information above, This script information is then combined to create a combined Vue object, which is rendered to nodes by dynamic components. The core logic of this piece can be seen in the code on the right of the image above.

In this case, the extension script is added to the basic component object by iterating through Vue extend. Therefore, the script can integrate with the most basic component code, and then put the integrated object, with the component ID as the key, and the integrated component as the value on the global object Window, and then render the component of the page through the dynamic component setting as the ID. After rendering, the style will be bound, and then bind the event. After binding things to the animation, the whole process is done by rendering the component.

To summarize, a component is actually a Vue object. The component is packaged and published to the CDN, and then it is pulled down by dynamically creating scripts, mounted to the Window object, and then rendered logic is recursed to a node. Component rendering is actually inserted into the page via Vue’s dynamic component feature. The overall component design is actually dependent on the entire flow of Vue.

Component property editing design

In addition to component design standards, a very important part of components is the design of component property editors. Because the component property editor provides an opening for operators to manage components more easily. So the component property editor is also important.

Then talk about the design of the code side. The design idea of the code platform is divided into two parts, one is the basic attribute editor, the other is the advanced attribute editor. How do you understand that? First, the base properties editor is just some fixed text with no logic, such as some single line of input fields, image selection, audio, video, etc., it has no logic, only fixed values, we call it the base properties.

The other is the advanced property editor, whose property values are not fixed. For example, it requires an interface request to obtain data. The other is that the interaction between these properties of the component is very complex, and both of these are what we call advanced property editors. So let me talk a little bit about the last two.

First take a look at what a basic property editor is. For example, a component consists of basic text, image and date selection. Based on these properties, we provide different controls for operations in the property panel, which is the property editor. The current ones are relatively basic.

You can take a look at the script here. If you are familiar with Vue, you should be familiar with it. In fact, it is an incoming parameter of Vue object. Inside each parameter, we extend an Editer property to it, and then we can parse through the editer configuration to provide different property editing panels for the component.

For example, the first editer property value is an image, so we provide an image control panel for operation, and then the following date, enumeration type, can be defined directly on the component parameters, such attributes we collectively called simple properties.

What are the total properties of Editer that can be configured? Here’s a quick explanation. On the right is a full configuration. We can first look at the label. The name of the label is easy to display in the editor. For example, if the value of the label is too long, it can also be moved up to make a dynamic reminder, so there is a description information here.

The other most important is the type type. We prefabricated many types, and the ones listed here are the ones we prefabricated. Including basic input box, color selection, image, video, audio, rich text, enumeration, time selection, radio, etc., these business types can be directly configured by a component type, the corresponding component of the property editor has the corresponding function. There is also a property that needs to be introduced, such as work, which can write some simple logic to make properties mutually exclusive, for example, if a component selects condition one in the drop-down box, then the checkbox in the component is not displayed.

And then let’s see how it works. We can get props information on all Vue objects via $option. After we get this, we will iterate through all the parameters and render different edit panels according to the different types of parameters. You can see here that we’re enumerating a lot of types, like input for string, number for number. And then things like date selection, enumeration, basically parsing the type of the parameter, and then rendering the different controls as needed for the operation to use.

This most basic property, it has some advantages. For example, it is easy to use, it just needs you to define the component, add an extra editer configuration to the component properties, then the code platform can parse the component to know what to provide for the properties of the edit panel, and it is more powerful when used with scripts. But it also has a number of disadvantages, the first is that it can only configure fixed data, as seen earlier it can only provide options such as single text or color without any logic, there is no way to write logic in the parameters, and then to dynamically obtain the data.

For example, there is a very simple scenario where the three options of a drop-down box are retrieved through an interface, which you can’t do with the underlying properties. Second, there is no way to provide strong relationships between attributes. For example, some properties select a value, and another property does not exist or displays something else. These complex logical operations cannot be satisfied by the basic properties. Finally, for example, some of the component properties panels are extremely complex, such as some of the common nine squares, turntable lottery, etc., require a complex property configuration panel to support.

Based on these shortcomings, we provided the idea of an advanced property editor where you can develop a property editor panel for a component at the same time you are developing that component.

Once you’ve developed it and published it, it will be matched in a good editor. For example, if you select the component on the left, it will load the property edit panel for the component, so you can develop the property edit panel for the component according to your own rules.

And then a brief introduction to the principle, as we saw earlier when we create a component, there are actually three parts, one is the editor, another is the preview module, and another is the core module of the component. In the overall structure of the component, we can see that all the components are parsing and displaying the incoming parameter information. The core logic of the editor is developed around how to edit this attribute, and their association is developed around the incoming parameter.

The logic of the component is that the component and the editor pass in the same parameter information, i.e. the props information of the component. The editor then edits these properties, and the rendered component module displays different information according to the different states of the data. That’s the general idea.

In the editor section, you can see that a component’s edit panel is divided into two parts, one is the advanced properties editor, where you can do complex logic development based on your own functionality or layout. The other is the basic properties panel, which displays, for example, extended script data, or some properties of advanced modules that need to be passed through to the basic properties for simple display and configuration.

In the implementation code, the overall process is: when you select a component, the component’s corresponding editor JS will be loaded locally by the way of dynamic load script. After loading, the same will be inserted here in the form of special key through the way of dynamic rendering component. This is the flow of the advanced properties panel.

Here’s the basic properties panel, which looks like this: When the property editor is created, the component’s incoming parameters are passed to it, so that the editor panel edits the corresponding property values, and the component displays different information based on the value of the component data.

In summary, the core purpose of a property editor is to provide friendly interactions for business use. So we have the ability to extend and build development zone extensions with the base property editor, and then we have the ability to provide advanced property editors to meet the specialized needs of operations.

Script design

The component and its corresponding property editor function, here must mention the script part, what is script? A script is like a wing attached to a component, and let’s talk briefly about what a script is.

A typical script inside a code platform looks like the one on the left. You can see, this is actually a Vue related features of an object, and then it can be introduced to some of the parameters, methods, and then we extend the a method of editor exposed a configuration information, when we added after the script of a component, then the component on the edit panel can more quickly come out such a methods and properties, Let the operation can fill it out, and we can deal with it in logic after filling it out.

For example, the method of the image button in yellow above can fill in some parameter information, which can be added through the configuration of the script, which is the script. In short, scripts can enhance some of the functionality of components and work well with the property editor panel.

Scripts can do more than expose this basic stuff. For example, you can make some data requests in the script and initialize the current component with the requested data. You can also get other components in the script by way of ID, and then modify and call the methods or properties of the obtained component. To summarize: A script is essentially a standard VUE object, with all the lifecycle of a VUE and the ability to customize methods.

Another feature of scripts is that they can be composed. For example, if we have a script for sharing, and then a script for saving images, and then a script for requesting data, we can combine these little functions into a button component, and the button component will have these functions, and it will make a more powerful button component. The core logic has been mentioned above, and this is what scripts do, is they quickly extend the capabilities of the current base component.

Let’s take a look at how scripts are used in the code platform. First of all, we can make a component to select more than one script, and then chose two scripts here, choose the right after the script, it will come out in the edit panel inside the corresponding attributes and methods, the properties and methods can be through script to add, and exposed the parameters and methods, parameters and methods can be through script to extend the property editor panel. Once the method is exposed, you can fill in some code as needed. This is how scripts are used. You can quickly add scripts to a component, and with some simple logical extensions, make the component look better in the editor.

How are scripts used in this process? Point 1: we can do some simple function coverage, for example, above the left side is a function of the component itself, and then submit the data needs to be some logic to handle, but we can go through a script to overwrite existing submission methods, and then to do some other logic processing, can also function of component replacement and enhanced.

Second point: scripts can be easily combined, such as text components, which have burying functions, jumping functions, sharing functions, and can be gradually iterated into a complex text component. The button component and image component are similar.

But if we use a script, we can take it apart. By composing, the logic of the original components does not change, but we can compose more and more powerful components, which is the benefit of the script.

But script design also brings other problems, such as complexity, scripts are difficult for operators, and operations do not write them. The other is too flexible, because the script design mechanism determines that the script can override the function of the component, so it is too flexible to control. So the script is only suitable for open development use.

Encapsulating components versus composing components

For development, we provide another way for operations to use it better. So that’s encapsulated and composed components. Let’s take a quick look at what encapsulated and composed components are.

First of all, we can see above the lower left corner is a commonly used component, then we can give it a wrapper, packaging after ok, you can see it will put the child inside a whole element synthesis, synthesis of a whole, it can reduce complexity, and then give the parcel in the unnecessary complexity, this is the packaging components.

So what are composite components? Composite component is that we save a component as, after saving as, we can first save, after saving, we can quickly find the component saved in the composite component, and then we can directly pull over to use, this is a composite component. The function of composite components is to save some of the functions we have edited into blocks as components, and then facilitate our r & D and operations to use quickly.

Then summarize the encapsulation component, we by encapsulating component encapsulation of complex logic operations, invisible, we can also cooperate with the script and the data bus, put some unnecessary things to hide it, and then expose some necessary things to the outermost layer, to fill in the operations, in order to reduce operational barriers.

The other is the composite component, which provides a platform for r & D to develop components. It can develop components and scripts you commonly use according to certain functions, and export a composite component quickly after development, which is convenient for operation and use, and also convenient for R & D to use next time.

Encapsulating component implementations is actually quite simple. Encapsulation of components is mainly achieved through some parameter markers, component states. Place some operational or display restrictions on the editor based on the state of the component. Can you expand it, can you drag it whole, can you click on the next child element? The implementation is not complicated.

The composition component implementation is easier to understand, because the entire page is a JSON, and then this part is saved and reused for the next time.

The template

With composite components, it solves most of the problems, but for operations, which need to create pages quickly, it needs to have rich templates.

Templates are probably easier for you to understand. In fact, templates are some pages that have been built by R&D and operation. If the operation thinks these pages are highly reusable, they can be saved as templates for quick use next time. The management of a template is simply a JSON file that manages the entire page, similar to composition components.

conclusion

Do a simple conclusion: using the component, script code is a good platform, combination components and template of this a few pieces of content, provided us with an operation without code oriented way, and for research and development of low code way to build a platform of high extension of the page, convenient people build and use, the overall code complexity is not high also, also convenient for people to learn.

Push the book

After our previous sharing, I would like to share with you a book called “Understanding JavaScript”, which is a JS related book I read when I first started my career. Although this book does not have a great influence on me, I find it very funny, so I recommend it to everyone. Reading this book kind of makes me read novels to learn JS feeling. So if it is the first to learn JS, I still recommend you can see.

recruitment

Another is that the front end team of Manbang Group is currently recruiting, and we hope you can join us. There will be corresponding positions in Shanghai and Nanjing. Finally, I would like to thank you for your time and share with you. I hope you can pay attention to our project. Thank you. That’s all for today.

Q&A

Q: Excuse me, Mr. Kun Ming, are all components deployed to THE CDN independently? If there is a component that needs to be updated, how can it be updated as a single component?

A: All right. All components are deployed individually to the CDN. As you can see, when the component is released, there is a component name and the corresponding version number in its naming rules, and the corresponding version number of each component in the CDN is a unique JS code.

Another is how to update the problem. In the code platform, when you use a component, the code platform will check if there is a new version of the component, and if there is a new version, it will tell you in the properties panel if there is a new component, if you need to click update, and then you can click update.

Q: Excuse me, Mr. Kun Ming, what is the packaging method of components? What about the size? How to reduce the size of components if most of them depend on the same dependency.

A: First of all, the size of A component depends on the complexity of its functionality. Sometimes you may rely on a lot of third-party libraries, but you’ll need to weigh that up yourself.

In theory, the size of a component package may not have much to do with the size of a third-party dependency package. Because the component’s project, the base tripartite packages that it depends on, such as Vue or some third party base framework layer, are already introduced in the renderer layer, your component’s code will in theory only package things that are relevant to your component’s logic. If the component relies on some chart library, you can also load the corresponding third party library by creating a script on the fly. It is not recommended to package it into the component code.

Another is the size of the component code, which I think depends on the situation. If you think the component is too big, there are many ways to optimize it, including some caching behavior.


😍 and don’t forget to give it a thumbs up below 😍