最近比较吐槽,大家都知道,现在web前端相对几年前来说已经变得很重了,各种js框架,各种面对对象,而且项目多了,就会提取公共模块,

这些模块的UI展示都一样,不一样的就是后台逻辑,举个例子吧,我们做企业差旅的时候,通常都有一个成本中心的js公共模块,客户在预定机票

的时候来填写这个成本中心,而这种成本中心分布在online,offline和app等预定端,这样也是方便后期和客户公司进行月结算。

  我们还知道,项目做大了,复杂化了,SOA化了之后,很多问题就来了,就像web中的一个理论,所有前端的数据都是不可信的,那对方团队

的接口数据又何尝不是,以前项目小的时候,不会那么不自信,也只会在Logic error的时候会记录下日志,正常的业务流程一般很少记录,毕竟

info日志看着不美观,而且还会消耗服务器带宽,也还会拖累web的性能,但是项目大了,当你某天在项目中遇到了奇怪的bug时,你靠着残缺不

全的日志,好不容易用肉眼逐行追溯到了接口,但是参数太多,无法准确的还原接口的参数数据,但是你又100%的自信认定肯定就是接口的返回

问题,但是又拿不出完整的报文,这时候你又没法找接口提供方,当时那个无奈呀,多想最好每行都有日志该多好啊,有了教训后,记流程日志的

趋势越来越盛行,最终也酿造了一个年初的大事件,稀里糊涂的说了一大堆,web后端如此,那现在的重前端不也一样要记录日志么?我们知道既

然是公共的js模块,那这个模块肯定自己封装了一些方法,肯定是绝对不可以让第三方程序去操作它自己的文本结点,比如下面这样:

 <!--third  module -->
公司:<input type="text" id="company" value="xxx有限公司" />
员工姓名:<input type="text" id="username" value="张三" />
<!-- --> <script type="text/javascript"> //成本中心
var costCenter = (function () {
var company = (document.getElementById("company") || "") && document.getElementById("company").value;
var username = (document.getElementById("username") || "") && document.getElementById("username").value; var result = {
getInfo: function () {
return { company: company, username: username };
},
validation: function () {
return Boolean(company && username);
}
}; return result; })(); </script>

为了简化操作,第三方UI提供了公司名和员工姓名的UI结点,并且封装了一个costcenter类来提供读取方法,可以看到,我的预定程序只需读

取costCenter.getInfo就好了,也起到了一个封装的作用,但是问题就出现在这里,项目实战中会因为各种原因导致在costcenter中取不到值,

当然也可能是common ui的bug,但是当时你又不能非常确定是否真的取到了值,但是在逻辑上就算取不到值,原则上你也不能阻止订单提交,

所以为了彻底追踪bug,就写了个logCenter单例类来记录日志。通常用js来记录log有这种方法。

<1> ajax

  这种方式很容易想到,但是你使用原生的xmlhttprequest的话,还需要考虑浏览器兼容,但不用原生的话,就要借助于第三方框架,比如

jquery,但是毕竟还是有很多公司是不使用jquery的,所以这个要根据实际的需要来使用了。

     //日志中心
var logCenter = (function () { var result = {
info: function (title, message) {
//ajax操作
$.get("http://xxx.com", { "title": title, "message": message }, function () { }, "post"); }
}; return result; })();

<2>image

   我们的dom中有一个叫做image的对象,所以可以通过动态给它的src赋值来达到请求后台url的目的,同时在url中加上我们需要传递 title和

message信息,这种动态给image.src的方式是不需要考虑浏览器兼容性的问题,非常不错。

     //日志中心
var logCenter = (function () { var result = {
info: function (title, message) {
//ajax操作
$.get("http://xxx.com", { "title": title, "message": message }, function () { }, "post"); }, info_image: function (title, message) {
//image
var img = new Image(); img.src = "http://www.baidu.com?title=" + title + "&message=" + message + "&temp=" + (Math.random() * 100000);
}
}; return result; })();

从上图中我们看到network中已经有了url请求,服务器端就可以querystring下url的参数,然后就可以开开心心的把日志记录下来,供后续我们

彻底的排查js前端中的流程信息,到时候谁都不可以扯皮。

最新文章

  1. 【小计】新人Tostring前忘记Null判断的处理
  2. Shell入门教程:Shell当中的特殊变量
  3. Python中format的用法
  4. CentOS6.5安装openLdap
  5. windows服务创建与管理
  6. String类的使用 Part2
  7. Service Trace Viewer Tool (SvcTraceViewer.exe)
  8. 一个web应用的诞生--数据存储
  9. 蓝桥杯比赛java 练习《立方变自身》
  10. Scala入门系列(十三):类型参数
  11. 第二节:重写(new)、覆写(overwrite)、和重载(overload)
  12. C#设计模式之十九策略模式(Stragety Pattern)【行为型】
  13. Aizu 2170 Marked Ancestor
  14. CF446 (Div. 1)简单题解
  15. (转)NHibernate+MySql常见问题
  16. mysql 触发器介绍
  17. Oracle导入的常见语句
  18. 创建窗口句柄时出错(error creating window handle)
  19. SSIS 组件属性整理
  20. google自定义广告系列

热门文章

  1. 查看SQL Server多实例的版本
  2. 【Java每日一题】20161128
  3. 【Linux_Fedora_应用系列】_5_如何安装XZ Utils 解压缩工具以及利用 xz工具来解压缩.xz文件
  4. 新手编辑c语言的注意事项
  5. ahjesus自定义隐式转换和显示转换
  6. CI框架源码阅读笔记8 控制器Controller.php
  7. java栈和堆区别
  8. python数据类型详解及列表字典集合推导式详解
  9. JavaScript寄生组合式继承分析
  10. WPF的ComboBox 数据模板自定义