Skip to content

Misc其它

概述

工具函数

jsonStringify

将对象obj转换为JSON字符串

javascript
Misc.jsonStringify(obj)
参数类型描述
objObject需要序列化的对象

返回值

类型 String obj序列化为JSON字符串,如果obj为null返回值为null

示例

javascript
Misc.jsonStringify('123456'); //"123456"
Misc.jsonStringify([1, 2, 3, 4, 5, 6]); //[1,2,3,4,5,6]
Misc.jsonStringify({ "a": 1, "b": 2 }); //{"a":1,"b":2}
Misc.jsonStringify(date); //1667232000000
Misc.jsonStringify(true); //true
Misc.jsonStringify(null); //null

jsonParse

将字符串str转换为JSON对象

javascript
Misc.jsonParse(str)
参数类型描述
strString需要转换为对象的字符串

返回值

类型 Object 转换后的对象,如果str为null或者不是正确的JSON结构,会抛出异常

示例

javascript
Misc.jsonParse('"123456"'); //123456
Misc.jsonParse('[1,2,3,4,5,6]'); //[1,2,3,4,5,6]
Misc.jsonParse('{"a":1,"b":2}'); //{a:1,b:2}
Misc.jsonParse(1667232000000); //1667232000000
Misc.jsonParse('"2022-12-03T15:31:10.844Z"'); //Sat Dec 03 23:31:10 CST 2022
Misc.jsonParse(true); //true
Misc.jsonParse(null); //null

parseFloat

将字符串str转换为小数

javascript
Misc.parseFloat(str)
参数类型描述
strString需要转换的字符串

返回值

类型 Double 转换后的小数,如果str为null或者不是正确的数字格式会抛出异常

示例

javascript
Misc.parseFloat(1); //1.0
Misc.parseFloat(2.0); //2.0
Misc.parseFloat('2'); //2.0
Misc.parseFloat('a'); //null
Misc.parseFloat(true); //null
Misc.parseFloat(null); //null

parseInt

将字符串str转换为整数

javascript
Misc.parseInt(str)
参数类型描述
strString需要转换的字符串

返回值

类型 Integer 转换后的整数,如果str为null或者不是正确的数字格式会抛出异常

示例

javascript
Misc.parseInt(1); //1
Misc.parseInt(2.0); //2
Misc.parseInt('2'); //2
Misc.parseInt('3.1415'); //3
Misc.parseInt('03.1415'); //3
Misc.parseInt('a'); //null
Misc.parseInt(true); //null
Misc.parseInt(null); //null

timestampToDate

距离UNIX时间戳数字值转换为日期类型

javascript
Misc.timestampToDate(timestamp)
参数类型描述
timestampIntegerUNIX时间戳

返回值

类型 Date 转换后的日期,如果timestamp为null返回null

示例

javascript
Misc.timestampToDate(1667232000000); //Tue Nov 01 00:00:00 CST 2022
Misc.timestampToDate('1667232000000'); //Tue Nov 01 00:00:00 CST 2022
Misc.timestampToDate('3.1415'); //null
Misc.timestampToDate('a'); //null
Misc.timestampToDate(null); //null

dateToTimestamp

日期类型转换为距离UNIX时间戳数字值

javascript
Misc.dateToTimestamp(date)
参数类型描述
dateDate日期

返回值

类型 Integer 转换后的UNIX时间戳,如果date为null返回null

示例

javascript
Misc.dateToTimestamp(new Date()); //1667232000000
Misc.timestampToDate(null); //null

formatDate

将变量date按照格式fmt(yyyy-MM-dd HH:mm:ss,SSS)转换为字符串

javascript
Misc.formatDate(date, fmt)
参数类型描述
dateDate要转换的日期
fmtString转换格式

返回值

类型 String 转换后的字符串,如果str为null或者str不是给定的日期格式返回null

示例

