aotoo是一个react的封装库,将react组件js实例化
在一些小型的项目,不需要引入redux等状态库,使用ao2封装原生react组件(自定义)生成JS对象,通过定义内部的属性和方法,来更新状态
GITHUB源码
yarn add @aotoo/aotoo
#
npm install @aotoo/aotoo
下例是一个简单的计数器组件,为react原生组件添加了属性和api方法,其中api暴露给外部使用,如下例中的button按钮通过暴露的increase方法设置组件计数
Demo: https://codesandbox.io/s/aotoo6jishuqi-dv1uf
import createComponent from '@aotoo/aotoo'
class Count extends React.Component {
render() {
return (
<div className="container" onClick={
this.env.increase}>
{
this.state.count || 0}
</div>
);
}
}
const countInstance = createComponent(Count, {
data: {
// 将转化成react组件的state
count: 0,
},
increase(e) {
let count = this.getData().count;
count++;
this.setData({
count });
}
});
function Container() {
return (
<>
<countInstance.UI />
<button onClick={
countInstance.increase}>计数器</button>
</>
);
}
ReactDOM.render(<Container />, document.getElementById('root'))
参考微信小程序组件的设计,使用配置化生成react组件,并对外曝露相关api方法
Demo: https://codesandbox.io/s/aotoo6jishuqi-forked-vh8n2
import createComponent from '@aotoo/aotoo'
const countTemplate = function (state, props) {
return <div className={
"container"}>{
state.count}</div>;
};
const countConfig = {
data: {
count: 0
},
increase() {
let count = this.getData().count;
count++;
this.setData({
count });
}
};
let count = createComponent(countConfig, countTemplate);
function Container() {
return (
<>
<count.UI />
<button onClick={
count.increase}>计数器</button>
</>
);
}
ReactDOM.render(<Container/>, document.getElementById('root'))
组件的生命周期,指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发。其中,最重要的生命周期是 created
attached
detached
,包含一个组件实例生命流程的最主要时间点。生命周期的设计参考微信小程序
import createComponent, {
$$} from '@aotoo/aotoo';
createComponent({
created: function(){
// 在组件实例刚刚被创建时执行
},
attached: function() {
// 在组件实例进入页面节点树时执行
},
ready: function(){
// 在组件在视图层布局完成后执行
},
didUpdate: function(){
// 在组件挂载后,每一次更新后会调用
},
detached: function() {
// 在组件实例被从页面节点树移除时执行
},
},
template
)
属性 | 类型 | 说明 |
---|---|---|
$$id | String | 类似于$(’#id’)的id |
created | Function | 生命周期,同小程序组件 |
attached | Function | 生命周期,同小程序组件 |
ready | Function | 生命周期,同小程序组件 |
didUpdate | Function | 每次更新后触发 |
方法 | 类型 | 说明 |
---|---|---|
parent | § | 查找父级 |
getData | () | 获取元素数据 |
show | () | 显示该组件 |
hide | () | 隐藏该组件 |
destory | () | 销毁该组件 |
render | § | 渲染组件,与直接写jsx一致 |
attr | (p1, p2) | 设置/获取data-*属性 |
引入@aotoo/aotoo
后,会生成全局变量ui_item
和全局方法组件UI_item
, item组件将会生成一个div
的html结构
配置化生成item组件
import '@aotoo/aotoo'
const itemConfig = {
title: '标题',
onClick: 'changeTitle?title=新的标题',
changeTitle(e, param, inst){
inst.update({
title: param.title
})
}
}
const item = ui_item(itemConfig)
ReactDOM.render(<item.UI />, document.getElementById('root'))
通过React方法组件
import '@aotoo/aotoo'
function changeTitle(e){
this.update({
title: '新的标题'
})
}
const JSX = <UI_item title='标题' onClick={
changeTitle}/>
属性 | 类型 | 说明 |
---|---|---|
$$id | String | 类似于$(’#id’)的id |
title | String/Object/Array | item结构 |
img | String/Object/Array | item结构 |
attr | Object | data-*属性 |
body | Array | item结构,子集均为item |
footer | Array | item结构 |
dot | Array | item结构 |
itemClass | String | 自定义样式 |
itemStyle | String | 自定义样式 |
methods | Object | 自定义方法 |
onXXXX | String/Function | all events |
created | Function | 生命周期,同小程序组件 |
attached | Function | 生命周期,同小程序组件 |
ready | Function | 生命周期,同小程序组件 |
方法 | 参数 | 说明 |
---|---|---|
reset | § | 恢复初始数据 |
update | (p, callback) | 更新数据 |
setData | (p, callback) | 与update相同 |
attr | (p1, p2) | 设置/获取data-*属性 |
addClass | (p, callback) | 新增样式类 |
removeClass | (p, callback) | 移除样式类名 |
hasClass | § | 检测样式类名 |
css | § | 自定义样式 |
toggleClass | (p, callback) | 切换样式类名 |
siblings | § | 查找兄弟元素 |
parent | § | 查找父级 |
getData | () | 获取元素数据 |
show | () | 显示该组件 |
hide | () | 隐藏该组件 |
destory | () | 销毁该组件 |
render | § | 渲染组件,与直接写jsx一致 |
引入@aotoo/aotoo
后,会生成全局变量ui_list
和全局方法组件UI_list
, list组件将会生成一组div
的html结构(基于item
组件)
配置生成list组件
const listConfig = {
data: [
{
title: 'JACK', onClick: 'onItemClick?user=jack'},
{
title: 'ROSE', onClick: 'onItemClick?user=rose'}
],
listClass: 'list-class',
onItemClick(e, param, inst){
if (param.user === 'jack') {
this.update({
'data[0].title': 'JACK LOVE ROSE'
})
}
}
}
const list = ui_list(listConfig)
ReactDOM.render(<list.UI />, document.getElementById('root'))
通过React方法组件
import {
$$} '@aotoo/aotoo'
function itemClick(e, param, inst){
if (param.user === 'jack') {
this.update({
'data[0].title': 'JAKE LOVE ROSE'
})
}
}
const listData = [
{
title: 'JACK', onClick: 'onItemClick?user=jack'},
{
title: 'ROSE'}
]
const JSX = <UI_list
$$id='mylist'
data={
listData}
onItemClick={
itemClick}
/>
setTimeout(() => {
$$('#mylist').update({
'data[1].title': 'ROSE LOVE JACK TOO'
})
}, 4000);
ReactDOM.render(JSX, document.getElementById('root'))
属性 | 类型 | 说明 |
---|---|---|
$$id | String | 类似于$(’#id’)的id |
data | Array | list子集合 |
header | JSX | 列表头部 |
footer | JSX | 列表底部 |
listClass | String | 列表样式类 |
listStyle | String | 列表内联样式 |
itemClass | String | 批量设置子项样式类 |
itemMethod | Object | 批量设置子项事件方法 |
methods | Object | 设置实例方法 |
mode | String | 列表类型 |
方法 | 参数 | 说明 |
---|---|---|
reset | § | 恢复初始数据 |
update | (p, callback) | 更新数据 |
setData | (p, callback) | 与update相同 |
insert | (query, pay) | 插入数据 |
append | (pay) | 追加数据 |
prepend | (pay) | 前置数据 |
remove | (query) | 删除数据 |
attr | (p1, p2) | 设置/获取data-*属性 |
addClass | (p, callback) | 新增样式类 |
removeClass | (p, callback) | 移除样式类名 |
hasClass | § | 检测样式类名 |
css | § | 自定义样式 |
toggleClass | (p, callback) | 切换样式类名 |
parent | § | 查找父级 |
getData | () | 获取元素数据 |
show | () | 显示该组件 |
hide | () | 隐藏该组件 |
destory | () | 销毁该组件 |
render | § | 渲染组件,与直接写jsx一致 |
tree组件是list组件的超集,通过扁平数据输出层次性的HTML结构,可支持多层次数据
const listConfig = {
data: [
{
title: '广东省', idf: 'gd'},
{
title: '广州市', parent: 'gd', idf: 'gz'},
{
title: '天河区', parent: 'gd', parent: 'gz'},
{
title: '白云区', parent: 'gd', parent: 'gz'},
{
title: '越秀区', parent: 'gd', parent: 'gz'},
{
title: '深圳市', parent: 'gd'},
{
title: '东莞市', parent: 'gd'},
{
title: '湖南省', idf: 'hn'},
{
title: '长沙市', parent: 'hn'},
{
title: '衡阳市', parent: 'hn'},
],
mode: 'tree'
}
const tree = ui_list(listConfig)
ReactDOM.render(<tree.UI />, document.getElementById('root'))
空格不是必须的,为展现数据层次
关注我们,后续完善文档