【聽棠】最經典的實現字元數控制的方案

iDotNetSpace發表於2008-06-10

最經典的實現字元數控制的方案
當我們在ASP.NET開發時,經常會遇到一個頭疼的問題:字元數的控制
 由於資料庫的欄位長度是固定的,因此在進行字元輸入時,最關鍵的就是控制字元的個數不能超過欄位的長度,要不然,一個個異常會讓人瘋掉的。
  對於單行文字框,不管是HTML控制元件還是Web控制元件,我們經常會使用MaxLength來控制,但這種控制無法控制到中文字元,即MaxLength=50的控制,可以輸入50個英文與50箇中文,這樣的話,還是會導致中文字元數的溢位。
  對於多行文字框,那就更慘了,使用MaxLenth根本不起作用的。

下面提供的方案優勢:
  1)最佳的方法是在文字框中輸入時,控制到最大字數,超過時不能進行輸入;

  2)對於粘帖的情況也要能相容,以前網上的方法不能控制到paste的情況;

  3)對於最後的一箇中文字元,寧願捨去也不能多一個字元,比如50的字元數,在第49個時,最後輸入一箇中文,會導致最終字數為51,而這種情況,推薦是不能輸入中文,保證最終的字元數<=50最佳,因為放棄一箇中文字元總比資料庫報錯要好吧。
 4)為了提高開發效率,儘可能的減少程式碼量,此方案不需要為文字框新增任何事件,而是由指令碼塊自己解決,因此只需要把指令碼塊飲包含到頁面中就可以了,這應該是相當方便了吧【聽棠】最經典的實現字元數控制的方案 
 
完善版修改:由於前一個方案中,一些輸入法無法啟用onpress事件,導致對於中文的不支援,現在採用onkeyup事件處理,在處理方式上也進行了修改,原來的onpress事件是進行輸入控制,而onkeyup只能對已經輸入後的字數進行字數判斷,過長的進行截短處理。

  在原方案中,有位朋友指出:資料採用n(type)系統不會報錯,是的,如果採用n(type)的話,是以字元為基礎的,可以不考慮資料庫出錯的可能性,但同樣也存在一個介面顯示的問題,比如介面上的Address值,希望是100個字元,如果不進行中英文字數區分,最多將輸入100箇中文,從而佔200 個位元組空間,導致Adress在顯示時會超過預料的空間,介面搞得不易控制。因此,此方案還是有可取之處的。
具體新方案實現:
 1)將以下的程式碼包含到頁面中:

