该项目为个人项目,使用antd1.X,目前已经迁移到 antd-auto 开源项目 欢迎大家关注
该项目为个人项目,使用antd1.X,目前已经迁移到 antd-auto 开源项目 欢迎大家关注
该项目为个人项目,使用antd1.X,目前已经迁移到 antd-auto 开源项目 欢迎大家关注
开发 npm run dev 打开浏览器 http://localhost:8989/
构建 npm run build 所使用的字体有跨域问题 在部署上线的时候需要注意下载字体自行部署 修改 src/css/customfont.less 即可
整体部署配置分为 整站配置文件 以及 功能页面配置文件
src/js/common/config.js
/**
* [Config description]
* @type {Object}
*
* header 管理后台头部配置
* title String 标题
* icon String 标题图标
* style Object 自定义样式
*
* sider 管理后台侧栏配置
* menu Array object sider列表
* openKeys Array 默认展开的sider 栏目区
* selectedKey String 默认打开的目标功能页面
* style Object 自定义样式
*
* main 功能区域配置
* components Object 配置sider对应功能区域组件
* Feature1 Object 对应sider menu 中的功能key对 应功能组件
* style Object 配置样式
*/
{
// 头部配置示例
header: {
title: "测试配置管理后台",
icon: "appstore",
style: {
padding: "15px 15px 15px 25px",
borderBottom: "1px solid #E9E9E9",
backgroundColor: "#F5F5F5"
}
},
// 边栏导航配置示例
sider: {
// 层级列表
menu: [
{
title: "数据展示项",
key: "dataShow",
icon: "bars",
items: [
{title: "table数据展示项", key: "Feature1-1"},
{title: "simple对象数据展示项", key: "Feature1-2"},
{title: "数据可视化展示项", key: "Feature1-3"},
{title: "综合数据展示", key: "Feature1-4"}
]
},
{
title: "导航1",
key: "subTitle1",
icon: "setting",
items: [
{title: "选项1", key: "Feature1"},
{title: "选项2", key: "Feature2"},
{title: "选项3", key: "Feature3"},
{
title: "导航3",
key: "subTitle3",
icon: "",
items: [
{title: "选项6", key: "Feature6"},
{title: "选项7", key: "Feature7"},
{title: "选项8", key: "Feature8"}
]
}
]
},{
title: "选项5",
key: "Feature5"
}
],
// 默认打开的导航项目
openKeys:['dataShow','dataOperate'],
// 默认功能页
selectedKey: "Feature1",
// 自定义样式
style: {}
},
// 配置sider对应功能区域组件
main: {
components: {
"Feature1-1": {
title: 'table 数据展示',
component: require('../feature/Feature1-1')
},
"Feature1-2": {
title: 'simple对象 数据展示',
component: require('../feature/Feature1-2')
},
......
},
style: {}
}
}
{
// 对于数据展现形式 目前有 tableList graphList simpleObject 三种类型
type: 'tableList', // tableList graphList simpleObject complexObject
// 初始化展现的数据,使用callback 回传列表数据
// 需要手动添加唯一id key
// callback 组件数据的回调函数(接受列表数据参数)
initData: function(callback){
// 请求数据
Reqwest({
url: 'XXXX',
type: 'jsonp',
jsonpCallback: 'fn',
success: function (data) {
// 获取数组数据
let lists = data.array;
// 必须要向数据中 添加唯一的 key
lists.forEach(function(ele) {
ele.key = ele.id;
});
// 回传数据
callback(lists);
}
});
},
// 功能模块需要时 添加 CRUD 4方法
Create: function(data, callback){
let dataI = Immutable.fromJS({
type: 'entry_list'
}).merge({id: data.key});
// ... 操作删除请求
console.log(dataI.toJS());
// 模拟请求删除成功的回调
setTimeout(function(){
callback();
}, 1000)
},
Delete: function(data, callback){
let dataI = Immutable.fromJS({
type: 'entry_list'
}).merge({id: data.key});
// ... 操作删除请求
console.log(dataI.toJS());
// 模拟请求删除成功的回调
setTimeout(function(){
callback();
}, 1000)
},
Update:function(data, callback){
console.log(data);
},
Retrieve: function(data, callback){
Reqwest({
url: XXXXX,
type: 'jsonp',
success: function (data) {
// 获取数组数据
let lists = data.array;
// 必须要向数据中 添加唯一的 key
lists.forEach(function(ele) {
ele.key = ele.id;
});
// 回传数据
callback(lists);
}
});
},
// 更新项目所需的字段
UType:[
{
name: 'docid',
label: '唯一标识',
type: 'string',
placeholder: '请输入标示名称'
},{
name: 'title',
label: '标题',
type: 'string',
placeholder: '请输入标示名称'
},{
name: 'link',
label: '链接',
type: 'string'
},{
name: 'date',
label: '日期',
type: 'date'
},{
name: 'img',
label: '图片',
type: 'imageUpload'
}
],
// table 列表展现配置
// {
// title table显示表题
// dataIndex 显示数据中的key
// type 展现形式 (string image link)
// render 自定义展现形式 参数 (当前数据,当前对象数据)
// sort 是否需要排序功能
// width 自定义该列宽度 否则等分
// }
//
columns: [
{
title: 'DOCID', // table header 文案
dataIndex: 'docid', // 数据对象内的属性,也做react vdom 的key
type: 'string', // table 内显示的类型
sort: true, // 是否需要排序
width:200
}, {
title: '标题',
dataIndex: 'title',
type: 'string'
}, {
title: '链接',
dataIndex: 'link',
type: 'link',
render: (text) => ( <span>
<a href={text}>链接</a>
</span>),
width: 50
},{
title: '日期',
dataIndex: 'date',
type: 'string',
width: 150
},{
title: '图片',
dataIndex: 'img',
type: 'image'
},{
title: '操作',
type: 'operate', // 操作的类型必须为 operate
width: 120,
btns: [{
text: '更新',
type: 'update'
},{
text: '删除',
type: 'delete'
}, {
text: '展示',
callback: function(item){
console.log(item)
}
}] // 可选
}
],
// simpleObject 类型下按钮
operate:[
{
text: '确认修改',
type: 'update',
style: {
'marginRight': '30px'
}
}, {
text: '展示数据',
callback: function(item){
console.log(item)
}
}
],
};