vuejs-elementUI-treeTable

1、树与数组转换对应的目录如下图所示:



1、树与数组转换

        /*

* @Author: zhr

*/

import Vue from 'vue';

function DataTransfer (data) {

  if (!(this instanceof DataTransfer)) {

    return new DataTransfer(data, null, null);

  }

};

DataTransfer.treeToArray = function (data, parent, level, expandedAll) {

  let tmp = [];

  Array.from(data).forEach(function (record) {

    if (record._expanded === undefined) {

      Vue.set(record, '_expanded', expandedAll);

    }

    if (parent) {

      Vue.set(record, '_parent', parent);

    }

    let _level = 0;

    if (level !== undefined && level !== null) {

      _level = level + 1;

    }

    Vue.set(record, '_level', _level);

    tmp.push(record);

    if (record.children && record.children.length > 0) {

      let children = DataTransfer.treeToArray(record.children, record, _level, expandedAll);

      tmp = tmp.concat(children);

    }

  });

  return tmp;

};

export default DataTransfer;

代码截图:


2、构造Tree-Table的页面

          对应的代码:

import Utils from './utils/index.js';

export default {

    name: 'tree-grid',

    props: {

        // 该属性是确认父组件传过来的数据是否已经是树形结构了,如果是,则不需要进行树形格式化

        treeStructure: {

            type: Boolean,

            default: function() {

                return false;

            }

        },

        // 这是相应的字段展示

        columns: {

            type: Array,

            default: function() {

                return [];

            }

        },

        // 这是数据源

        dataSource: {

            type: Array,

            default: function() {

                return [];

            }

        },

        // 这个作用是根据自己需求来的,比如在操作中涉及相关按钮编辑,删除等,需要向服务端发送请求,则可以把url传过来

        requestUrl: {

            type: String,

            default: function() {

                return '';

            }

        },

        // 这个是是否展示操作列

        treeType: {

            type: String,

            default: function() {

                return 'unnormal';

            }

        },

        // 是否默认展开所有树

        defaultExpandAll: {

            type: Boolean,

            default: function() {

                return true;

            }

        },

        // 默认被点击时的样式处理

        defaultRowHightLine: {

            type: String,

            default: function() {

                return '';

            }

        }

    },

    data() {

        return {

            rowDefalut: '' // 防止被上次点击颜色渲染标志位

        };

    },

    computed: {

        // 格式化数据源

        data: function() {

            let me = this;

            if (me.treeStructure) {

                let data = Utils.MSDataTransfer.treeToArray(me.dataSource, null, null, me.defaultExpandAll);

                data.forEach(e => {

                  if (this.defaultRowHightLine !== '') {

                    e = this.$options.methods.hindChild(e, this.defaultRowHightLine);

                  }

                });

                return data;

            }

            return me.dataSource;

        }

    },

    methods: {

        // 显示行

        showTr: function({row, rowIndex}) {

            let show = (row._parent ? (row._parent._expanded && row._parent._show) : true);

            row._show = show;

            // 编辑时只展开该行对应的机构以及上层机构

            if (this.defaultRowHightLine !== '' && this.defaultRowHightLine === row.id + '') {

                return show;

            }

            return show ? '' : 'display:none;';

        },

        adjustCol({row, column, rowIndex, columnIndex}) {

            if (column.label === this.$i18n.t('treeTable.commonName')) {

              console.log('21212111');

              return 'width-row';

            }

        },

        // 将没有选择的节点隐藏

        hindChild(row, lid) {

          let id = row.id + '';

          if (id !== lid && row.children && row.children.length > 0) {

            this.hindChild(row.children);

            row._expanded = false; // 若不是已选择的节点,则设为不展开

          }

          if (id === lid && row._parent) {

            this.showParent(row._parent);

          }

          return row;

        },

        showParent(row) {

          row._expanded = true;

          if (row._parent) {

            this.showParent(row._parent);

          }

        },

        // 点击某一行

        clickRow(row, event, column) {

            if (this.treeType === 'unnormal') {

                this.$emit('setInstitution', row);

            }

            this.rowDefalut = row.id + '';

        },

        // 列表中行样式处理

        tableRowClassName({row, rowIndex}) {

            let id = row.id;

            if (typeof id === 'number') {

                id = id + '';

            }

            // 某一行编辑时默认样式处理

            if (this.defaultRowHightLine !== '' && this.defaultRowHightLine === id) {

                this.rowDefalut = '';

                return 'info-row';

            } else if (this.rowDefalut === id) { // 机构发生改变时,点击时颜色发生发生变动

                return 'info-row';

            } else {

                return '';

            }

        },

        // 展开下级

        toggle: function(trIndex) {

            let me = this;

            let record = me.data[trIndex];

            record._expanded = !record._expanded;

        },

        // 显示层级关系的空格和图标

        spaceIconShow(index) {

            let me = this;

            if (me.treeStructure && index === 0) {

                return true;

            }

            return false;

        },

        // 点击展开和关闭的时候,图标的切换

        toggleIconShow(index, record) {

            let me = this;

            if (me.treeStructure && index === 0 && record.children && record.children.length > 0) {

                return true;

            }

            return false;

        },

        handleEdit(row) { // 编辑

            this.$emit('editRow', row);

        },

        handleAdd(id) { // 添加

            this.$emit('addChild', id);

        },

        handleDelete(row) { // 删除

            this.$emit('delete', row);

        }

    }

};.ms-tree-space {

    position: relative;

    top: 1px;

    display: inline-block;

    font-family: 'Glyphicons Halflings';

    font-style: normal;

    font-weight: 400;

    line-height: 1;

    width: 18px;

    height: 14px;

}