javascript
//假设date的值是 2022-11-01 13:01:01,000, 时间戳 timestamp 为 1667278861000
Misc.formatDate(date, 'yyyy-MM'); //2022-11
Misc.formatDate(date, 'yyyy-MM-dd'); //2022-11-01
Misc.formatDate(date, 'yyyy'); //2022
Misc.formatDate(date, 'HH:mm:ss,SSS'); //13:01:01,000
Misc.formatDate(date, 'abc'); //null
Misc.formatDate(timestamp, 'yyyy-MM'); //2022-11
Misc.formatDate(timestamp, 'yyyy-MM-dd'); //2022-11-01
Misc.formatDate(timestamp, 'yyyy'); //2022
Misc.formatDate(timestamp, 'HH:mm:ss,SSS'); //13:01:01,000
Misc.formatDate(timestamp, 'abc'); //null
Misc.formatDate(null, 'yyyy-MM-dd'); //null
Misc.formatDate(date, null); //null
Misc.formatDate(timestamp, null); //null
Misc.formatDate(null, null); //null

parseDate

将str按照格式fmt(yyyy-MM-dd HH:mm:ss,SSS)转换为日期

javascript
Misc.parseDate(str, fmt)
参数类型描述
strString要转换的日期字符串
fmtString转换格式

返回值

类型 Date 转换后的日期,如果str为null或者str不是给定的日期格式返回null

示例

javascript
Misc.parseDate('2022-11-01 13:01:01,000', 'yyyy-MM'); //Tue Nov 01 00:00:00 CST 2022
Misc.parseDate('2022-11-01 13:01:01,000', 'yyyy-MM-dd'); //Tue Nov 01 00:00:00 CST 2022
Misc.parseDate('2022-11-01 13:01:01,000', 'yyyy'); //Sat Jan 01 00:00:00 CST 2022
Misc.parseDate('2022-11-01 13:01:01,000', 'HH:mm:ss,SSS'); //null
Misc.parseDate('2022-11-01 13:01:01,000', 'abc'); //null
Misc.parseDate(null, 'yyyy-MM-dd'); //null
Misc.parseDate('2022-11-01 13:01:01,000', null); //null
Misc.parseDate(null, null); //null

host

返回系统的首页地址

javascript
Misc.host()

返回值

类型 String 系统的首页地址

示例

javascript
Misc.host() // https://next.informat.cn/

pinyin

返回字符串 str 的中文拼音

javascript
Misc.pinyin(str)
参数类型描述
strString要转换为拼音的字符串

返回值

类型 String 转换后的拼音,如果str为null则返回null

示例

javascript
Misc.pinyin('你好织信'); //ni hao zhi xin
Misc.pinyin('Hellow 织信'); //H e l l o w   zhi xin
Misc.pinyin(null); //null

shortPinyin

返回字符串 str 的每个中文汉字拼音的首字母

javascript
Misc.shortPinyin(str)
参数类型描述
strString要转换为拼音的字符串

返回值

类型 String 转换后的拼音首字母,如果str为null则返回null

示例

javascript
Misc.shortPinyin('你好织信'); //nhzx
Misc.shortPinyin('Hellow 织信'); //Hellow zx
Misc.shortPinyin(null); //null

expectNotNull

判定对象是否为空,为空则抛出提示为 message 的异常,否则返回对象

javascript
Misc.expectNotNull(obj, message)
参数类型描述
objObject要判断的对象
messageString如果obj为空,异常的提示信息

返回值

类型 Object 传入的对象

示例

javascript
Misc.expectNotNull(null, '消息') //会抛出异常
Misc.expectNotNull('obj', '消息') //返回 'obj'

expectFirst

返回array第一个元素。如果array为空,则抛出提示为 message 的异常

javascript
Misc.expectFirst(array, message)
参数类型描述
arrayArray数组
messageString如果array为null或者长度为0,异常的提示信息

返回值

类型 Object array的第一个元素

示例

javascript
Misc.expectFirst(null, '消息') //会抛出异常
Misc.expectFirst([], '消息') //会抛出异常
Misc.expectFirst(['1', '2'], '消息') //返回1

