您好,欢迎访问一九零五行业门户网

JavaScript日志操作对象实例

现在我们来综合使用一下所学知识,来实现一个javascript日志操作对象的实例,我们需要的是这几个文件:
        mylog.js:主要作用是构建mylogger构造函数、添加行、添加节点、css控制。
        ld.js:主要作用是对脚本和字符串制定规则、构造命名空间和根据id、classname取出对象。
        test.js:主要作用是对窗体添加事件,并测试mylog中部分函数的可用性。
        log.html:用于显示日志对象。
以下是各个文件代码:
test.js
[javascript] view plaincopyprint?//向window对象里面添加一个load事件  
ld.addevent(window,'load',function(){ 
    ld.log.writeraw('this is raw');
ld.log.writeraw('<strong>this is bold!</strong>');
ld.log.header('with a header');
ld.log.write('write source:<strong>this is bold!</strong>');
for(i in document){ 
            ld.log.write(i); 
        } 
}); 
//向window对象里面添加一个load事件
ld.addevent(window,'load',function(){
 ld.log.writeraw('this is raw');
 ld.log.writeraw('<strong>this is bold!</strong>');
 ld.log.header('with a header');
 ld.log.write('write source:<strong>this is bold!</strong>');
for(i in document){
         ld.log.write(i);
  }
});mylog.js[javascript] view plaincopyprint?// javascript document
//mylogger的构造函数  
function mylogger(id){ 
    id=id||iclogwindow;
//日志窗体的引用  
    var logwindow=null; 
    //创建日志窗体  
    var createwindow=function(){ 
            var browserwindowsize = ld.getbrowserwindowsize(); 
            var top=(browserwindowsize.height-200)/2||0; 
            var left=(browserwindowsize.width-200)/2||0;
//使用ul  
            logwindow=document.createelement(ul); 
            //在document下添加一个dom对象ul
//添加id进行标识        
            logwindow.setattribute(id,id);
//对窗体进行css样式控制  
            logwindow.style.position='absolute'; 
            logwindow.style.top=top+'px'; 
            logwindow.style.left=left+'px';
logwindow.style.width='200px'; 
            logwindow.style.height='200px'; 
            logwindow.style.overflow='scroll';
logwindow.style.padding='0'; 
            logwindow.style.margin='0'; 
            logwindow.style.border='1px solid black'; 
            logwindow.style.backgroundcolor='white'; 
            logwindow.style.liststyle='none'; 
            logwindow.style.font='10px/10px verdana, tahoma, sans';
//将窗体添加到页面上面  
            document.body.appendchild(logwindow); 
        }
//向日志窗体中添加一行  
    this.writeraw=function(message){ 
            //如果初始窗体是不存在的,则生成日志窗体  
        if(!logwindow){ 
                createwindow(); 
            } 
//创建li的dom节点  
        var li=document.createelement('li');
//对窗体进行css样式控制
li.style.padding='2px'; 
        li.style.border='0'; 
        li.style.borderbottom='1px dotted black'; 
        li.style.margin='0'; 
        li.style.color='#000';
//      验证message信息  
        if(typeof message == 'undefined'){
//在li里面添加文本节点。  
                li.appendchild(  
                    document.createtextnode('message is undefined')     
                    ); 
            }else if(typeof li.innerhtml!=undefined){ 
        //这是另一种方式的表达  
                    li.innerhtml=message; 
                }else{ 
                        li.appendchild( 
                            document.createtextnode(message)        
                        ); 
                    } 
                logwindow.appendchild(li); 
                return true; 
        }; 

//对象字面量的方式声明特权方法  
//向日志窗体中添加一行,向输入的内容进行简单处理  
mylogger.prototype={
write:function(message){ 
        if(typeof message=='string' && message.length==0 ){ 
                return this.writeraw('没有输入信息');

        if(typeof message !='string'){ 
                if(message.tostring){ 
                    return this.writeraw(message.tostring()); 
                }else{ 
                    return this.writeraw(typeof message); 
                } 
            } 
//将大于号小于号进行正则转换成html标记  
        message=message.replace(/</g,"<").replace(/>/g,>); 
        return this.writeraw(message); 
    }, 
    header:function(message){ 
        message='<span style="color:white;background-color:black;font-weight:bold;padding:0px 5px;">'+message+'</span>'; 
        return this.writeraw(message); 
        } 
}; 
window['ld']['log'] = new mylogger(); 
// javascript document
//mylogger的构造函数
function mylogger(id){
 id=id||iclogwindow;
 //日志窗体的引用
 var logwindow=null;
 //创建日志窗体
 var createwindow=function(){
         var browserwindowsize = ld.getbrowserwindowsize();
   var top=(browserwindowsize.height-200)/2||0;
   var left=(browserwindowsize.width-200)/2||0;
   //使用ul
   logwindow=document.createelement(ul);
   //在document下添加一个dom对象ul
   //添加id进行标识     
   logwindow.setattribute(id,id);
   //对窗体进行css样式控制
   logwindow.style.position='absolute';
   logwindow.style.top=top+'px';
   logwindow.style.left=left+'px';
logwindow.style.width='200px';
   logwindow.style.height='200px';
   logwindow.style.overflow='scroll';
logwindow.style.padding='0';
   logwindow.style.margin='0';
   logwindow.style.border='1px solid black';
   logwindow.style.backgroundcolor='white';
   logwindow.style.liststyle='none';
   logwindow.style.font='10px/10px verdana, tahoma, sans';
   //将窗体添加到页面上面
   document.body.appendchild(logwindow);
  }
//向日志窗体中添加一行
 this.writeraw=function(message){
         //如果初始窗体是不存在的,则生成日志窗体
  if(!logwindow){
    createwindow();
   }
//创建li的dom节点
  var li=document.createelement('li');
  //对窗体进行css样式控制
li.style.padding='2px';
  li.style.border='0';
  li.style.borderbottom='1px dotted black';
  li.style.margin='0';
  li.style.color='#000';
  //  验证message信息
  if(typeof message == 'undefined'){
          //在li里面添加文本节点。
    li.appendchild(
     document.createtextnode('message is undefined')   
     );
   }else if(typeof li.innerhtml!=undefined){
        //这是另一种方式的表达
     li.innerhtml=message;
    }else{
      li.appendchild(
       document.createtextnode(message)   
      );
     }
    logwindow.appendchild(li);
    return true;
  };
}
//对象字面量的方式声明特权方法
//向日志窗体中添加一行,向输入的内容进行简单处理
mylogger.prototype={
write:function(message){
  if(typeof message=='string' && message.length==0 ){
          return this.writeraw('没有输入信息');
}
  if(typeof message !='string'){
    if(message.tostring){
     return this.writeraw(message.tostring());
    }else{
     return this.writeraw(typeof message);
    }
   }
//将大于号小于号进行正则转换成html标记
  message=message.replace(/</g,"<").replace(/>/g,>);
  return this.writeraw(message);
 },
 header:function(message){
  message='<span style="color:white;background-color:black;font-weight:bold;padding:0px 5px;">'+message+'</span>';
  return this.writeraw(message);
  }
};
window['ld']['log'] = new mylogger();ld.js[javascript] view plaincopyprint?// javascript document  
if(document.all && !document.getelementbyid){ 
    document.getelementbyid=function(id){ 
        return document.all[id]; 
        } 
    }
if(!string.repeat){ 
        string.prototype.repeat=function(l){ 
            return new array(l+1).join(this); 
            } 
    }
if(!string.trim){ 
        string.prototype.trim=function(){ 
                return this.replace(/^\s+|\+$/g,''); 
            }  
    }
(function(){ 
    //构造命名空间  
    window['ld']={} ;
function $(){ 
        var elements=new array(); 
        //arguments当前函数的参数数组。参数  
        for(var i=0;i                var element=arguments[i];
if(typeof element=='string'){ 
                        element=document.getelementbyid(element); 
                    } 
                if(arguments.length==1){ 
                    return element; 
                    } 
                elements.push(element); 
        } 
        return elements; 
    } 
    //注册命名空间  
    window['ld']['$']=$;
function getelementsbyclassname(classname,tag){ 
            parent=parent || document; 
            if(!(parent=$(parent))) return false;
//var alltags=document.getelementsbytagname(tag);  
            //对tag进行过滤,把tag的对象全取出来  
            var alltags=(tag == * && parent.all) ? parent.all : parent.getelementsbytagname(tag); 
            var matchingelements=new array();
classname=classname.replace(/\-/g,\\-); 
            var regex=new  regexp((^|\\s)+classname+ (\\s|$));
var element; 
            for(var i=0;i                    element=alltags[i]; 
                    if(regex.test(element.classname)){ 
                            matchingelements.push(element); 
                        } 
                }
//返回这个数组  
            return matchingelements; 
        } 
        window['ld']['getelementsbyclassname']=getelementsbyclassname;
function bindfunction(ojb,func){ 
                return function(){ 
                        func.apply(obj,arguments); 
                    } 
            }; 
        window['ld']['bindfunction']=bindfunction;
function getbrowserwindowsize(){ 
            var de=document.documentelement; 
            return{ 
                    'width':( 
                        window.innerwidth 
                        || (de && de.clientwidth) 
                        || document.body.clientwidth), 
                    'heigth':( 
                        window.innerheight 
                        || (de && de.clientheight) 
                        || de && document.body.clientheight) 
                } 
        }; 
        //注册本事件  
    window['ld']['getbrowserwindowsize']=getbrowserwindowsize;
function addevent(node,type,listener){ 
            if(!(node=$(node))) return false;
if(node.addeventlistener){ 
                node.addeventlistener(type,listener,false); 
                return true; 
               }else if(node.attachevent){ 
                    node['e'+type+listener]=listener; 
                    node[type+listener]=function(){node['e'+type+listener](window.event);} 
                    node.attachevent('on'+type, node[type+listener]); 
                    return true; 
                   } 
               return false; 
        }; 
        //注册本事件  
    window['ld']['addevent']=addevent;
})(); 
// javascript document
if(document.all && !document.getelementbyid){
 document.getelementbyid=function(id){
  return document.all[id];
  }
 }
if(!string.repeat){
  string.prototype.repeat=function(l){
   return new array(l+1).join(this);
   }
 }
if(!string.trim){
  string.prototype.trim=function(){
    return this.replace(/^\s+|\+$/g,'');
   }
 }
(function(){
 //构造命名空间
 window['ld']={} ;
function $(){
  var elements=new array();
  //arguments当前函数的参数数组。参数
  for(var i=0;i    var element=arguments[i];
if(typeof element=='string'){
      element=document.getelementbyid(element);
     }
    if(arguments.length==1){
     return element;
     }
    elements.push(element);
  }
  return elements;
 }
 //注册命名空间
 window['ld']['$']=$;
function getelementsbyclassname(classname,tag){
   parent=parent || document;
   if(!(parent=$(parent))) return false;
//var alltags=document.getelementsbytagname(tag);
   //对tag进行过滤,把tag的对象全取出来
   var alltags=(tag == * && parent.all) ? parent.all : parent.getelementsbytagname(tag);
   var matchingelements=new array();
classname=classname.replace(/\-/g,\\-);
   var regex=new  regexp((^|\\s)+classname+ (\\s|$));
var element;
   for(var i=0;i     element=alltags[i];
     if(regex.test(element.classname)){
       matchingelements.push(element);
      }
    }
//返回这个数组
   return matchingelements;
  }
  window['ld']['getelementsbyclassname']=getelementsbyclassname;
function bindfunction(ojb,func){
    return function(){
      func.apply(obj,arguments);
     }
   };
  window['ld']['bindfunction']=bindfunction;
function getbrowserwindowsize(){
   var de=document.documentelement;
   return{
     'width':(
      window.innerwidth
      || (de && de.clientwidth)
      || document.body.clientwidth),
     'heigth':(
      window.innerheight
      || (de && de.clientheight)
      || de && document.body.clientheight)
    }
  };
  //注册本事件
 window['ld']['getbrowserwindowsize']=getbrowserwindowsize;
function addevent(node,type,listener){
   if(!(node=$(node))) return false;
if(node.addeventlistener){
       node.addeventlistener(type,listener,false);
    return true;
      }else if(node.attachevent){
        node['e'+type+listener]=listener;
     node[type+listener]=function(){node['e'+type+listener](window.event);}
     node.attachevent('on'+type, node[type+listener]);
     return true;
       }
      return false;
  };
  //注册本事件
 window['ld']['addevent']=addevent;
})();运行结果:
总结
        这个小例子,基本上把以前所学内容,包括基础支持、面向对象、原型、对象字面量、this、作用域链等知识点全部囊括,算是对javascript学习的一个小结。
其它类似信息

推荐信息