javascript模拟dotNet中的StreamBuild及应用
2007-09-04 15:31
381 查看
javascript做为弱类型的编程语言,并不具备真正的面向对象特性.而在字符串的拼接过程中,每一次+=的操作都伴随着两次对象的初始化和销毁.不仅速度慢,而且效率也不高.通过javascript内置的array对象和prototype属性模拟出StringBuilder类.
//=============================================================================
//class StringBuilder:字符串拼接
//=============================================================================
StringBuilder=function()
{
this.buffer=null;
this.buffer=new Array();
StringBuilder.prototype.Append=function append(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.buffer.push(string);
}
StringBuilder.prototype.AppendLine=function appendLine(string)
{
this.Append(string);
this.buffer.push("/r/n");
}
StringBuilder.prototype.Clear=function clear()
{
if(this.buffer.length>0)
{
this.buffer.splice(0,this.buffer.length);
}
}
StringBuilder.prototype.IsEmpty=function isEmpty()
{
return (this.buffer.length==0);
}
StringBuilder.prototype.ToString=function toString()
{
return this.buffer.join("");
}
}
下面是基于StreamBuilder生成表格的TableBuilder类
//=============================================================================
//class TableBuilder类:生成表格
//=============================================================================
TableBuilder=function(heigth,witdh)
{
this.otable=null;
this.otable=new StringBuilder();
this.otable.Append("<table height="+heigth+" width="+width+">");
TableBuilder.prototype.AppendInnerTD=function appendInnerTD(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append("<td>");
this.otable.Append(string);
this.otable.Append("</td>");
}
TableBuilder.prototype.AppendOutTD=function appendOutTD(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append(string);
}
TableBuilder.prototype.AppendInnerTR=function appendInnerTR(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append("<tr>");
this.otable.Append(string);
this.otable.Append("</tr>");
}
TableBuilder.prototype.AppendOutTR=function appendOutTR(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append(string);
}
TableBuilder.prototype.GetTableHtml()
{
this.otable.Append("</table>");
return this.otable;
}
}
修改后拼接字符串的速度可以提高一个数量级.
//=============================================================================
//class StringBuilder:字符串拼接
//=============================================================================
StringBuilder=function()
{
this.buffer=null;
this.buffer=new Array();
StringBuilder.prototype.Append=function append(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.buffer.push(string);
}
StringBuilder.prototype.AppendLine=function appendLine(string)
{
this.Append(string);
this.buffer.push("/r/n");
}
StringBuilder.prototype.Clear=function clear()
{
if(this.buffer.length>0)
{
this.buffer.splice(0,this.buffer.length);
}
}
StringBuilder.prototype.IsEmpty=function isEmpty()
{
return (this.buffer.length==0);
}
StringBuilder.prototype.ToString=function toString()
{
return this.buffer.join("");
}
}
下面是基于StreamBuilder生成表格的TableBuilder类
//=============================================================================
//class TableBuilder类:生成表格
//=============================================================================
TableBuilder=function(heigth,witdh)
{
this.otable=null;
this.otable=new StringBuilder();
this.otable.Append("<table height="+heigth+" width="+width+">");
TableBuilder.prototype.AppendInnerTD=function appendInnerTD(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append("<td>");
this.otable.Append(string);
this.otable.Append("</td>");
}
TableBuilder.prototype.AppendOutTD=function appendOutTD(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append(string);
}
TableBuilder.prototype.AppendInnerTR=function appendInnerTR(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append("<tr>");
this.otable.Append(string);
this.otable.Append("</tr>");
}
TableBuilder.prototype.AppendOutTR=function appendOutTR(string)
{
if((string==null)||(typeof(string)=='undefined'))
{
return;
}
if((typeof(string)=='string')&&(string.length==0))
{
return;
}
this.otable.Append(string);
}
TableBuilder.prototype.GetTableHtml()
{
this.otable.Append("</table>");
return this.otable;
}
}
修改后拼接字符串的速度可以提高一个数量级.
相关文章推荐
- 手机端轻应用模拟原生的下拉刷新效果(JavaScript)
- Selenium2学习-027-WebUI自动化实战实例-025-JavaScript 在 Selenium 自动化中的应用实例之三(页面滚屏,模拟鼠标拖动滚动条)
- 在JavaScript应用中实现延迟加载的方法
- Javascript模拟继承(赠送.net吐槽一段)
- Javascript 深拷贝与浅拷贝理解与应用
- JavaScript实际应用:简单二级联动菜单实现
- javascript实现-表单正则应用
- JavaScript 事件冒泡应用实例分析
- HTML+css+JavaScript 实例应用 图片旋转切换效果
- javascript --- 原型继承与属性拷贝的综合应用
- CMake的应用(在vision studio2008中去掉 ALL_BUILD 和 ZERO_CHECK)
- JavaScript应用:Iframe自适应其加载的内容高度
- javascript模拟map输出与去除重复项的方法
- 你想的到想不到的 javascript 应用小技巧方法
- JavaScript File API应用——如何设计和实现Ajax文件上传组件
- 模拟JavaScript中alert和confirm
- javascript的hasChildNodes()的应用
- javascript日期星期的实现-项目中小应用
- 在C#中应用javascript创建POP动态信息提示。
- javascript针对DOM的应用