这些天做了一个WebControl,Control支持复杂的交互,有很多的参数通过调用 __doPostBack(id, eventArgument)来和控件交互。doPostBack的用法是,id: 服务器控件的ClientID,eventArgument: 传回服务器的参数。这个参数在服务器端通过IPostBackDataHandler.LoadPostData(string postDataKey, NameValueCollection postCollection)来读取,本来事情就这么简单,可是后来由于eventArgument里是任意的数据,就出现了$、:、#、%等字符情况,这就把我开始用“:”来分隔的eventArguemnt里的多过个参数搞faint了
。
于是我就想,把字符串编码一下的了,把分隔符转掉就行了呗,可是后来发现有些数据需要在Client端由JavaScript去读取处理,然后再PostBack,这样就要在服务器端实现JavaScript的escape和unescape两个函数,真是麻烦。后来想,反正就是为了组合和切分字符串嘛,干脆把字符串线性排好,记下每个字串的length。分解的时候使用length来分解出每个字符子串,这样就再也不用care字符串的内容了,也比编码的效率高些。这个方法的原理和数据压缩里的行程码有点类似,只是我这里不能压缩而已。
于是我在控件和脚本里分别实现了一个StringHelper类,他们具有相同的方法和方法参数调用:

C# StringHelper Class#region C# StringHelper Class
public class StringHelper


{
public StringHelper()

{
}
// if list = {'a', 'bc', 'def', 'ghij'}; then return "abcdefghijkl$1:2:3:4"
public static string ArrayToString(params string [] list)

{
if ( list.Length <= 0 )

{
return string.Empty;
}
string strLengthLine = String.Empty;
string strStringLine = String.Empty;
for ( int i= 0 ; i < list.Length ; i++ )

{
strLengthLine += ":" + list[i].Length;
strStringLine += list[i];
}
return strStringLine + '$' + strLengthLine.Substring(1);
}
public static string ArrayToString(params object [] list)

{
string [] strList = new string [list.Length];
for ( int i=0 ; i < list.Length ; ++i )

{
if ( list[i] is string )

{
strList[i] = (string)list[i];
}
else

{
strList[i] = Convert.ToString(list[i]);
}
}
return ArrayToString(strList);
}
// if strStringLine = "abcdefghijkl$1:2:3:4" then return {'a', 'bc', 'def', 'ghij'}.
public static string [] StringToArray(string strStringLine)

{
int index = strStringLine.LastIndexOf('$');
if ( index == -1 )

{

return new string []
{strStringLine};
}
string strLengthLine = strStringLine.Substring(index+1);

string [] aryLength = strLengthLine.Split(new char []
{':'});
string [] list = new string [aryLength.Length];
int start = 0;
for ( int i=0 ; i < list.Length ; ++i )

{
int length = int.Parse(aryLength[i]);
list[i] = strStringLine.Substring(start, length);
start += length;
}
return list;
}
}
#endregion

JavaScript StringHelper Class#region JavaScript StringHelper Class
StringHelper = function() {}
StringHelper.ArrayToString = function()
{
if ( arguments.length == 0 )
{
throw 'Must have parameters for call me.';
}
var strLengthLine = '';
var strStringLine = '';
for ( var i=0 ; i < arguments.length ; i++ )
{
var str = '' + arguments[i];
strLengthLine += ':' + str.length;
strStringLine += str;
}
return strStringLine + '$' + strLengthLine.substring(1);
};
StringHelper.StringToArray = function(strStringLine)
{
var index = strStringLine.lastIndexOf('$');
if ( index == -1 )
{
return [strStringLine];
}
var strLengthLine = strStringLine.substring(index+1);
var aryLength = strLengthLine.split(':');
var list = new Array(aryLength.length);
var start = 0;
for ( var i=0 ; i < list.length ; ++i )
{
var length = parseInt(aryLength[i]);
list[i] = strStringLine.substr(start, length);
start += length;
}
return list;
};
#endregion
完成了这两个Helper后,我发现还有很多新的用途,有的时候我们需要在ViewState里放上一些多dimension的字符串数组数据的时候,我们也可以用n次(n和数组维度一样)StringHelper.ArrayToString来serialize数据。当然我们也可以序列化对象放到ViewState里,单纯的string的substring操作,效率上比binaryformat要高很多吧。特别是对于ViewState字符串本身就200,300K的页面来说,能省点是点吧
。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述