expectLast

返回array最后一个元素。如果array为空,则抛出提示为 message 的异常

javascript
Misc.expectLast(array, message)
参数类型描述
arrayArray数组
messageString如果array为null或者长度为0,异常的提示信息

返回值

类型 Object array的最后一个元素

示例

javascript
Misc.expectLast(null, '消息') //会抛出异常
Misc.expectLast([], '消息') //会抛出异常
Misc.expectLast(['1', '2'], '消息') //返回2

invokeScript

调用脚本中的函数

脚本中的函数必须使用export语法导出。如果脚本或者脚本中的函数不存在则抛出异常

javascript
Misc.invokeScript(script, func, ...args)
参数类型描述
scriptString脚本的路径
funcString函数名
args...Object参数列表

返回值

类型 Object 脚本函数的返回值,如果函数没有返回值则为null

示例

脚本test.js

javascript
export function add(a, b) {
    return a + b;
}
javascript
Misc.invokeScript('test.js', 'add1') //会抛出异常
Misc.invokeScript('test.js', 'add', 1, 2) //3

invokeAutomatic

调用自动化程序

如果自动化程序不存在则抛出异常

javascript
Misc.invokeAutomatic(automaticId, ...args)
参数类型描述
automaticIdString自动化程序的标识符
args...Object参数列表

返回值

类型 Object 自动化程序的返回值,如果自动化程序没有返回值则为null

示例

javascript
Misc.invokeAutomatic('testAutomatic', 1, 2) //3

httpGet

通过GET方式访问url地址,返回请求的内容

如果url地址不正确会抛出异常,如果http请求的response code不是200也会抛出异常

javascript
Misc.httpGet(url)
参数类型描述
urlStringurl地址

返回值

类型 String http请求的返回的body内容

示例

javascript
Misc.httpGet('https://next.informat.cn/web0/api/i1mwqy35y88hl/helloworld') //hello world!

prop

取出对象 object 中的属性 key 的值

如果对象为Map类型则返回键为key的那一项,如果为对象类型则返回其中的key属性。如果object为null则返回null

javascript
Misc.prop(object, key)
参数类型描述
objectObject要返回属性的对象
keyString要返回属性的名称,如果key为空时会抛出异常

返回值

类型 Object object中key属性的值

示例 假设 对象 object的结构如下

javascript
Misc.prop({ 'a': '1', 'b': 2 }, 'a'); //1
Misc.prop({ 'a': '1', 'b': 2 }, 'c'); //null
Misc.prop({ 'a': '1', 'b': 2 }, null); //null
Misc.prop(null, 'c'); //null
Misc.prop(null, null); //null

appId

获取所在应用的ID

javascript
Misc.appId()

返回值

类型 String 所在应用的ID

getAppIdByKey

通过应用标识符查询团队下的应用ID

javascript
Misc.getAppIdByKey(key)
参数类型描述
keyString应用标识符

返回值

类型 String 应用ID

attachmentURL

获取附件访问的链接地址

通过附件字段的数据表标识符、字段标识符、值获取访问链接地址

javascript
Misc.attachmentURL(tableKey, fieldKey, value)
参数类型描述
tableKeyString数据表ID
fieldKeyString字段ID
valueStringTableAttachment中的id属性

返回值 类型 String 附件的访问地址

示例

javascript
Misc.attachmentURL('staff', 'photo', '1af34d8a031d4faeaef40a989585caa5.png')
//https://next.informat.cn/web0/file/fieldkey/psl4wawpyued1/staff/photo/1af34d8a031d4faeaef40a989585caa5.png

appResURL

获取应用资源库的资源地址

通过传入资源库资源ID获取访问链接地址

javascript
Misc.appResURL(appResId)
参数类型描述
appResIdString资源ID

返回值 类型 String 资源库的资源访问地址

示例

