学完JavaScript,部分小结可参看我以前的博客《JavaScript中的正则表达式》、《JavaScript中的细节》、《自建JavaScript函数库》、《JavaScript中的面向对象》、《JavaScript中的作用域和闭包》、《JavaScript中的继承和原型》。现在我们来综合使用一下所学知识,来实现一个JavaScript日志操作对象的实例,我们需要的是这几个文件:
myLog.js:主要作用是构建myLogger构造函数、添加行、添加节点、css控制。
LD.js:主要作用是对脚本和字符串制定规则、构造命名空间和根据Id、className取出对象。
test.js:主要作用是对窗体添加事件,并测试mylog中部分函数的可用性。
log.html:用于显示日志对象。
以下是各个文件代码:
test.js
//向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 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 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<arguments.length;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<allTags.length;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学习的一个小结。学的越多,越要找到所学内容之间的联系,学习JS,不只是仅仅学习JS,更要联系以前所学的面向对象、C#、CSS等知识,让知识像路一样四通八达,才能“书越读越薄”。现在能做的,就是继续构建我的知识网。