vue、react相继都有了小程序的开发框架,作为一个nger,也该为社区做点事情了!
很遗憾,由于ng和小程序的差异性,我们暂时没打算直接把ng项目转换成小程序,而是用ng的一套思想(依赖注入
、装饰器
等)来规范开发小程序!已达到一套代码多平台运行。
用装饰器实现应用跨平台,如Controller装饰器,在前端就是发送http请求,在后端就是响应http请求 主要目标nger-compiler根据平台需求,选择性的去除或修改代码,nger-platform-*提供装饰器解析器。
**PropertyAst
是属性装饰器节点,对应的有is**PropertyAst
方法**ClassAst
是类装饰器节点,对应的有is**ClassAst
方法**MethodAst
是方法装饰器节点,对应的有is**MethodAst
方法**ControllerAst
是构造装饰器节点,对应的有is**ControllerAst
方法**Parameter
是方法参数装饰器节点,对应的有is**ParameterAst
方法
命令行工具
-
yarn cli build
构建打包- 手机h5
yarn cli build h5
- pc网站
yarn cli build pc
- 微信公众号
yarn cli build wechat
- 微信小程序
yarn cli build weapp
- 支付宝小程序
yarn cli build alipay
- 百度智能小程序
yarn cli build swap
- 字节跳动小程序
yarn cli build tt
- ios客户端
yarn cli build ios
- android客户端
yarn cli build android
- 手机h5
- 初始化
yarn cli init demo
-
yarn cli init
初始化 -
yarn cli test
单元测试 -
yarn cli start
启动服务 -
yarn cli publish
发布到当前src模块应用商城
核心库
- angular装饰器
- typeorm装饰器
- entity
- ChildEntity
- Entity
- TableInheritance
- columns
- Column
- CreateDateColumn
- ObjectIdColumn
- PrimaryColumn
- PrimaryGeneratedColumn
- UpdateDateColumn
- VersionColumn
- listeners
- AfterInsert
- AfterLoad
- AfterRemove
- AfterUpdate
- BeforeInsert
- BeforeRemove
- BeforeUpdate
- EventSubscriber
- relations
- JoinColumn
- JoinTable
- ManyToMany
- ManyToOne
- OneToMany
- OneToOne
- RelationCount
- RelationId
- transaction
- Transaction
- TransactionManager
- TransactionRepository
- tree
- Tree
- TreeChildren
- TreeLevelColumn
- TreeParent
- other
- Check
- EntityRepository
- Exclusion
- Generated
- Unique
- entity
- nest装饰器
-
Get
(可选)发送get
请求 -
Post
(可选)发送post
请求 -
Controller
(可选)Api层,用于后端
-
- 其他装饰器
-
Page
页面 -
Command
(可选)命令行 -
Option
(可选)命令参数 -
It
(可选)单元测试
-
- 生命周期
-
OnInit
-
DoCheck
-
OnDestroy
-
AfterContentInit
-
AfterContentChecked
-
AfterViewInit
-
AfterViewChecked
-
开发重点 nger-compiler 到 nger-di 目标src目录中的文件,编译到各个平台,并运行。
- 扫描项目目录,并记录每个文件导出的有装饰器装饰的类及名称。
- 根据运行目标,去掉没有用的或者可以去掉的一些内容,例如
@It
,@Command
,@Option
等 -
@Component
装饰的类生成对应的Component(ComponentInstance)
-
@Page
装饰的类生成对应的Page(PageInstance)
- 搜集配置信息生成
json
文件 - 编译
html
生成wxml
文件 - 编译
scss
/less
/styl
生成wxss
文件 - 编译生成
js
文件
客户端运行时需要编译器转码
import { Controller, Get, Post } from 'nger-core'
@Controller({
path: '/'
})
export class IndexController {
info: any = {
username: 'nger',
age: 28
}
@Get()
userInfo() {
return this.info;
}
@Post()
setUserInfo(username: string, age: number) {
this.info = {
username,
age
}
}
}
// to
import { Get, Post, Controller } from 'nger-core'
@Controller({
path: '/'
})
export class NgerUserController {
@Get()
userInfo: () => Promise<any>;
@Post()
setUserInfo: (username: string, age: number) => Promise<any>;
}
// TODO
@Page({
path: `pages/index/index`,
template: `<view></view>`
})
export class ImsPage{}
// pages/index/index.js
// pages/index/index.json
// pages/index/index.wxss
// pages/index/index.wxml
// **/ims-demo.ts
import {Component,Input,EventEmitter} from 'nger-core';
@Component({
selector: 'ims-demo',
template: `<view (onTap)="click"></view>`
})
export class ImsDemo {
@Input()
title: string;
@Output()
bindmyevent: EventEmitter;
click(e){
this.bindmyevent.emit(e);
}
}
// to
// **/ims-demo.js
const instance = new ImsDemo();
Component({
behaviors: [],
data: {
instance: instance
},
properties: {
// Input
title: instance.title
},
lifetimes: {
created(){
instance.ngOnInit()
},
attached() {
instance.onViewInit()
},
ready(){
instance.onAfterViewInit()
},
moved() {
instance.onMoved()
},
detached() {
instance.onDestory()
},
error() {
instance.onError()
},
},
pageLifetimes: {
show(){
instance.onShow()
},
hide(){
instance.onHide()
},
resize(){
instance.onResize()
}
},
methods: {
click: instance.click
}
})
// **/ims-demo.json
{}
// **/ims-demo.wxss
// **/ims-demo.wxml
<view onTap="click"></view>
<ng-template [ngIf]="condiction"></ng-template>
<!-- to -->
<ng-template wx:if="{{condiction}}"></ng-template>
<ng-template [ngIf]="condiction" [ngIfELse]="elseBlock">condiction</ng-template>
<ng-template #elseBlock>elseBlock</ng-template>
<!-- to -->
<ng-template wx:if="{{condiction}}"></ng-template>
<ng-template wx:else>elseBlock</ng-template>
<ng-template [ngIf]="condiction" [ngIfThen]="thenBlcok" [ngIfELse]="elseBlock"></ng-template>
<ng-template #thenBlcok>thenBlcok</ng-template>
<ng-template #elseBlock>elseBlock</ng-template>
<!-- to -->
<ng-template wx:if="{{condiction}}">thenBlcok</ng-template>
<ng-template wx:else>elseBlock</ng-template>
<ng-template ngFor let-item="it" let-i="index" [ngForOf]="items"></ng-template>
<!-- to -->
<ng-template wx:for="items" wx:for-item="it" wx:for-index="i"></ng-template>
用于启动测试
用于启动cli
express环境
express环境
typeorm环境
小程序运行
依赖注入实现
带色打印工具
- Logger 接口
-
ConsoleLogger
Logger
的console
实现