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
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
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
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
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学习的一个小结。