jspdd

particle data

View on GitHub

jspdd

基于JSON数据的变更自动产生操作日志,并可自定义日志说明文字。

操作日志精确到 JSON 数据的具体字段.

可记录所有字段的 增/删/改 操作。

install

npm install jspdd --save

importing

import JSPDD from 'jspdd';

example

import JSPDD from 'jspdd'; //导入 jspdd

    //定义测试的原始数据
let srcData = { a: 1 }      
    //定义测试的变更数据
    , newData = { b: 2 }
    ;

let jspdd = new JSPDD( srcData, newData );

//从原始数据和变更数据,生成数据字典
jspdd.descData = JSPDD.generatorDict( JSON.parse( JSON.stringify( srcData ) ), newData );

jspdd.userName   = 'test username';   //设置用户名(可选)
jspdd.userId     = 'test userid';     //设置用户ID(可选) 
jspdd.alldata    = 1;                 //结果是否包含所有数据( 0:仅出现在字典的数据, 1:所有数据 ),默认1

//执行处理操作,并返回处理结果
let result = jspdd.proc();

//打印相关内容到控制台
console.log( 'jspdd:', jspdd );     
console.log( 'result:', result );

API

构造函数 JSPDD( srcData, newData, descData );

srcData: 原始数据

newData: 修改后的数据

descData: 描述数据

alldata: int

输出结果是否包含所有数据, 1 = 包含所有数据, 0 = 只包含字典里的数据

默认值 = 1

userName: String

设置用户名,可选值

userId: String

设置用户ID,可选值

datakey_prefix:String

定义 datakey 的前缀文字

srcData: Object

用于生成数据对比的原始数据

newData: Object

用于生成数据对比的变更数据

descData: Object

用于生成数据说明文字的字典数据

proc(): Object

执行分析处理, 并返回处理结果

{
    "data": [
        ...{
            "label": [...],             //array , 所有字段的文字描述 label
            "datakey": [...],           //array , 所有字段的属性名
            "desc": [...],              //array , 已经由jspdd处理过的数据文字描述
            "val": null,                //*     , 字段新值  , 编辑的时候会有这个值
            "_val": null,               //*     , 字段原始值, 新增,删除,编辑的时值会有这个值
            "indict": 1,                //(0|1) , 字段数据是否出现在字典里
            "action": "delete"          //string, 字段的变更类型, (add = 新增, delete = 删除, edit = 编辑)
        }
    ],
    "alldata": 1,                       //(0|1) , 输出结果是否包含所有数据, 1 = 包含所有数据, 0 = 只包含字典里的数据   
    "userName": "testUser",             //string, 操作数据时的用户名
    "userId": "222",                    //string, 操作数据时的用户ID
    "date": "2018-07-03 17:23:57",      //string, 操作数据时的标准日期时间
    "ts": 1530609837718                 //string, 操作数据时的时间戳
}

debugData(): Object

输出调试数据,用于调试用,通常在执行 jspdd.proc后调用。

{
    DESC: {
        'new'               : this.N
        , 'delete'          : this.D
        , 'edit'            : this.E
        , 'arrayedit'       : this.A
        , 'RESULT_ALL'      : this.RESULT_ALL
        , 'RESULT_INDICT'   : this.RESULT_INDICT
        , 'RESULT_OUTDICT'  : this.RESULT_OUTDICT
    }
    , SRC: {
        srcData             : this.srcData
        , newData           : this.newData
        , descData          : this.descData
        , diffData          : this.diffData
        , map               : this.MAP
        , allmap            : this.ALL_MAP
        , dictData          : this.DICT
    }
    , INFO: {
    }
}

静态方法 JSPDD.generatorDict( sdata = {}, ndata = {}, ddata = {}, datalabelFormat = ‘’ ): Object

从sdata, ndata 生成字典描述数据ddata

sdata: 原始数据

ndata: 修改后的数据

ddata: 描述数据

datalabelFormat: 自定义文本内容的格式

占位符: {path} = 完整路径, {key} = 属性名 

例子:     
    lang( '{path}' )

演示链接:

https://openjavascript.github.io/jspdd-demo/demo/tools-dict-generator-for-method.html

静态属性 JSPDD.TEXT

定义描述文字内容

JSPDD.TEXT = {
    "NEW"                   : "新增"
    , "EDIT"                : "编辑"
    , "DELETE"              : "删除"
    , "NEW_VAL"             : "新值"
    , "OLD_VAL"             : "旧值"
    , "FIELD_DETAIL"        : "字段描述"
    , "DATA_TYPE"           : "数据类型"
    , "DATA_PATH"           : "数据路径"
    , "FIELD"               : "字段"
    , "INDEX"               : "索引"
    , "VAL"                 : "值"

    , "DEFAULT_DICT_TEXT"   : "文字描述 "
};

相关演示

  1. 自动生成字典数据 - 注入自定义方法

    https://openjavascript.github.io/jspdd-demo/demo/tools-dict-generator-for-method.html

  2. 自动生成字典数据

    https://openjavascript.github.io/jspdd-demo/demo/tools-dict-generator.html

  3. 手动设置字典数据

    https://openjavascript.github.io/jspdd-demo/demo/demo-case1.html

  4. 手动设置字典数据 - 添加字段单位(unit) 与 字段枚举值(enum)

    https://openjavascript.github.io/jspdd-demo/demo/demo-unit-enum.html

  5. 手动设置字典数据 - 忽略字段(is_ignore_field)

    https://openjavascript.github.io/jspdd-demo/demo/demo-is-ignore-field.html

  6. 更多演示请查看 jspdd-demo 项目