JavaScript日志操作对象实例
来源:互联网 发布:阿里 西安 云计算 编辑:程序博客网 时间:2024/06/09 14:32
学完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;//使用ULlogWindow=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 Documentif(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等知识,让知识像路一样四通八达,才能“书越读越薄”。现在能做的,就是继续构建我的知识网。
- JavaScript日志操作对象实例
- JavaScript日志操作对象实例
- [js点滴]JavaScript中Image对象操作实例
- JavaScript面向对象实例——创建日志调试对象来代替alert函数进行调试
- javascript 对象 实例
- JavaScript 对象 实例
- javascript对象实例化
- Javascript DOM操作实例
- javascript操作表格对象
- javascript对象的操作
- JavaScript操作选择对象
- JavaScript操作Java对象
- javascript 的对象操作
- javascript操作Date对象
- JavaScript操作java对象
- Javascript 数组对象 操作
- javascript操作Document对象
- javascript操作window对象
- JavaScript中的面向对象
- 我的博客组件被删,博文被多次删除,啥意思
- Android的NDK开发(1)————Android JNI简介与调用流程
- mini2440----keil for AMR之IIC读写EEPROM(AT24C08)
- ListView 中含有Button ,让它Item能接收事件,并且button能够接收事件
- JavaScript日志操作对象实例
- JSON-lib框架,转换JSON、XML不再困难
- Nmap扫描原理与用法
- bind()
- Android的NDK开发(2)——Android NDK编写一个HelloWorld
- C6678共享存储器问题
- Android的NDK开发(3)————JNI数据类型的详解
- 完美数的判断
- HTML 4.0 语 法 教 学