页面组件
创建页面组件
我们先通过一个 cli 命令来创建一个页面组件counter
:
bash
$ zova :create:page counter --module=a-demo
- module 选项指示该页面组件归属于模块
a-demo
。也可以不指定选项,在命令行提示中再指定 - 该命令会创建一个路由和一个目录
路由
src/suite/a-demo/modules/a-demo/src/routes.ts
typescript
import Counter from './page/counter/index.vue';
export const routes: IModuleRoute[] = [
//
{ path: 'counter', component: Counter },
];
- path:
counter
是相对路径,由于该页面组件属于模块a-demo
,因此其绝对路径是/a/demo/counter
目录
在 Zova 中,一个页面组件被切分为四个文件:
src/suite/a-demo/modules/a-demo/src/page/counter
src
└─ page
└─ counter
├─ index.vue
├─ controller.ts
├─ render.tsx
└─ style.ts
名称 | 说明 |
---|---|
index.vue | 用于定义vue组件 |
controller.ts | 用于业务逻辑的 local bean |
render.tsx | 用于页面渲染的 local bean |
style.ts | 用于页面样式的 local bean |
index.vue
vue
<script setup lang="ts">
import { useControllerPage } from 'zova';
import { ControllerPageCounter } from './controller.js';
import { RenderCounter } from './render.jsx';
import { StyleCounter } from './style.js';
useControllerPage(ControllerPageCounter, RenderCounter, StyleCounter);
</script>
- 只需在
index.vue
中引入controller
bean、render
bean 和style
bean 即可 - useControllerPage 会自动引入一个 IOC 容器,并在容器中注入所需要的 bean 实例
controller.ts
typescript
@Local()
export class ControllerPageCounter {
count: number = 0;
increment() {
this.count++;
}
decrement() {
this.count--;
}
}
- 使用
@Local
将controller
定义为 local bean,从而注册在 IOC 容器中 - 定义一个响应式属性:
count
,类型为number
- 直接用原生 js 代码来修改
count
的值
render.tsx
typescript
@Local()
export class RenderCounter {
render() {
return (
<div>
<div>count(ref): {this.count}</div>
<button onClick={() => this.increment()}>Increment</button>
<button onClick={() => this.decrement()}>Decrement</button>
</div>
);
}
}
- 使用
@Local
将render
定义为 local bean,从而注册在 IOC 容器中 - 在
render
方法中使用tsx
语法书写渲染逻辑 - 直接用原生 js 代码来获取
count
的值
style.ts
typescript
@Local()
export class StyleCounter {}
- 使用
@Local
将style
定义为 local bean,从而注册在 IOC 容器中 - 支持强大的 css-in-js 能力,参见:CSS-in-JS: Style & Theme
渐进式开发
Zova 奉行渐进式开发的理念。如果某些 Vue 组件逻辑比较简单,或者想利用旧的 Vue 组件代码,那么直接像通常一样使用 SFC 开发即可,不必引入 IOC 容器