JavaScript日志操作对象实例

来源:互联网 发布:smash it up bgm 编辑:程序博客网 时间:2024/06/10 01:12
        学完JavaScript,部分小结可参看我以前的博客《JavaScript中的正则表达式》、《JavaScript中的细节》、《自建JavaScript函数库》、《JavaScript中的面向对象》、《JavaScript中的作用域和闭包》、《JavaScript中的继承和原型》。现在我们来综合使用一下所学知识,来实现一个JavaScript日志操作对象的实例,我们需要的是这几个文件:

        myLog.js:主要作用是构建myLogger构造函数、添加行、添加节点、css控制。

        LD.js:主要作用是对脚本和字符串制定规则、构造命名空间和根据Id、className取出对象。

        test.js:主要作用是对窗体添加事件,并测试mylog中部分函数的可用性。

        log.html:用于显示日志对象。

以下是各个文件代码:

test.js

[javascript] view plaincopy
  1. //向window对象里面添加一个load事件  
  2. LD.addEvent(window,'load',function(){  
  3.     LD.log.writeRaw('This is raw');  
  4.   
  5.     LD.log.writeRaw('<strong>This is bold!</strong>');  
  6.   
  7.     LD.log.header('With a header');  
  8.   
  9.     LD.log.write('write source:<strong>This is bold!</strong>');  
  10.       
  11.     for(i in document){  
  12.             LD.log.write(i);  
  13.         }  
  14. });  
myLog.js
[javascript] view plaincopy
  1. // JavaScript Document  
  2.   
  3. //myLogger的构造函数  
  4. function myLogger(id){  
  5.     id=id||"ICLogWindow";  
  6.   
  7.     //日志窗体的引用  
  8.     var logWindow=null;  
  9.     //创建日志窗体  
  10.     var createWindow=function(){  
  11.             var browserWindowSize = LD.getBrowserWindowSize();  
  12.             var top=(browserWindowSize.height-200)/2||0;  
  13.             var left=(browserWindowSize.width-200)/2||0;  
  14.   
  15.             //使用UL  
  16.             logWindow=document.createElement("UL");  
  17.             //在document下添加一个dom对象UL  
  18.   
  19.             //添加ID进行标识        
  20.             logWindow.setAttribute("id",id);  
  21.   
  22.             //对窗体进行css样式控制  
  23.             logWindow.style.position='absolute';  
  24.             logWindow.style.top=top+'px';  
  25.             logWindow.style.left=left+'px';  
  26.       
  27.             logWindow.style.width='200px';  
  28.             logWindow.style.height='200px';  
  29.             logWindow.style.overflow='scroll';  
  30.               
  31.             logWindow.style.padding='0';  
  32.             logWindow.style.margin='0';  
  33.             logWindow.style.border='1px solid black';  
  34.             logWindow.style.backgroundColor='white';  
  35.             logWindow.style.listStyle='none';  
  36.             logWindow.style.font='10px/10px Verdana, Tahoma, Sans';  
  37.   
  38.             //将窗体添加到页面上面  
  39.             document.body.appendChild(logWindow);  
  40.         }  
  41.   
  42. //向日志窗体中添加一行  
  43.     this.writeRaw=function(message){  
  44.             //如果初始窗体是不存在的,则生成日志窗体  
  45.         if(!logWindow){  
  46.                 createWindow();  
  47.             }  
  48. //创建li的dom节点  
  49.         var li=document.createElement('LI');  
  50.   
  51.         //对窗体进行css样式控制  
  52.           
  53.         li.style.padding='2px';  
  54.         li.style.border='0';  
  55.         li.style.borderBottom='1px dotted black';  
  56.         li.style.margin='0';  
  57.         li.style.color='#000';  
  58.   
  59.         //      验证message信息  
  60.         if(typeof message == 'undefined'){  
  61.   
  62.                 //在li里面添加文本节点。  
  63.                 li.appendChild(   
  64.                     document.createTextNode('Message is undefined')      
  65.                     );  
  66.             }else if(typeof li.innerHTML!=undefined){  
  67.         //这是另一种方式的表达  
  68.                     li.innerHTML=message;  
  69.                 }else{  
  70.                         li.appendChild(  
  71.                             document.createTextNode(message)         
  72.                         );  
  73.                     }  
  74.                 logWindow.appendChild(li);  
  75.                 return true;  
  76.         };  
  77. }  
  78. //对象字面量的方式声明特权方法  
  79. //向日志窗体中添加一行,向输入的内容进行简单处理  
  80. myLogger.prototype={  
  81.       
  82.     write:function(message){  
  83.         if(typeof message=='string' && message.length==0 ){  
  84.                 return this.writeRaw('没有输入信息');  
  85.               
  86.         }  
  87.         if(typeof message !='string'){  
  88.                 if(message.toString){  
  89.                     return this.writeRaw(message.toString());  
  90.                 }else{  
  91.                     return this.writeRaw(typeof message);  
  92.                 }  
  93.             }  
  94. //将大于号小于号进行正则转换成HTML标记  
  95.         message=message.replace(/</g,"<").replace(/>/g,">");  
  96.         return this.writeRaw(message);  
  97.     },  
  98.     header:function(message){  
  99.         message='<span style="color:white;background-color:black;font-weight:bold;padding:0px 5px;">'+message+'</span>';  
  100.         return this.writeRaw(message);  
  101.         }  
  102. };  
  103. window['LD']['log'] = new myLogger();  
