用javaScript实现跟C#中类似的StringBuilder的功能
2009-07-29 13:47
543 查看
StringBuilder类
///<summary>
///声明一个相当于C#类StringBuilder
///</summary>
function StringBuilder()
{
this._string=new Array();
}
///<summary>
///声明一个方法,连接字符串
///</summary>
///<param name=str>要连接的字符串</param>
StringBuilder.prototype.append=function(str)
{
this._string.push(str);
}
///<summary>
///声明一个方法,获得字符串
///</summary>
StringBuilder.prototype.toString=function()
{
return this._string.join("");
}
//获取字符数组
StringBuilder.prototype.ToCharArray=function()
{
return this.split("");
}
//获取N个相同的字符串
StringBuilder.prototype.Repeat=function(num)
{
var tmpArr=[];
for(var i=0;i<num;i++) tmpArr.push(this);
return tmpArr.join("");
}
//逆序
StringBuilder.prototype.Reverse=function()
{
return this.split("").reverse().join("");
}
//测试是否是数字
StringBuilder.prototype.IsNumeric=function()
{
var tmpFloat=parseFloat(this);
if(isNaN(tmpFloat)) return false;
var tmpLen=this.length-tmpFloat.toString().length;
return tmpFloat+"0".Repeat(tmpLen)==this;
}
//测试是否是整数
StringBuilder.prototype.IsInt=function()
{
if(this=="NaN") return false;
return this==parseInt(this).toStringBuilder();
}
// 合并多个空白为一个空白
StringBuilder.prototype.resetBlank = function()
{
return this.replace(/s+/g," ");
}
// 除去左边空白
StringBuilder.prototype.LTrim = function()
{
return this.replace(/^s+/g,"");
}
// 除去右边空白
StringBuilder.prototype.RTrim = function()
{
return this.replace(/s+$/g,"");
}
// 除去两边空白
StringBuilder.prototype.trim = function()
{
return this.replace(/(^s+)|(s+$)/g,"");
}
// 保留数字
StringBuilder.prototype.getNum = function()
{
return this.replace(/[^d]/g,"");
}
// 保留字母
StringBuilder.prototype.getEn = function()
{
return this.replace(/[^A-Za-z]/g,"");
}
// 保留中文
StringBuilder.prototype.getCn = function()
{
return this.replace(/[^u4e00-u9fa5uf900-ufa2d]/g,"");
}
// 得到字节长度
StringBuilder.prototype.getRealLength = function()
{
return this.replace(/[^x00-xff]/g,"--").length;
}
// 从左截取指定长度的字串
StringBuilder.prototype.left = function(n)
{
return this.slice(0,n);
}
// 从右截取指定长度的字串
StringBuilder.prototype.right = function(n)
{
return this.slice(this.length-n);
}
// HTML编码
StringBuilder.prototype.HTMLEncode = function()
{
var re = this;
var q1 = [/x26/g,/x3C/g,/x3E/g,/x20/g];
var q2 = ["&","<",">"," "];
for(var i=0;i<q1.length;i++)
re = re.replace(q1[i],q2[i]);
return re;
}
// Unicode转化
StringBuilder.prototype.ascW = function()
{
var strText = "";
for (var i=0; i<this.length; i++) strText += "" + this.charCodeAt(i) + ";";
return strText;
}
接着我们就可以使用了,使用方法"
var strBuilder=new StringBuilder()
strBuilder.app("abc")
strBuilder.app("abc")
strBuilder.toString()
///<summary>
///声明一个相当于C#类StringBuilder
///</summary>
function StringBuilder()
{
this._string=new Array();
}
///<summary>
///声明一个方法,连接字符串
///</summary>
///<param name=str>要连接的字符串</param>
StringBuilder.prototype.append=function(str)
{
this._string.push(str);
}
///<summary>
///声明一个方法,获得字符串
///</summary>
StringBuilder.prototype.toString=function()
{
return this._string.join("");
}
//获取字符数组
StringBuilder.prototype.ToCharArray=function()
{
return this.split("");
}
//获取N个相同的字符串
StringBuilder.prototype.Repeat=function(num)
{
var tmpArr=[];
for(var i=0;i<num;i++) tmpArr.push(this);
return tmpArr.join("");
}
//逆序
StringBuilder.prototype.Reverse=function()
{
return this.split("").reverse().join("");
}
//测试是否是数字
StringBuilder.prototype.IsNumeric=function()
{
var tmpFloat=parseFloat(this);
if(isNaN(tmpFloat)) return false;
var tmpLen=this.length-tmpFloat.toString().length;
return tmpFloat+"0".Repeat(tmpLen)==this;
}
//测试是否是整数
StringBuilder.prototype.IsInt=function()
{
if(this=="NaN") return false;
return this==parseInt(this).toStringBuilder();
}
// 合并多个空白为一个空白
StringBuilder.prototype.resetBlank = function()
{
return this.replace(/s+/g," ");
}
// 除去左边空白
StringBuilder.prototype.LTrim = function()
{
return this.replace(/^s+/g,"");
}
// 除去右边空白
StringBuilder.prototype.RTrim = function()
{
return this.replace(/s+$/g,"");
}
// 除去两边空白
StringBuilder.prototype.trim = function()
{
return this.replace(/(^s+)|(s+$)/g,"");
}
// 保留数字
StringBuilder.prototype.getNum = function()
{
return this.replace(/[^d]/g,"");
}
// 保留字母
StringBuilder.prototype.getEn = function()
{
return this.replace(/[^A-Za-z]/g,"");
}
// 保留中文
StringBuilder.prototype.getCn = function()
{
return this.replace(/[^u4e00-u9fa5uf900-ufa2d]/g,"");
}
// 得到字节长度
StringBuilder.prototype.getRealLength = function()
{
return this.replace(/[^x00-xff]/g,"--").length;
}
// 从左截取指定长度的字串
StringBuilder.prototype.left = function(n)
{
return this.slice(0,n);
}
// 从右截取指定长度的字串
StringBuilder.prototype.right = function(n)
{
return this.slice(this.length-n);
}
// HTML编码
StringBuilder.prototype.HTMLEncode = function()
{
var re = this;
var q1 = [/x26/g,/x3C/g,/x3E/g,/x20/g];
var q2 = ["&","<",">"," "];
for(var i=0;i<q1.length;i++)
re = re.replace(q1[i],q2[i]);
return re;
}
// Unicode转化
StringBuilder.prototype.ascW = function()
{
var strText = "";
for (var i=0; i<this.length; i++) strText += "" + this.charCodeAt(i) + ";";
return strText;
}
接着我们就可以使用了,使用方法"
var strBuilder=new StringBuilder()
strBuilder.app("abc")
strBuilder.app("abc")
strBuilder.toString()
相关文章推荐
- javascript模拟实现类似c#下的hashtable的简单功能
- JavaScript中实现类似StringBuilder的功能
- ASP.NET(C#)AJAX+JAVASCRIPT实现类似QQ,MSN窗口之功能(续)
- 在c#中实现类似c/c++函数指针的功能
- SQL实现类似C#的Split()函数的功能
- JAVA--实现类似C#输入功能的Console类
- HTML+javascript+aspx+c#实现ajax功能
- javascript 实现类似百度联想输入,自动补全功能
- 利用C#动态编译功能实现像Javascript中的Eval的功能来将一段字符串进行数学运算
- 扩展 delphi 泛型 以实现类似lambda功能 , C#中的any count first last 等扩展方法
- 使用javascript ajax C#实现类似百度的搜索框效果
- C# 实现类似SMSS的执行脚本的功能
- C#+AE实现类似IDentify功能及对高亮显示相关接口的总结
- Android实现类似C#ComBox功能用AutoCompleteTextView实现
- JAVA--实现类似C#输入功能的Console类
- JavaScript实现类似Title Alt功能并且可以显示图片。
- C#类似QQ窗体抖动功能的实现
- javascript模拟实现C# String.format函数功能代码
- JavaScript实现类似Title Alt功能并且可以显示图片。