【聽棠】最經典的實現字元數控制的方案<script language="javascript"> 
【聽棠】最經典的實現字元數控制的方案
<!-- 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案String.prototype.len
=function(){ 
【聽棠】最經典的實現字元數控制的方案
return this.replace(/[^\x00-\xff]/g,"**").length; 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
//Set maxlength for multiline TextBox 
【聽棠】最經典的實現字元數控制的方案
function setMaxLength(object,length) 
【聽棠】最經典的實現字元數控制的方案{
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
var result = true
【聽棠】最經典的實現字元數控制的方案    
var controlid = document.selection.createRange().parentElement().id; 
【聽棠】最經典的實現字元數控制的方案    
var controlValue = document.selection.createRange().text; 
【聽棠】最經典的實現字元數控制的方案    
var tempString=object.value;
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
var tt=""
【聽棠】最經典的實現字元數控制的方案    
for(var i=0;i<length;i++
【聽棠】最經典的實現字元數控制的方案        { 
【聽棠】最經典的實現字元數控制的方案            
if(tt.len()<length) 
【聽棠】最經典的實現字元數控制的方案                tt
=tempString.substr(0,i+1); 
【聽棠】最經典的實現字元數控制的方案            
else 
【聽棠】最經典的實現字元數控制的方案                
break
【聽棠】最經典的實現字元數控制的方案        } 
【聽棠】最經典的實現字元數控制的方案    
if(tt.len()>length)
【聽棠】最經典的實現字元數控制的方案        tt
=tt.substr(0,tt.length-1);
【聽棠】最經典的實現字元數控制的方案    object.value
=tt;
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
//Check maxlength for multiline TextBox when paste 
【聽棠】最經典的實現字元數控制的方案
function limitPaste(object,length) 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案        
var tempLength = 0
【聽棠】最經典的實現字元數控制的方案        
if(document.selection) 
【聽棠】最經典的實現字元數控制的方案        { 
【聽棠】最經典的實現字元數控制的方案            
if(document.selection.createRange().parentElement().id == object.id) 
【聽棠】最經典的實現字元數控制的方案            { 
【聽棠】最經典的實現字元數控制的方案                tempLength 
= document.selection.createRange().text.len(); 
【聽棠】最經典的實現字元數控制的方案            } 
【聽棠】最經典的實現字元數控制的方案        } 
【聽棠】最經典的實現字元數控制的方案        
var tempValue = window.clipboardData.getData("Text"); 
【聽棠】最經典的實現字元數控制的方案        tempLength 
= object.value.len() + tempValue.len() - tempLength; 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案        
if (tempLength > length) 
【聽棠】最經典的實現字元數控制的方案        { 
【聽棠】最經典的實現字元數控制的方案            tempLength 
-= length; 
【聽棠】最經典的實現字元數控制的方案            
var tt=""
【聽棠】最經典的實現字元數控制的方案            
for(var i=0;i<tempValue.len()-tempLength;i++
【聽棠】最經典的實現字元數控制的方案                { 
【聽棠】最經典的實現字元數控制的方案                    
if(tt.len()<(tempValue.len()-tempLength)) 
【聽棠】最經典的實現字元數控制的方案                        tt
=tempValue.substr(0,i+1); 
【聽棠】最經典的實現字元數控制的方案                    
else 
【聽棠】最經典的實現字元數控制的方案                        
break
【聽棠】最經典的實現字元數控制的方案                } 
【聽棠】最經典的實現字元數控制的方案            
if(tt.len()<=0)
【聽棠】最經典的實現字元數控制的方案            {    
【聽棠】最經典的實現字元數控制的方案                window.event.returnValue
=false;
【聽棠】最經典的實現字元數控制的方案                
【聽棠】最經典的實現字元數控制的方案            }
【聽棠】最經典的實現字元數控制的方案            
else
【聽棠】最經典的實現字元數控制的方案            {
【聽棠】最經典的實現字元數控制的方案                tempValue
=tt; 
【聽棠】最經典的實現字元數控制的方案                window.clipboardData.setData(
"Text", tempValue); 
【聽棠】最經典的實現字元數控制的方案                window.event.returnValue 
= true
【聽棠】最經典的實現字元數控制的方案            }
【聽棠】最經典的實現字元數控制的方案        } 
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
function PressLength()
【聽棠】最經典的實現字元數控制的方案{
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
if(event.srcElement.type=="text" || event.srcElement.type=="textarea" )
【聽棠】最經典的實現字元數控制的方案    {
【聽棠】最經典的實現字元數控制的方案        
if(event.srcElement.length!=null)
【聽棠】最經典的實現字元數控制的方案            setMaxLength(event.srcElement,event.srcElement.length);
【聽棠】最經典的實現字元數控制的方案        
【聽棠】最經典的實現字元數控制的方案    }
【聽棠】最經典的實現字元數控制的方案}
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
function LimitLength()
【聽棠】最經典的實現字元數控制的方案{
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案    
if(event.srcElement.type=="text" || event.srcElement.type=="textarea" )
【聽棠】最經典的實現字元數控制的方案    {
【聽棠】最經典的實現字元數控制的方案        
if(event.srcElement.length!=null)
【聽棠】最經典的實現字元數控制的方案            limitPaste(event.srcElement,event.srcElement.length);
【聽棠】最經典的實現字元數控制的方案    }
【聽棠】最經典的實現字元數控制的方案}
【聽棠】最經典的實現字元數控制的方案document.documentElement.attachEvent('onkeyup', PressLength); 
【聽棠】最經典的實現字元數控制的方案document.documentElement.attachEvent('onpaste', LimitLength);
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
//--&gt 
【聽棠】最經典的實現字元數控制的方案
        script>


2)在需要控制的控制元件上新增length="n"(n為要控制的字數)即可,如:
 
【聽棠】最經典的實現字元數控制的方案<INPUT  type="text" length="3">
【聽棠】最經典的實現字元數控制的方案<TEXTAREA length="20"  rows="2" cols="20">TEXTAREA>
【聽棠】最經典的實現字元數控制的方案<asp:TextBox id="TextBox1"  runat="server" length="7">asp:TextBox>
【聽棠】最經典的實現字元數控制的方案<asp:TextBox id="TextBox2" runat="server" TextMode="MultiLine" length="10">asp:TextBox>
上面是HTML控制元件與Web控制元件的例子,只要加一個length就可以了。

最經典的實現字元數控制的方案
當我們在ASP.NET開發時,經常會遇到一個頭疼的問題:字元數的控制
 由於資料庫的欄位長度是固定的,因此在進行字元輸入時,最關鍵的就是控制字元的個數不能超過欄位的長度,要不然,一個個異常會讓人瘋掉的。
  對於單行文字框,不管是HTML控制元件還是Web控制元件,我們經常會使用MaxLength來控制,但這種控制無法控制到中文字元,即MaxLength=50的控制,可以輸入50個英文與50箇中文,這樣的話,還是會導致中文字元數的溢位。
  對於多行文字框,那就更慘了,使用MaxLenth根本不起作用的。

下面提供的方案優勢:
  1)最佳的方法是在文字框中輸入時,控制到最大字數,超過時不能進行輸入;

  2)對於粘帖的情況也要能相容,以前網上的方法不能控制到paste的情況;

  3)對於最後的一箇中文字元,寧願捨去也不能多一個字元,比如50的字元數,在第49個時,最後輸入一箇中文,會導致最終字數為51,而這種情況,推薦是不能輸入中文,保證最終的字元數<=50最佳,因為放棄一箇中文字元總比資料庫報錯要好吧。
 4)為了提高開發效率,儘可能的減少程式碼量,此方案不需要為文字框新增任何事件,而是由指令碼塊自己解決,因此只需要把指令碼塊飲包含到頁面中就可以了,這應該是相當方便了吧【聽棠】最經典的實現字元數控制的方案 
 