LD.js
[javascript] view plaincopy
  1. // JavaScript Document  
  2. if(document.all && !document.getElementById){  
  3.     document.getElementById=function(id){  
  4.         return document.all[id];  
  5.         }  
  6.     }  
  7.   
  8. if(!String.repeat){  
  9.         String.prototype.repeat=function(l){  
  10.             return new Array(l+1).join(this);  
  11.             }  
  12.     }  
  13.   
  14. if(!String.trim){  
  15.         String.prototype.trim=function(){  
  16.                 return this.replace(/^\s+|\+$/g,'');  
  17.             }   
  18.     }  
  19.   
  20. (function(){  
  21.     //构造命名空间  
  22.     window['LD']={} ;    
  23.       
  24.     function $(){  
  25.         var elements=new Array();  
  26.         //arguments当前函数的参数数组。参数  
  27.         for(var i=0;i<arguments.length;i++){  
  28.                 var element=arguments[i];  
  29.                   
  30.                 if(typeof element=='string'){  
  31.                         element=document.getElementById(element);  
  32.                     }  
  33.                 if(arguments.length==1){  
  34.                     return element;  
  35.                     }  
  36.                 elements.push(element);  
  37.         }  
  38.         return elements;  
  39.     }  
  40.     //注册命名空间  
  41.     window['LD']['$']=$;  
  42.       
  43.     function getElementsByClassName(className,tag){  
  44.             parent=parent || document;  
  45.             if(!(parent=$(parent))) return false;  
  46.               
  47.               
  48.             //var allTags=document.getElementsByTagName(tag);  
  49.             //对tag进行过滤,把tag的对象全取出来  
  50.             var allTags=(tag == "*" && parent.all) ? parent.all : parent.getElementsByTagName(tag);  
  51.             var matchingElements=new Array();  
  52.               
  53.             className=className.replace(/\-/g,"\\-");  
  54.             var regex=new  RegExp("(^|\\s)"+className+ "(\\s|$)");  
  55.               
  56.             var element;  
  57.             for(var i=0;i<allTags.length;i++){  
  58.                     element=allTags[i];  
  59.                     if(regex.test(element.className)){  
  60.                             matchingElements.push(element);  
  61.                         }  
  62.                 }  
  63.                   
  64.                 //返回这个数组  
  65.             return matchingElements;  
  66.         }  
  67.         window['LD']['getElementsByClassName']=getElementsByClassName;  
  68.           
  69.         function bindFunction(ojb,func){  
  70.                 return function(){  
  71.                         func.apply(obj,arguments);  
  72.                     }  
  73.             };  
  74.         window['LD']['bindFunction']=bindFunction;  
  75.           
  76.     function getBrowserWindowSize(){  
  77.             var de=document.documentElement;  
  78.             return{  
  79.                     'width':(  
  80.                         window.innerWidth  
  81.                         || (de && de.clientWidth)  
  82.                         || document.body.clientWidth),  
  83.                     'heigth':(  
  84.                         window.innerHeight  
  85.                         || (de && de.clientHeight)  
  86.                         || de && document.body.clientHeight)  
  87.                 }  
  88.         };  
  89.         //注册本事件  
  90.     window['LD']['getBrowserWindowSize']=getBrowserWindowSize;  
  91.       
  92.       
  93.     function addEvent(node,type,listener){  
  94.             if(!(node=$(node))) return false;  
  95.               
  96.             if(node.addEventListener){  
  97.                 node.addEventListener(type,listener,false);  
  98.                 return true;  
  99.                }else if(node.attachEvent){  
  100.                     node['e'+type+listener]=listener;  
  101.                     node[type+listener]=function(){node['e'+type+listener](window.event);}  
  102.                     node.attachEvent('on'+type, node[type+listener]);  
  103.                     return true;  
  104.                    }  
  105.                return false;  
  106.         };  
  107.         //注册本事件  
  108.     window['LD']['addEvent']=addEvent;  
  109.       
  110. })();  
运行结果:

总结

        这个小例子,基本上把以前所学内容,包括基础支持、面向对象、原型、对象字面量、this、作用域链等知识点全部囊括,算是对JavaScript学习的一个小结。学的越多,越要找到所学内容之间的联系,学习JS,不只是仅仅学习JS,更要联系以前所学的面向对象、C#、CSS等知识,让知识像路一样四通八达,才能“书越读越薄”。现在能做的,就是继续构建我的知识网。