javascript
Misc.appResURL('cjkhd8819chd8dhs.jpg')
//https://next.informat.cn/web0/main/app_res/icxt9rsd1f0ai/demoApp/cjkhd8819chd8dhs.jpg

websiteResURL

获取应用网站模块的资源地址

通过传入网站模块ID和资源路径获取访问链接地址

javascript
Misc.websiteResURL(moduleKey,filePath)
参数类型描述
moduleKeyString网站模块ID
filePathString文件路径

返回值 类型 String 返回网站模块的资源地址

示例

javascript
Misc.websiteResURL('websiteModule', 'logo.png');
//https://next.informat.cn/web0/website/od6km3qte7vdb/j8j56sgtoj8b7/logo.png
Misc.websiteResURL('websiteModule', './logo.png');
//https://next.informat.cn/web0/website/od6km3qte7vdb/j8j56sgtoj8b7/./logo.png

barcodeURL

返回表示条码图片的BASE64值

javascript
Misc.barcodeURL(value, format)
参数类型描述
valueString条码的值,只能包含数字
formatString条码格式,可选值为 CODE39 CODE128 CODE128A CODE128B CODE128C ISBN EAN13 EAN8 EAN5 EAN2 UPC ITF ITF14 MSI MSI11 MSI1010 MSI1110 pharmacode codabar

返回值 类型 String 条码图片的BASE64值

示例

javascript
Misc.barcodeURL('12345', 'CODE39');
// 

qrcodeURL

返回表示条码图片的BASE64值

javascript
Misc.qrcodeURL(value, format)
参数类型描述
valueString二维码内容
widthInterger生成的二维码大小

返回值 类型 String 二维码图片的BASE64值

示例

javascript
Misc.qrcodeURL('12345', 300)
// 

eval

使用上下文 context 变量执行表达式引擎替换表达式字符串 str 模板中的数据

javascript
Misc.eval(str, context)
参数类型描述
strString表达式字符串
contextObject上下文变量

返回值 类型 Object 模板表达式执行后的值

示例

javascript
Misc.eval(null,null) // null
Misc.eval('${true}',null)// true
Misc.eval('${true}',{}) // true
Misc.eval('name',{"name":"informat"}) // 'name'
Misc.eval('${name}',{"name":"informat"}) // 'informat'
Misc.eval('${detail.age}',{"name":"informat","detail":{"age":12}}) // 12
Misc.eval('${detail.sex}',{"name":"informat","detail":{"age":12}}) // null
Misc.eval(null,{"name":"informat"})//null

safesql

为带有占位符?sql生成安全的完整sql

javascript
Misc.safesql(sql, params);
参数类型描述
sqlString带有占位符?sql
paramsArray<Object>参数,按占位符的顺序与数组序号一一对应进行替换

返回值

类型 String 安全的sql

示例

javascript
Misc.safesql(`update tab set age=?,name=? where id=?`, [18, "李四", `'张' or 1=1`]) 
// update tab set age=18,name='李四' where id='''张'' or 1=1'

uuid16

生成一个16位的uuid字符串

javascript
Misc.uuid16();

返回值

类型 String

示例

javascript
Misc.uuid16()//lqjfw3xaglp38tru
Misc.uuid16()//xnqdnq24zubdrk1y

uuid32

生成一个32位的uuid字符串

javascript
Misc.uuid32();

返回值

类型 String

例子:

javascript
Misc.uuid32()//rigzv6usysisu2gmkash6hdg526y10b5
Misc.uuid32()//h7b1gde1bz402kwhgoq383hfl6k2p77m

newObject

构建一个空对象

javascript
Misc.newObject();

返回值

类型 Object

示例

javascript
Misc.newObject()//{}

recordSql

执行SQL查询数据表记录列表,只运行执行Select语句,并且只支持查询数据表模块的记录

javascript
Misc.recordSql(sql, parameters)
参数类型描述
sqlStringSQL语句
parametersArray<Object>参数列表

返回值

类型 Array<Object> 查询的结果集

示例