.ms-tree-space::before {

    content: ""

}

table td {

    line-height: 26px;

}

.el-table__expand-icon--expanded {

    -ms-transform: rotate(90deg);

    transform: rotate(90deg);

}

/**

* 颜色标红提醒

*/

.el-table .info-row {

    background: #FFFACD;

}

.el-table .width-row {

    width: 300px;

}

该部分代码较多,所以没有截图。

3、在页面引用

import TreeGrid from '@/components/TreeGrid';

import backTop from '@/components/back-top';

import {

    checkCode

}

from '@/common/js/validate';

import {

    IS_ADD

}

from '@/common/js/dict';

import {

    findTree, createTree, updateTree, deleteTree

}

from '@/common/api/system/organization/organization';

export default {

    components: {

        'tree-grid': TreeGrid,

        'back-top': backTop

    },

    data() {

        return {

            normal: 'normal', // 控制操作按钮是否显示

            filters: {

                commonName: ''

            },

            orgForm: {

                id: '',

                commonName: '',

                shortName: '',

                enName: '',

                parentId: '',

                type: '',

                isAdd: '',

                remarks: ''

            },

            orgFormVisible: false,

            dataSource: [{

                id: '1',

                commonName: '外交外事相关机构',

                enName: '1111',

                shortName: '222222',

                nodeLevel: '0',

                parentId: '0',

                remarks: '2222222',

                isAdd: 0,

                children: [{

                    id: '4',

                    commonName: '外交部中心',

                    enName: '22222',

                    shortName: '33333',

                    nodeLevel: '1',

                    parentId: '1',

                    remarks: '22222',

                    isAdd: 0,

                    children: [{

                        id: '9',

                        commonName: '领事司',

                        enName: '22222',

                        shortName: '33333',

                        nodeLevel: '2',

                        parentId: '4',

                        remarks: '22222',

                        isAdd: 1,

                        children: [{

                            id: '39',

                            commonName: '亚非领事处',

                            enName: '22222',

                            shortName: '33333',

                            nodeLevel: '3',

                            parentId: '9',

                            remarks: '22222',

                            isAdd: 1,

                            children: [{

                                id: '79',

                                commonName: 'ddddd12',

                                enName: '22222',

                                shortName: '33333',

                                nodeLevel: '4',

                                parentId: '39',

                                remarks: '22222',

                                isAdd: 1

                            }, {

                                id: '80',

                                commonName: 'sssss12',

                                enName: '22222',

                                shortName: '33333',

                                nodeLevel: '4',

                                parentId: '39',

                                remarks: '22222',

                                isAdd: 1

                            }]

                        }, {

                            id: '40',

                            commonName: '欧美大领事处',

                            enName: '22222',

                            shortName: '33333',

                            nodeLevel: '3',

                            parentId: '9',

                            remarks: '22222',

                            isAdd: 1

                        }]

                    }, {

                        id: '10',

                        commonName: 'xxxxx',

                        enName: '22222',

                        shortName: '33333',

                        nodeLevel: '2',

                        parentId: '4',

                        remarks: '22222',

                        isAdd: 1

                    }]

                }, {

                    id: '2',

                    commonName: '其他单位',

                    enName: '22222',

                    shortName: '33333',

                    nodeLevel: '1',

                    remarks: '22222',

                    parentId: '1',

                    isAdd: 1,

                    children: [{

                        id: '11',

                        commonName: '领事司',

                        enName: '22222',

                        shortName: '33333',

                        nodeLevel: '2',

                        parentId: '2',

                        remarks: '22222',

                        isAdd: 1

                    }, {

                        id: '12',

                        commonName: 'xxxxx',

                        enName: '22222',

                        shortName: '33333',

                        nodeLevel: '2',

                        parentId: '2',

                        remarks: '22222',

                        isAdd: 1

                    }]

                }, {

                    id: '3',

                    commonName: '地方外办',

                    enName: '22222',

                    shortName: '33333',

                    nodeLevel: '1',

                    parentId: '1',

                    remarks: '22222',

                    isAdd: 1,

                    children: [{

                        id: '8',

                        commonName: '领事司',

                        enName: '22222',

                        shortName: '33333',

                        nodeLevel: '2',

                        parentId: '3',

                        remarks: '22222',

                        isAdd: 1

                    }, {

                        id: '13',

                        commonName: 'xxxxx',

                        enName: '22222',

                        shortName: '33333',

                        nodeLevel: '2',

                        parentId: '3',

                        remarks: '22222',

                        isAdd: 1

                    }]

                }]

            }]

        };

    },

    created() {

        this.loadData();

    },

    computed: {

        columns() {

                return [{ // 列表索引

                    text: this.$i18n.tp('table.commonName'),

                    dataIndex: 'commonName'

                }, {

                    text: this.$i18n.tp('table.shortName'),

                    dataIndex: 'shortName'

                }, {

                    text: this.$i18n.tp('table.id'),

                    dataIndex: 'id'

                }, {

                    text: this.$i18n.tp('table.nodeLevel'),

                    dataIndex: 'nodeLevel'

                }, {

                    text: this.$i18n.tp('table.isAdd'),

                    dataIndex: 'isAdd'

                }, {

                    text: this.$i18n.tp('table.remarks'),

                    dataIndex: 'remarks'

                }];

            },

            ruler() {

                return {

                    commonName: [{

                        required: true,

                        message: this.$i18n.t('validate.checkNull.nempty')

                    }],

                    id: [{

                        required: true,

                        messages: {

                            error1: this.$i18n.t('validate.checkNum.digital'),

                            error2: this.$i18n.t('validate.checkNum.nzero'),

                            error3: this.$i18n.t('validate.checkNum.limitParLength')

                        },

                        validator: checkCode

                    }],

                    enName: [{

                        required: true,

                        message: this.$i18n.t('validate.checkNull.nempty')

                    }],

                    shortName: [{

                        required: true,

                        message: this.$i18n.t('validate.checkNull.nempty')

                    }]

                };

            }

    },

    methods: {

            search() {

                this.loadData();

            },

            loadData() { // 加载数据

                let param = Object.assign({}, this.filters);

                findTree(param).then(resp => {

                    // console.log('1111', resp.data);

                    this.treeData = resp.data;

                }).catch(error => {

                    this.$message({

                        // message: this.$i18n.tp('treeMsg.selectFail'),

                        message: error.data,

                        type: 'error'

                    });

                    // console.log('22222', JSON.stringify(error));

                    return error;

                });

            },

            handleCurrentAddChild(id) { // 新增子节点

                this.$refs.orgForm.resetFields();

                this.orgFormVisible = true;

                this.orgForm.parentId = id;

                this.orgForm.id = '';

                this.orgForm = Object.assign(this.orgForm, this.currentDict);

                this.$nextTick(() => {  // 页面渲染之后处理

                  document.getElementById('tree-table').scrollTop = this.$refs.orgForm.$el.offsetTop; //

                });

            },

            handleCurrentEdit(row) { // 编辑列表中某一行

                this.$refs.orgForm.resetFields();

                this.orgFormVisible = true;

                if (row._parent !== undefined) {

                    this.orgForm.parentId = row._parent.id;

                }

                this.orgForm = Object.assign(this.orgForm, row);

                this.orgForm.isAdd = this.commonDict(row.isAdd, IS_ADD);

                this.$nextTick(() => {  // 页面渲染之后处理

                  // orgForm 设为锚点

                  document.getElementById('tree-table').scrollTop = this.$refs.orgForm.$el.offsetTop; //

                });

            },

            handleCurrentDelete(row) { // 注销列表中某一行

                if (row._level === 0 || row._level === 1) {

                    this.$message({

                        message: this.$i18n.tp('treeMsg.noallow'),

                        type: 'danger'

                    });

                    return;

                }

                this.$refs.orgForm.resetFields();

                this.orgFormVisible = false;

                this.$confirm(this.$i18n.tp('message.del'), this.$i18n.tp('message.prompt'), {

                    confirmButtonText: this.$i18n.tp('message.sure'),

                    cancelButtonText: this.$i18n.tp('message.cancel'),

                    confirmButtonClass: 'confirmButtonClass',

                    type: 'warning'

                }).then(() => {

                    let params = {

                        id: row.id

                    };

                    deleteTree(params).then(data => {

                        if (data.status === 0) {

                            this.$message({

                                message: this.$i18n.tp('treeMsg.delSucc'),

                                type: 'success'

                            });

                            this.orgFormVisible = false;

                            // console.log('1111', row._parent.id);

                            this.loadData();

                        }

                    }).catch(error => {

                        this.$message({

                            message: error.data,

                            type: 'error'

                        });

                        return error;

                    });

                }).catch(() => {

                    this.$message({

                        type: 'info',

                        message: this.$i18n.tp('message.canceldel'),

                        duration: 1000

                    });

                });

            },

            submitForm() { // 保存

                this.$refs.orgForm.validate((valid) => {

                    if (valid) {

                        let params = Object.assign({}, this.orgForm);

                        params.isAdd = this.commonDictCover(params.isAdd, IS_ADD);

                        delete params.children;

                        var response = {};

                        if (params.id !== null && params.id !== undefined && params.id.length > 0) {

                            response = updateTree(params); // 更新

                        } else {

                            response = createTree(params); // 创建节点

                        }

                        response.then(data => {

                            this.$message({

                                message: this.$i18n.tp('treeMsg.saveSucc'),

                                type: 'success'

                            });

                            this.orgFormVisible = false;

                            this.resetForm();

                            this.loadData();

                        }).catch(error => {

                            this.$message({

                                message: this.$i18n.tp('treeMsg.saveFail'),

                                type: 'error',

                                showClose: true,

                                duration: 3000

                            });

                            return error;

                        });

                    }

                });

            },

            resetForm() { // 取消 按钮的事件

                this.$refs.orgForm.resetFields(); // 表单中填写的数据的重置方法

                this.orgFormVisible = false;

            },

            commonDict(type, Obj) { // 字典处理

                let obj = Object.assign({}, Obj);

                for (var variable in obj) {

                    if (typeof type === 'number') {

                        variable = parseInt(variable);

                    }

                    if (variable === type) {

                        obj[variable] = this.$i18n.t(obj[variable]);

                        return obj[variable];

                    }

                }

            },

            commonDictCover(str, Obj) { // 字典反解Key处理

                if (parseInt(str) === 1 || parseInt(str) === 0) {

                    return str;

                }

                let obj = Object.assign({}, Obj);

                for (var variable in obj) {

                    if (this.$i18n.t(obj[variable]) === str) {

                        return parseInt(variable);

                    }

                }

            }

    }

};.main-backTop {

    height: calc(100vh - 9.35rem);

    overflow: auto;

}

