基于浏览器端的console的日志记录组件。支持如下特性:
日志级别设置;
异常提交到服务器;
提交环境信息;
日志Tag过滤器;
<script src="log4web.js"></script><script> log4web.log("houyhea"); log4web.error(new Error("houyhea"));</script>
require.config({ paths: { "log4web": "path/to/log4web", } }); define(["log4web"], function (log4web) { log4ewb.log("houyhea"); log4web.error(new Error("houyhea")); });
对日志组件进行配置。如果不传参数,则返回当前日志组件的配置信息。 配置项主要有:
是否开启调试模式。如果开启调试模式,则可以在console中输入window.log4web进行调试.默认值:0.
日志级别,error(4)、warn(3)、info(2)、log(1)、debug(0),级别越高,输出的日志越少。比如:当前级别如果是warn,则只输出error、warn的日志.默认值:debug; 代码示例
var Level = { "error": 4, "warn": 3, "info": 2, "log": 1, "debug": 0 };
日志tag筛选,正则表达式字符串.使用者可以通过在console控制台通过 log4web.config({tagFilter:”usersmodule”}) 配置值输出”usersmodule”tag的日志。默认值:”“.
log4web.config({tagFilter:"usersmodule"});
当发生异常是是否post到服务器。 此处只有当msg参数是Error对象时,才判断是否有提交到服务器.默认值:0.
是否提交环境数据.默认值:1
异常信息提交的服务器地址.默认值:”/api/exception”。 代码示例:
log4web.config({ debug: 0, level: "debug", tagFilter: "", post: 0, postContextInfo: 1, postUrl: "/api/exception" });
这里单独说一下postData,主要包含如下信息:
browser.浏览器描述信息。返回字符串,格式:” Chrome,39.0.2171.95”,逗号前表示浏览器类型,逗号后表示浏览器版号.
os.操作系统字符串。
flash.返回字符串,格式:”1,15”,逗号分隔,第一个表示是否安装flash,1:是,0:否。15:表示flash版本.
referrer.document.referrer信息.
url.当前页面的url.
resolution.屏幕分辨率信息.返回格式:”1920*1080”,(window.screen对象获取).
name.异常名称。
message.异常message。
stack.异常调用堆栈字符串。
日志消息。可以是字符串或Error对象。
用于过滤器,可为空。 调用示例:
log4web.log("log info.","usersmodule"); log4web.log("log info.");
用于过滤器,可为空。
参见。
兼容IE8+,chrome,firefox。
需要依赖 jquery 库,post数据用到了jquery.post方法。如果不想依赖jquery,可自行修改相关代码。