public路由
说明
通过使用 /public
路由来免登陆访问页面;
页面需使用公共接口。
效果
使用
1.定义路由
根据 hzero
路由定义方式定义路由,需要在path
上加入 /public
前缀,例如
{
authorized: true,
path: "/public/hiam/public-demo",
component: "PublicDemo",
key: '/public/hiam/public-demo',
models: [
"publicDemo"
]
}
2.开发页面
页面的开发方式保持不变。
index.js
:
import React from 'react';
import { connect } from 'dva';
import { Table } from 'hzero-ui';
import { Bind } from 'lodash-decorators';
import { Content, Header } from 'components/Page';
import FilterForm from './FilterForm';
@connect(({ loading, publicDemo }) => ({
fetchLoading: loading.effects['publicDemo/fetchData'],
publicDemo,
}))
export default class PublicDemo extends React.Component {
filterForm;
componentDidMount() {
this.fetchList();
}
fetchList(params = {}) {
const {
dispatch,
publicDemo: { pagination = {} },
} = this.props;
const filterValue = this.filterForm === undefined ? {} : this.filterForm.getFieldsValue();
dispatch({
type: 'publicDemo/fetchData',
payload: { page: pagination, ...filterValue, ...params },
});
}
@Bind()
handleSearch() {
this.fetchList({ page: {} });
}
@Bind()
handleBindRef(ref) {
this.filterForm = (ref.props || {}).form;
}
@Bind()
handleResetSearch() {
this.filterForm.resetFields();
}
/**
* handlePagination - 分页设置
* @param {object} pagination - 分页对象
*/
@Bind()
handlePagination(pagination) {
this.fetchList({ page: pagination });
}
render() {
const { fetchLoading = false, publicDemo: { data = [] } = {}, pagination = {} } = this.props;
const columns = [
{
title: 'ID',
dataIndex: 'id',
width: 100,
},
{
title: '客户端名',
dataIndex: 'clientName',
},
];
return (
<React.Fragment>
<Header title="前端免登陆示例" />
<Content>
<div className="table-list-search">
<FilterForm
onSearch={this.handleSearch}
onReset={this.handleResetSearch}
onRef={this.handleBindRef}
/>
</div>
<Table
bordered
loading={fetchLoading}
rowKey="id"
columns={columns}
dataSource={data}
pagination={pagination}
onChange={this.handlePagination}
/>
</Content>
</React.Fragment>
);
}
};
FilterForm.js
:
import React from 'react';
import { Form, Button, Input } from 'hzero-ui';
import { Bind } from 'lodash-decorators';
import intl from 'utils/intl';
const FormItem = Form.Item;
@Form.create({ fieldNameProp: null })
export default class FilterForm extends React.PureComponent {
constructor(props) {
super(props);
// 调用父组件 props onRef 方法
props.onRef(this);
}
/**
* 查询操作
*/
@Bind()
handleSearch() {
const { form, onSearch } = this.props;
onSearch(form);
}
/**
* 重置操作
*/
@Bind()
handleReset() {
const { form, onReset } = this.props;
onReset(form);
}
render() {
const { form } = this.props;
const { getFieldDecorator } = form;
return (
<Form layout="inline">
<FormItem label="客户端名">
{getFieldDecorator('param')(<Input />)}
</FormItem>
<FormItem>
<Button style={{ marginRight: 8 }} onClick={this.handleReset}>
{intl.get('hzero.common.button.reset').d('重置')}
</Button>
<Button type="primary" htmlType="submit" onClick={this.handleSearch}>
{intl.get('hzero.common.button.search').d('查询')}
</Button>
</FormItem>
</Form>
);
}
}