一键置顶操作

export default {

  name: 'BackTop',

  props: {

    scrollmyself: {

      type: Boolean,  // 这是选择滚动对象的props值,如果滚动的对象是当前组件的父元素,就设置scrollObj为true.如果没有设置就默认为window对象

      default: false

    }

  },

  data () {

    return {

      isShow: false,

      target: ''

    };

  },

  methods: {

    addhoverClass (e) {

      if (e.type === 'mouseover') {

        this.$el.classList.add('hover');

      } else if (e.type === 'mouseout') {

        this.$el.classList.remove('hover');

      }

    },

    showIcon () {

      if (this.target.scrollTop > 100) {

        this.isShow = true;

        this.$el.addEventListener('mouseover', this.addhoverClass);

        this.$el.addEventListener('mouseout', this.addhoverClass);

      } else if (this.target.scrollTop < 100) {

        this.isShow = false;

      }

    },

    getTop () {

      this.$emit('shutdownForm'); // 关闭表单

      let timer = setInterval(() => {

        let top = this.target.scrollTop;

        let speed = Math.ceil(top / 5);

        this.target.scrollTop = top - speed;

        if (top === 0) {

          clearInterval(timer);

        }

      }, 20);

    }

  },

  mounted () {

    // 通过这个target来判断当前的滚动监听对象是谁

    if (this.scrollmyself) {

      this.target = this.$el.parentNode;

    } else {

      this.target = document.body;

    }

    console.log(this.target);

    this.target.addEventListener('scroll', this.showIcon);

  },

  beforeDestroy () {

    this.target.removeEventListener('scroll', this.showIcon);

  }

};  .slide-fade-enter-active {

    transition: all .1s ease;

  }

  .slide-fade-leave-active {

    transition: all .1s cubic-bezier(1.0, 0.3, 0.8, 1.0);

    opacity: 0;

  }

  .slide-fade-enter, .slide-fade-leave-to

  /* .slide-fade-leave-active 在低于 2.1.8 版本中 */ {

  // transform: translateY(-20px);

    opacity: 0;

  }

  .page-component-up {

    background-color: #4eb1fb;

    position: fixed;

    right: 5rem;

    bottom: 5rem;

    width: 50px;

    height: 50px;

    border-radius: 25px;

    cursor: pointer;

    opacity: .4;

    transition: .3s;

    text-align: center;

    z-index: 999;

  }

  .tri {

    width: 0;

    height: 0;

    border: 12px solid transparent;

    border-bottom-color: #dfe6ec;

    text-align: center;

  }

  .hover {

    background-color: red;

  }

