本篇文章给大家分享的是有关C#中怎么读取TextBox内容的中文长度,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
当我们通过C# TextBox控件向数据库中添加内容时,有时为了程序的可靠性,往往需要限定TextBox中输入内容的长度,以吻合数据库中定义的长度。TextBox控件本身有个maxlength属性,它可以限制TextBox中输入字符的***长度,所以在只有字符输入的情况下,该属性可以很好的帮助我们达到限制输入长度的目的。
但如果输入包含中文或中英文混合的内容时,该属性就不那么完善了,因为它没有把一个汉字当作两个字符来处理,所以这通常会对一些刚刚接触C# TextBox控件编程的朋友造成些许的小麻烦。为了解决这个问题,我们先来简单分析一下,然后给出一个解决示例,希望能抛砖引玉。
C# TextBox控件中的text是string类型的,该类型是unicode编码,所以我只需获取中文的unicode值范围,然后对string逐个进行分析,如果在中文unicode值范围内就加2,否则就加1。如此,便可以得到TextBox中包含中英文混合内容的实际长度。
注:前128个Unicode字符(16位代码从0x0000到0x007F)就是ASCII字符,接下来的128个Unicode字符(代码从0x0080到0x00FF)是ISO 8859-1对ASCII的扩展。
* 中国、日本和韩国的象形文字(总称为CJK)占用了从0x3000到0x9FFF的代码
* 希腊字母表使用从0x0370到0x03FF的代码
* 斯拉夫语使用从0x0400到0x04FF的代码
* 美国使用从0x0530到0x058F的代码
* 希伯来语使用从0x0590到0x05FF的代码
C# TextBox简单代码实现:
public static int GetTextBoxLength(string textboxTextStr) { int nLength = 0; for (int i = 0; i < textboxTextStr.Length; i++) { if (textboxTextStr[i] >= 0x3000 && textboxTextStr[i] <= 0x9FFF) nLength += 2; else nLength++; } return nLength; }
以上就是C#中怎么读取TextBox内容的中文长度,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。