Skip to content

File structure

Zova provides a flexible file structure that can be gradually adjusted according to the complexity of the business, always maintaining the simplicity and elegance of the code, which is more conducive to continuous iteration and maintenance of the code

Three-level iteration

The file structure of a component can refer to the following three iterations:

NameDescription
Single-FileController(1)
Three-FileController(1) + Render(1) + Style(1)
More-FileController(1) + Render(n) + Style(n) + Service(n)

Single-File

In the initial stage of business development, there is relatively little code, and a single file can be used

typescript
class ControllerCard {
  protected render() {
    return null;
  }
}

Three-File

When the code starts to grow, you can separate the Render and Style

Create first Render Bean

First, separate out the Render

1. CLI command

bash
$ zova :refactor:firstRender component/card --module=demo-student

2. Menu command

TIP

Context Menu - [Module Path/src/component/componentName]: Zova Refactor/Create First Render Bean

Create first Style Bean

Then separate out the Style

1. CLI command

bash
$ zova :refactor:firstStyle component/card --module=demo-student

2. Menu command

TIP

Context Menu - [Module Path/src/component/componentName]: Zova Refactor/Create First Style Bean

More-File

As the code continues to grow, you can continue to adjust the file structure, create more Render files and Style files, and also create multiple Service files to separate state management

Create Another Render Bean

1. CLI command

bash
$ zova :refactor:anotherRender component/card another --module=demo-student

2. Menu command

TIP

Context Menu - [Module Path/src/component/componentName]: Zova Refactor/Create Another Render Bean

Create Another Style Bean

1. CLI command

bash
$ zova :refactor:anotherStyle component/card another --module=demo-student

2. Menu command

TIP

Context Menu - [Module Path/src/component/componentName]: Zova Refactor/Create Another Style Bean

Create Another Service Bean

Create a Service another to separate state management

1. CLI command

bash
$ zova :create:bean service component/card/another --module=demo-student

2. Menu command

TIP

Context Menu - [Module Path/src/component/componentName]: Zova Create/Service

Released under the MIT License.