校验文件

/** 数据字典校验位数限制 */

const checkCode = (ruls, value, callback) => {

  console.log('222222', ruls.messages, value);

  setTimeout(() => {

    if (value.length > 18) {

      callback(new Error(ruls.messages.error3));

    }

    if (!/^\+?[0-9][0-9]*$/.test(value)) {

      callback(new Error(ruls.messages.error1));

    } else {

      if (parseInt(value) < 0) {

        callback(new Error(ruls.messages.error2));

      } else {

        callback();

      }

    }

  }, 500);

};

/** 账户ID限制 */

const checkAccount = (ruls, value, callback) => {

  console.log('222222', ruls.messages, /^[\dA-Za-z.]{1,20}$/ig.test(value));

  setTimeout(() => {

    if (!value) {

      callback(new Error(ruls.messages.error1));

    }

    if (!/^[\dA-Za-z.]{1,20}$/ig.test(value)) {

      callback(new Error(ruls.messages.error2));

    } else {

      callback();

    }

  }, 500);

};

/** 判断密码 */

const checkPwd = (ruls, value, callback) => {

    setTimeout(() => {

    if (!value) {

      callback(new Error(ruls.messages.error1));

    }

    if (!/^[\dA-Za-z]{6,18}$/ig.test(value)) {

      callback(new Error(ruls.messages.error2));

    } else {

      callback();

    }

  }, 500);

};

/** 确认密码 */

const checkConfirmPwd = (ruls, value, callback) => {

    setTimeout(() => {

    if (!value) {

      callback(new Error(ruls.messages.error1));

    }

    if (value !== ruls.confirm()) {

      callback(new Error(ruls.messages.error2));

    } else {

      callback();

    }

  }, 500);

};