完善版修改:由於前一個方案中,一些輸入法無法啟用onpress事件,導致對於中文的不支援,現在採用onkeyup事件處理,在處理方式上也進行了修改,原來的onpress事件是進行輸入控制,而onkeyup只能對已經輸入後的字數進行字數判斷,過長的進行截短處理。

  在原方案中,有位朋友指出:資料採用n(type)系統不會報錯,是的,如果採用n(type)的話,是以字元為基礎的,可以不考慮資料庫出錯的可能性,但同樣也存在一個介面顯示的問題,比如介面上的Address值,希望是100個字元,如果不進行中英文字數區分,最多將輸入100箇中文,從而佔200 個位元組空間,導致Adress在顯示時會超過預料的空間,介面搞得不易控制。因此,此方案還是有可取之處的。
具體新方案實現:
 1)將以下的程式碼包含到頁面中:

【聽棠】最經典的實現字元數控制的方案<script language="javascript"> 
【聽棠】最經典的實現字元數控制的方案
<!-- 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案String.prototype.len
=function(){ 
【聽棠】最經典的實現字元數控制的方案
return this.replace(/[^\x00-\xff]/g,"**").length; 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
//Set maxlength for multiline TextBox 
【聽棠】最經典的實現字元數控制的方案
function setMaxLength(object,length) 
【聽棠】最經典的實現字元數控制的方案{
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
var result = true
【聽棠】最經典的實現字元數控制的方案    
var controlid = document.selection.createRange().parentElement().id; 
【聽棠】最經典的實現字元數控制的方案    
var controlValue = document.selection.createRange().text; 
【聽棠】最經典的實現字元數控制的方案    
var tempString=object.value;
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
var tt=""
【聽棠】最經典的實現字元數控制的方案    
for(var i=0;i<length;i++
【聽棠】最經典的實現字元數控制的方案        { 
【聽棠】最經典的實現字元數控制的方案            
if(tt.len()<length) 
【聽棠】最經典的實現字元數控制的方案                tt
=tempString.substr(0,i+1); 
【聽棠】最經典的實現字元數控制的方案            
else 
【聽棠】最經典的實現字元數控制的方案                
break
【聽棠】最經典的實現字元數控制的方案        } 
【聽棠】最經典的實現字元數控制的方案    
if(tt.len()>length)
【聽棠】最經典的實現字元數控制的方案        tt
=tt.substr(0,tt.length-1);
【聽棠】最經典的實現字元數控制的方案    object.value
=tt;
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
//Check maxlength for multiline TextBox when paste 
【聽棠】最經典的實現字元數控制的方案
function limitPaste(object,length) 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案        
var tempLength = 0
【聽棠】最經典的實現字元數控制的方案        
if(document.selection) 
【聽棠】最經典的實現字元數控制的方案        { 
【聽棠】最經典的實現字元數控制的方案            
if(document.selection.createRange().parentElement().id == object.id) 
【聽棠】最經典的實現字元數控制的方案            { 
【聽棠】最經典的實現字元數控制的方案                tempLength 
= document.selection.createRange().text.len(); 
【聽棠】最經典的實現字元數控制的方案            } 
【聽棠】最經典的實現字元數控制的方案        } 
【聽棠】最經典的實現字元數控制的方案        
var tempValue = window.clipboardData.getData("Text"); 
【聽棠】最經典的實現字元數控制的方案        tempLength 
= object.value.len() + tempValue.len() - tempLength; 
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案        
if (tempLength > length) 
【聽棠】最經典的實現字元數控制的方案        { 
【聽棠】最經典的實現字元數控制的方案            tempLength 
-= length; 
【聽棠】最經典的實現字元數控制的方案            
var tt=""
【聽棠】最經典的實現字元數控制的方案            
for(var i=0;i<tempValue.len()-tempLength;i++
【聽棠】最經典的實現字元數控制的方案                { 
【聽棠】最經典的實現字元數控制的方案                    
if(tt.len()<(tempValue.len()-tempLength)) 
【聽棠】最經典的實現字元數控制的方案                        tt
=tempValue.substr(0,i+1); 
【聽棠】最經典的實現字元數控制的方案                    
else 
【聽棠】最經典的實現字元數控制的方案                        
break
【聽棠】最經典的實現字元數控制的方案                } 
【聽棠】最經典的實現字元數控制的方案            
if(tt.len()<=0)
【聽棠】最經典的實現字元數控制的方案            {    
【聽棠】最經典的實現字元數控制的方案                window.event.returnValue
=false;
【聽棠】最經典的實現字元數控制的方案                
【聽棠】最經典的實現字元數控制的方案            }
【聽棠】最經典的實現字元數控制的方案            
else
【聽棠】最經典的實現字元數控制的方案            {
【聽棠】最經典的實現字元數控制的方案                tempValue
=tt; 
【聽棠】最經典的實現字元數控制的方案                window.clipboardData.setData(
"Text", tempValue); 
【聽棠】最經典的實現字元數控制的方案                window.event.returnValue 
= true
【聽棠】最經典的實現字元數控制的方案            }
【聽棠】最經典的實現字元數控制的方案        } 
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
function PressLength()
【聽棠】最經典的實現字元數控制的方案{
【聽棠】最經典的實現字元數控制的方案    
【聽棠】最經典的實現字元數控制的方案    
if(event.srcElement.type=="text" || event.srcElement.type=="textarea" )
【聽棠】最經典的實現字元數控制的方案    {
【聽棠】最經典的實現字元數控制的方案        
if(event.srcElement.length!=null)
【聽棠】最經典的實現字元數控制的方案            setMaxLength(event.srcElement,event.srcElement.length);
【聽棠】最經典的實現字元數控制的方案        
【聽棠】最經典的實現字元數控制的方案    }
【聽棠】最經典的實現字元數控制的方案}
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
function LimitLength()
【聽棠】最經典的實現字元數控制的方案{
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案    
if(event.srcElement.type=="text" || event.srcElement.type=="textarea" )
【聽棠】最經典的實現字元數控制的方案    {
【聽棠】最經典的實現字元數控制的方案        
if(event.srcElement.length!=null)
【聽棠】最經典的實現字元數控制的方案            limitPaste(event.srcElement,event.srcElement.length);
【聽棠】最經典的實現字元數控制的方案    }
【聽棠】最經典的實現字元數控制的方案}
【聽棠】最經典的實現字元數控制的方案document.documentElement.attachEvent('onkeyup', PressLength); 
【聽棠】最經典的實現字元數控制的方案document.documentElement.attachEvent('onpaste', LimitLength);
【聽棠】最經典的實現字元數控制的方案
【聽棠】最經典的實現字元數控制的方案
//--&gt 
【聽棠】最經典的實現字元數控制的方案
        script>


2)在需要控制的控制元件上新增length="n"(n為要控制的字數)即可,如:
 
【聽棠】最經典的實現字元數控制的方案<INPUT  type="text" length="3">
【聽棠】最經典的實現字元數控制的方案<TEXTAREA length="20"  rows="2" cols="20">TEXTAREA>
【聽棠】最經典的實現字元數控制的方案<asp:TextBox id="TextBox1"  runat="server" length="7">asp:TextBox>
【聽棠】最經典的實現字元數控制的方案<asp:TextBox id="TextBox2" runat="server" TextMode="MultiLine" length="10">asp:TextBox>
上面是HTML控制元件與Web控制元件的例子,只要加一個length就可以了。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-343248/,如需轉載,請註明出處,否則將追究法律責任。

相關文章