把前端uniapp里的ccxxx

This commit is contained in:
陆柯 2023-01-19 16:01:58 +08:00
parent ba52b720a0
commit 2d7b927a78

View File

@ -2,40 +2,82 @@ const colors = require('colors')
// HBuilder 内置环境的 console 不支持颜色。为了检查是否支持颜色,可测试 uniCloud 是否存在不存在说明在自己的server环境里或 require('supports-color'),相应的返回不同的 ccXXX 函数。
module.exports = typeof uniCloud === 'undefined' ? {
function pageNow () {
return globalThis.getCurrentPages()[globalThis.getCurrentPages().length - 1]
}
module.exports =
globalThis.uni && globalThis.UniApp // && globalThis.getApp?.()?.constructor?.name === 'Vue' // 是前端 uniapp。
? {
cclog (...args) {
console.log({timeiso: new Date().toJSON()}, ...args)
const pageName = pageNow()?.route || 'VueApp'
console.log('%c ' + JSON.stringify({ time: new Date().toJSON(), page: pageName }), 'color:blue;background:lightgrey', ...args)
},
ccinfo (...args) {
console.info({timeiso: new Date().toJSON()}, ...args)
const pageName = pageNow()?.route || 'VueApp'
console.info('%c ' + JSON.stringify({ time: new Date().toJSON(), page: pageName }), 'color:green;background:lightgrey', ...args)
},
ccerror(...args) { // console.error will appear in pm2's error log
console.error({timeiso: new Date().toJSON()}, ...args)
ccwarn (...args) {
const pageName = pageNow()?.route || 'VueApp'
console.warn('%c ' + JSON.stringify({ time: new Date().toJSON(), page: pageName }), 'color:orange;background:lightgrey', ...args)
},
ccwarn(...args) { // console.warn will appear in pm2's error log
console.warn({timeiso: new Date().toJSON()}, ...args)
ccerror (...args) {
const pageName = pageNow()?.route || 'VueApp'
console.error('%c ' + JSON.stringify({ time: new Date().toJSON(), page: pageName }), 'color:red;background:lightgrey', ...args)
},
ccdebug (...args) {
if ('development'===process.env.NODE_ENV) { // 在server的测试环境下. 注意在 uniCloud 环境下,`process.env.NODE_ENV` 不存在. 如要应用本方法,需要手动设置 `process.env.NODE_ENV`
console.log({timeiso: new Date().toJSON()}, ...args)
if (process.env.NODE_ENV !== 'production') {
const pageName = pageNow()?.route || 'VueApp'
console.debug('%c ' + JSON.stringify({ time: new Date().toJSON(), page: pageName }), 'color:cyan;background:lightgrey', ...args)
}
},
cctitle (...args) {
const pageName = pageNow().route || 'VueApp'
console.debug('%c ' + JSON.stringify({ time: new Date().toJSON(), page: pageName }), 'color:cyan;background:lightgrey', ...args)
},
}
} : {
: typeof uniCloud === 'undefined'
? {
cclog (...args) {
console.log(colors.blue({ timeiso: new Date().toJSON() }), ...args)
},
ccinfo (...args) {
console.info(colors.green({ timeiso: new Date().toJSON() }), ...args)
},
ccerror(...args) { // console.error will appear in pm2's error log
ccerror (...args) {
// console.error will appear in pm2's error log
console.error(colors.red({ timeiso: new Date().toJSON() }), ...args)
},
ccwarn(...args) { // console.warn will appear in pm2's error log
ccwarn (...args) {
// console.warn will appear in pm2's error log
console.warn(colors.yellow({ timeiso: new Date().toJSON() }), ...args)
},
ccdebug (...args) {
if ('development'===process.env.NODE_ENV) { // 在server的测试环境下. 注意在 uniCloud 环境下,`process.env.NODE_ENV` 不存在. 如要应用本方法,需要手动设置 `process.env.NODE_ENV`
if ('development' === process.env.NODE_ENV) {
// 在server的测试环境下. 注意在 uniCloud 环境下,`process.env.NODE_ENV` 不存在. 如要应用本方法,需要手动设置 `process.env.NODE_ENV`
console.log(colors.rainbow({ timeiso: new Date().toJSON() }), ...args)
}
},
}
: {
cclog (...args) {
console.log({ timeiso: new Date().toJSON() }, ...args)
},
ccinfo (...args) {
console.info({ timeiso: new Date().toJSON() }, ...args)
},
ccerror (...args) {
// console.error will appear in pm2's error log
console.error({ timeiso: new Date().toJSON() }, ...args)
},
ccwarn (...args) {
// console.warn will appear in pm2's error log
console.warn({ timeiso: new Date().toJSON() }, ...args)
},
ccdebug (...args) {
if ('development' === process.env.NODE_ENV) {
// 在server的测试环境下. 注意在 uniCloud 环境下,`process.env.NODE_ENV` 不存在. 如要应用本方法,需要手动设置 `process.env.NODE_ENV`
console.log({ timeiso: new Date().toJSON() }, ...args)
}
},
}