/** 数量校验 空白卡管理模块-生产工人归还/查验人归还-公共 */

const checkNum = (ruls, value, callback) => {

  console.log('222222', ruls.messages, value);

  setTimeout(() => {

    if (!/^\+?[0-9][0-9]*$/.test(value)) {

      callback(new Error(ruls.messages.error1()));

    } else {

      if (parseInt(value) < 0) {

        callback(new Error(ruls.messages.error2()));

      } else {

        callback();

      }

    }

  }, 500);

};

/** 内容不为空提示 */

const checkNull = (ruls, value, callback) => {

  console.log('1112222211', ruls.messages, value);

  setTimeout(() => {

    if (!value) {

      callback(new Error(ruls.messages.error1()));

    } else {

      callback();

    }

  }, 500);

};

/** 手机号校验  */

const checkPhone = (rule, value, callback) => {

    let reg = /^((\d{3}-\d{8}|\d{4}-\d{7,8})|(1[3|5|7|8][0-9]{9}))$/;

    setTimeout(() => {

        if (!reg.test(value)) {

            callback(new Error(rule.messages.illegal()));

        } else {

            callback();

        }

    }, 1000);

};

/** 采集点邮寄天数配置 时间验证 */

const validDay = (ruls, value, callback) => {

  setTimeout(() => {

    if (!Number.isInteger(value * 1)) {

      callback(new Error(ruls.messages.err01()));

    } else if (value < 0) {

      callback(new Error(ruls.messages.err02()));

    } else if (value === '' || value.toString().trim() === '') {

      callback(new Error(ruls.messages.err03()));

    } else {

      callback();

    }

  });

};

export {

  checkCode,

  checkAccount,

  checkPhone,

  validDay,

  checkNull,

  checkPwd,

  checkConfirmPwd,

  checkNum

};

字典文件

// 常量

/**

* 团组进度状态

*/

export const GROUP_STATUS = {

  '1': '已受理',

  '0': '已结束'

};

// 查询状态

export const QUERY_STATUS = {

  '1': '查询成功',

  '0': '查询中',

  '-1': '查询失败'

};

// 是否有效

export const IS_EFFECT = {

  1: 'dict.isEffect.effect',

  0: 'dict.isEffect.invalid'

};

// 是否可以编辑

export const IS_EDIT = {

  1: 'dict.isEdit.yes',

  0: 'dict.isEdit.no'

};

// 是否可以添加管理员

export const IS_ADD = {

  1: 'dict.isAdd.yes',

  0: 'dict.isAdd.no'

};

// 角色类型

export const ROLE_TYPE = {

  1: 'dict.roleType.bussineAdmin',

  2: 'dict.roleType.inspectAdmin',

  3: 'dict.roleType.sysAdmin'

};

// 角色数据源

export const ROLE_SOURCE = [

  {

    value: '1',

    label: 'dict.roleType.bussineAdmin'

  }, {

    value: '2',

    label: 'dict.roleType.inspectAdmin'

  }, {

    value: '3',

    label: 'dict.roleType.sysAdmin'

  }

];

// 角色类型

export const ACCOUNT_STATUS_TYPE = {

  0: 'dict.accountType.normal',

  1: 'dict.accountType.locked',

  2: 'dict.accountType.invalid',

  3: 'dict.accountType.expired',

  4: 'dict.accountType.logged'

};

// 账户资源

export const ACCOUNT_STATUS_SOURCE = [

  {

    value: '0',

    label: 'dict.accountType.normal'

  }, {

    value: '1',

    label: 'dict.accountType.locked'

  }, {

    value: '2',

    label: 'dict.accountType.invalid'

  }, {

    value: '3',

    label: 'dict.accountType.expired'

  }, {

    value: '3',

    label: 'dict.accountType.logged'

  }

];

后台API

import { post } from '@/common/js/axios';

// 获取用户列表 //

/** 查询用户 */

export const accountFind = params => { return post(`/sysdict/account/find`, params); };

/** 添加用户 */

export const accountAdd = params => { return post(`/sysdict/account/create`, params); };

/** 编辑用户 */

export const accountUpdate = params => { return post(`/sysdict/account/update`, params); };

/** 删除用户 */

export const accountDelete = params => { return post(`/sysdict/account/delete`, params); };

/** 查询机构信息 */

export const findTree = params => post(`/sysdict/tree/find.json`, params);

国际化:

英文:

{

  "filtres": {

    "search":"Search",

    "addUser": "Add Account",

    "uid":"User ID",

    "commonName":"User name",

    "status":"Account Status",

    "roles":"Role",

    "fkOuIdName":"Institution Name",

    "fkOuId":"Institution Code",

    "lockStatus": "Lock/Unlock",

    "lock": "Lock",

    "unlock": "Unlock",

    "operator":"Operator",

    "edit":"Edit",

    "usersDel":"Log off users",

    "operateRecord": "Operate Record",

    "confirmPwd": "Confirm Password",

    "password":"Password",

    "save":"Save",

    "cancel":"Cancel",

    "selectRole": "please select",

    "rec": "Record"

  },

  "record": {

    "operat":"Operator",

    "type":"Operate Type",

    "time":"Operate Time"

  },

  "message": {

    "save":"Save",

    "cancel":"Cancel",

    "cannot":"Account ID cannot be empty!",

    "empty":"User name cannot be empty!",

    "rolesNo": "Role type cannot be empty!",

    "fkOuIdName": "Institution Name cann be empty",

    "fkId": "Institution Code cann be empty",

    "passwordCannot":"Password cannot be empty!",

    "saveSuccess":"Save success",

    "updateSuccess":"Update success",

    "deleteSuccess":"Delete success",

    "conDel": "Confirm log off this account ?",

    "selectFail": "This Institution do not allow add User !",

    "tip": "Prompt !",

    "sure": "Sure"

  }

}

中文:

{

  "filtres": {

    "search":"查询",

    "addUser": "新增账户",

    "uid":"用户Id",

    "commonName":"用户名称",

    "status":"账户状态",

    "roles":"角色",

    "fkOuIdName":"机构名称",

    "fkOuId":"机构代码",

    "lockStatus": "锁定/解锁",

    "lock": "锁定",

    "unlock": "解锁",

    "operator":"操作",

    "edit":"编辑",

    "usersDel":"注销用户",

    "operateRecord": "操作记录",

    "confirmPwd": "确认密码",

    "password":"密码",

    "save":"保存",

    "cancel":"取消",

    "selectRole": "请选择",

    "rec": "记录"

  },

  "record": {

    "operat":"操作人",

    "type":"操作类型",

    "time":"操作时间"

  },

  "message": {

    "save":"保存",

    "cancel":"取消",

    "cannot":"账户ID不能为空 !",

    "empty":"用户名不能为空 !",

    "rolesNo": "角色类型不能为空 !",

    "fkOuIdName": "机构名称不能为空 !",

    "fkId": "机构代码不能为空 !",

    "passwordCannot":"密码不能为空 !",

    "saveSuccess":"保存成功",

    "updateSuccess":"更新成功",

    "deleteSuccess":"删除成功",

    "conDel": "确认注销该用户?",

    "selectFail": "此机构不允许添加用户 !",

    "tip": "提示 !",

    "sure": "确定"

  }

}

公共部分国际化

{

  "el": {

    "colorpicker": {

      "confirm": "OK",

      "clear": "Clear"

    },

    "datepicker": {

      "now": "Now",

      "today": "Today",

      "cancel": "Cancel",

      "clear": "Clear",

      "confirm": "OK",

      "exit":"Exit Login",

      "confirmExit":"Confirm exit?",

      "prompted":"Prompted",

      "selectDate": "Select date",

      "selectTime": "Select time",

      "startDate": "Start Date",

      "startTime": "Start Time",

      "endDate": "End Date",

      "endTime": "End Time",

      "prevYear": "Previous Year",

      "nextYear": "Next Year",

      "prevMonth": "Previous Month",

      "nextMonth": "Next Month",

      "year": "",

      "month1": "January",

      "month2": "February",

      "month3": "March",

      "month4": "April",

      "month5": "May",

      "month6": "June",

      "month7": "July",

      "month8": "August",

      "month9": "September",

      "month10": "October",

      "month11": "November",

      "month12": "December",

      "weeks": {

        "sun": "Sun",

        "mon": "Mon",

        "tue": "Tue",

        "wed": "Wed",

        "thu": "Thu",

        "fri": "Fri",

        "sat": "Sat"

      },

      "months": {

        "jan": "Jan",

        "feb": "Feb",

        "mar": "Mar",

        "apr": "Apr",

        "may": "May",

        "jun": "Jun",

        "jul": "Jul",

        "aug": "Aug",

        "sep": "Sep",

        "oct": "Oct",

        "nov": "Nov",

        "dec": "Dec"

      }

    },

    "select": {

      "loading": "Loading",

      "noMatch": "No matching data",

      "noData": "No data",

      "placeholder": "Select"

    },

    "cascader": {

      "noMatch": "No matching data",

      "loading": "Loading",

      "placeholder": "Select"

    },

    "pagination": {

      "goto": "Go to",

      "pagesize": "/page",

      "total": "Total {total}",

      "pageClassifier": ""

    },

    "messagebox": {

      "title": "Message",

      "confirm": "OK",

      "cancel": "Cancel",

      "error": "Illegal input"

    },

    "upload": {

      "deleteTip": "press delete to remove",

      "delete": "Delete",

      "preview": "Preview",

      "continue": "Continue"

    },

    "table": {

      "emptyText": "No Data",

      "confirmFilter": "Confirm",

      "resetFilter": "Reset",

      "clearFilter": "All",

      "sumText": "Sum"

    },

    "tree": {

      "emptyText": "No Data"

    },

    "transfer": {

      "noMatch": "No matching data",

      "noData": "No data",

      "titles": ["List 1", "List 2"],

      "filterPlaceholder": "Enter keyword",

      "noCheckedFormat": "{total} items",

      "hasCheckedFormat": "{checked}/{total} checked"

    }

  },

  "menu": {

    "sys":"System configure",

    "org":"Organization Manage",

    "account": "Account Manage",

    "user": "User Manage"

  },

  "utilFilters": {

    "yes": "Yes",

    "no": "No"

  },

  "validate": {

    "checkBoxNum": {

      "emptyBox": "The number of outbound boxes cannot be empty",

      "numlimitBox": "The outbound quantity must be less than the current system inventory",

      "positiveInt": "Please enter a positive integer",

      "boxnumLimit": "The number of outbound boxes must not exceed 50 boxes"

    },

    "checkNum": {

      "digital": "Positive digital is necessary",

      "nzero": "Digital must be greater than 0",

      "limitParLength": "The input length should be 18 ",

      "limitLength": "The input length should be 6 "

    },

    "checkNull": {

      "nempty": "Name is necessary, the length is limited to 1-32"

    },

    "telPhone": {

      "illegal": "Mobile phone number is illegal"

    },

    "validDay": {

      "dayInt": "The number of days sent must be an integer",

      "daygthan": "Mail days cannot be negative",

      "dayEmpty": "Mail days cannot be empty"

    },

    "checkPwd": {

      "empty": "The password cannot be empty",

      "LimitType": "Please input 6-18 digital or letter password",

      "twoDiff": "Input twice password is different, please input again"

    }

  },

  "treeTable": {

    "operate": "Operate",

    "edit": "Edit",

    "delete": "Delete",

    "addInstitute": "Add subordinate agencies",

    "commonName": "Institution Name",

    "enName": "Institution English Name",

    "shortName": "Institution Abbreviation",

    "id": "Institution Code",

    "nodeLevel": "Node level",

    "remarks": "Remark",

    "isAdd": "Whether can add administrator",

    "type": "Institution Type",

    "parent": "Parent Code"

  },

  "dict": {

    "groupStatus": {

      "accepted": "Accepted",

      "end": "End"

    },

    "queryStatus": {

      "sucQuery": "Query success",

      "query": "Querying",

      "failQuery":"Query fail"

    },

    "editOpertion": {

      "yedit":"Editable",

      "nedit": "Not Editable"

    },

    "sex": {

      "man": "Man",

      "woman":"Female"

    },

    "isEffect":{

      "effect": "Visible",

      "invalid": "Invisible"

    },

    "isEdit":{

      "yes": "Yes",

      "no": "No"

    },

    "isAdd":{

      "yes": "Yes",

      "no": "No"

    },

    "roleType":{

      "bussineAdmin": "Bussiness administrator",

      "inspectAdmin": "Inspect administrator",

      "sysAdmin": "System administrator"

    },

    "accountType":{

      "normal": "Normal",

      "locked": "Lock",

      "invalid": "Invalid",

      "expired": "Expired",

      "logged": "Logged out"

    }

  }

}

中文:

{

  "el": {

  "colorpicker": {

    "confirm": "确定",

    "clear": "清空"

  },

  "datepicker": {

    "now": "此刻",

    "today": "今天",

    "cancel": "取消",

    "clear": "清空",

    "confirm": "确定",

    "exit":"退出登录",

    "prompted":"提示",

    "confirmExit":"确认退出?",

    "selectDate": "选择日期",

    "selectTime": "选择时间",

    "startDate": "开始日期",

    "startTime": "开始时间",

    "endDate": "结束日期",

    "endTime": "结束时间",

    "prevYear": "前一年",

    "nextYear": "后一年",

    "prevMonth": "上个月",

    "nextMonth": "下个月",

    "year": "年",

    "month1": "1 月",

    "month2": "2 月",

    "month3": "3 月",

    "month4": "4 月",

    "month5": "5 月",

    "month6": "6 月",

    "month7": "7 月",

    "month8": "8 月",

    "month9": "9 月",

    "month10": "10 月",

    "month11": "11 月",

    "month12": "12 月",

    "weeks": {

      "sun": "日",

      "mon": "一",

      "tue": "二",

      "wed": "三",

      "thu": "四",

      "fri": "五",

      "sat": "六"

    },

    "months": {

      "jan": "一月",

      "feb": "二月",

      "mar": "三月",

      "apr": "四月",

      "may": "五月",

      "jun": "六月",

      "jul": "七月",

      "aug": "八月",

      "sep": "九月",

      "oct": "十月",

      "nov": "十一月",

      "dec": "十二月"

    }

  },

  "select": {

    "loading": "加载中",

    "noMatch": "无匹配数据",

    "noData": "无数据",

    "placeholder": "请选择"

  },

  "cascader": {

    "noMatch": "无匹配数据",

    "loading": "加载中",

    "placeholder": "请选择"

  },

  "pagination": {

    "goto": "前往",

    "pagesize": "条/页",

    "total": "共 {total} 条",

    "pageClassifier": "页"

  },

  "messagebox": {

    "title": "提示",

    "confirm": "确定",

    "cancel": "取消",

    "error": "输入的数据不合法!"

  },

  "upload": {

    "deleteTip": "按 delete 键可删除",

    "delete": "删除",

    "preview": "查看图片",

    "continue": "继续上传"

  },

  "table": {

    "emptyText": "暂无数据",

    "confirmFilter": "筛选",

    "resetFilter": "重置",

    "clearFilter": "全部",

    "sumText": "合计"

  },

  "tree": {

    "emptyText": "暂无数据"

  },

  "transfer": {

    "noMatch": "无匹配数据",

    "noData": "无数据",

    "titles": ["列表 1", "列表 2"],

    "filterPlaceholder": "请输入搜索内容",

    "noCheckedFormat": "共 {total} 项",

    "hasCheckedFormat": "已选 {checked}/{total} 项"

  }

},

"menu": {

  "sys":"系统管理",

  "org":"机构管理",

  "account": "账号管理",

  "user": "用户管理"

},

"utilFilters": {

  "yes": "是",

  "no": "否"

},

"validate": {

  "checkBoxNum": {

    "emptyBox": "出库盒数不能为空",

    "numlimitBox": "出库数量不得大于当前系统库存量",

    "positiveInt": "请输入一个正整数",

    "boxnumLimit": "出库盒数不得大于50盒"

  },

  "checkNull": {

    "nempty": "名字不能为空, 请输入1-32位的名称"

  },

  "checkNum": {

    "digital": "请输入一个正整数",

    "nzero": "请输入大于0整数",

    "limitParLength": "请输入一个长度为18位编码 ",

    "limitLength": "请输入一个长度为6位编码 "

  },

  "telPhone": {

    "illegal": "输入手机号不合法"

  },

  "validDay": {

    "dayInt": "寄送天数必须是整数!",

    "daygthan": "寄送天数不能为负数!",

    "dayEmpty": "寄送天数不能为空!"

  },

  "checkAccount": {

    "LimitType": "请输入1-20位数字,字母或者.的账户ID"

  },

  "checkPwd": {

    "empty": "密码不能为空",

    "LimitType": "请输入6-18的数字或者字母的密码",

    "twoDiff": "两次输入密码不一致,请重新输入"

  }

},

"treeTable": {

  "operate": "操作",

  "edit": "编辑",

  "delete": "删除",

  "addInstitute": "添加下级机构",

  "commonName": "机构名称",

  "enName": "机构英文名称",

  "shortName": "机构简称",

  "id": "机构代码",

  "nodeLevel": "节点级别",

  "remarks": "备注",

  "isAdd": "是否可以添加管理员",

  "parentId": "上级机构代码",

  "type": "机构类型"

},

"dict": {

  "groupStatus": {

    "accepted": "已受理",

    "end": "已结束"

  },

  "queryStatus": {

    "sucQuery": "查询成功",

    "query": "查询中",

    "failQuery":"查询失败"

  },

  "editOpertion": {

    "yedit":"可编辑",

    "nedit": "不可编辑"

  },

  "sex": {

    "man": "男",

    "woman":"女"

  },

  "isEffect":{

    "effect": "可见",

    "invalid": "不可见"

  },

  "isEdit":{

    "yes": "是",

    "no": "否"

  },

  "isAdd":{

    "yes": "是",

    "no": "否"

  },

  "roleType":{

    "bussineAdmin": "业务管理员",

    "inspectAdmin": "审核管理员",

    "sysAdmin": "系统管理员"

  },

  "accountType":{

    "normal": "正常",

    "locked": "已锁定",

    "invalid": "无效用户",

    "expired": "过期用户",

    "logged": "已注销"

  }

}

}

路由:

let menus = [

{ // 首页

      path: '/index',

      name: '欢迎页面',

      hidden: true,

      src: 'views/main/index.vue',

      children: [

        { // hello

          path: '/index/hello',

          src: 'views/hello.vue'

          }

      ]

    }, {

    path: '/system',

    name: 'menu.sys',

    iconCls: 'el-icon-my-icon',

    src: 'views/main/index.vue',

    rpath: '/system',

    // onlyPage: true,

    children: [

      {

        path: 'organization',

        name: 'menu.org',

        iconCls: 'el-icon-my-icon',

        rpath: '/organization',

        meta: {i18n: 'system/organization'},

        src: 'views/system/organization.vue'

      },

      {

        path: 'administrator',

        name: 'menu.account',

        iconCls: 'el-icon-my-icon',

        rpath: '/administrator',

        meta: {i18n: 'system/administrator'},

        src: 'views/system/administrator.vue'

      },

      {

        path: 'userManager',

        name: 'menu.user',

        iconCls: 'el-icon-my-icon',

        rpath: '/usermanager',

        meta: {i18n: 'system/userManager'},

        src: 'views/system/userManager.vue'

      }

    ]

  }, { // login

    path: '/login',

    hidden: true,

    src: 'views/login/index.vue'

  }, { // login

  path: '/treeGrid',

  hidden: true,

  src: 'components/TreeGrid.vue'

  }

  ];

export {menus};

最后实现的效果:


修改TreeGrid.vue文件中的机构名称的宽度


注明:此处设计国际化部分需要自己去修改,还有字典和校验部分加入,需要自己去调整。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • 一. Java基础部分.................................................
    wy_sure阅读 3,805评论 0 11
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,028评论 0 2
  • 最近自己好像掉进了"婆婆妈妈"的世界两个妈都在我家,同时演绎着女儿和媳妇的角色。已经快一个星期了,目前大家都相处的...
    绿萝子情阅读 186评论 0 0
  • 之前公司项目中UIWebView,涉及到js 调用oc原生方法.WKWebview项目中没使用,想了解的话,间书中...
    CCloud阅读 3,049评论 0 1