小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

最經(jīng)典的實(shí)現(xiàn)字符數(shù)控制的方案哦!(完善版)

 duduwolf 2005-09-17
最經(jīng)典的實(shí)現(xiàn)字符數(shù)控制的方案
當(dāng)我們在ASP.NET開發(fā)時,經(jīng)常會遇到一個頭疼的問題:字符數(shù)的控制
 由于數(shù)據(jù)庫的字段長度是固定的,因此在進(jìn)行字符輸入時,最關(guān)鍵的就是控制字符的個數(shù)不能超過字段的長度,要不然,一個個異常會讓人瘋掉的。
  對于單行文本框,不管是HTML控件還是Web控件,我們經(jīng)常會使用MaxLength來控制,但這種控制無法控制到中文字符,即MaxLength=50的控制,可以輸入50個英文與50個中文,這樣的話,還是會導(dǎo)致中文字符數(shù)的溢出。
  對于多行文本框,那就更慘了,使用MaxLenth根本不起作用的。

下面提供的方案優(yōu)勢:
  1)最佳的方法是在文本框中輸入時,控制到最大字?jǐn)?shù),超過時不能進(jìn)行輸入;

  2)對于粘帖的情況也要能兼容,以前網(wǎng)上的方法不能控制到paste的情況;

  3)對于最后的一個中文字符,寧愿舍去也不能多一個字符,比如50的字符數(shù),在第49個時,最后輸入一個中文,會導(dǎo)致最終字?jǐn)?shù)為51,而這種情況,推薦是不能輸入中文,保證最終的字符數(shù)<=50最佳,因?yàn)榉艞壱粋€中文字符總比數(shù)據(jù)庫報(bào)錯要好吧。
 4)為了提高開發(fā)效率,盡可能的減少代碼量,此方案不需要為文本框添加任何事件,而是由腳本塊自己解決,因此只需要把腳本塊飲包含到頁面中就可以了,這應(yīng)該是相當(dāng)方便了吧 
 
完善版修改:由于前一個方案中,一些輸入法無法激活onpress事件,導(dǎo)致對于中文的不支持,現(xiàn)在采用onkeyup事件處理,在處理方式上也進(jìn)行了修改,原來的onpress事件是進(jìn)行輸入控制,而onkeyup只能對已經(jīng)輸入后的字?jǐn)?shù)進(jìn)行字?jǐn)?shù)判斷,過長的進(jìn)行截短處理。

  在原方案中,有位朋友指出:數(shù)據(jù)采用n(type)系統(tǒng)不會報(bào)錯,是的,如果采用n(type)的話,是以字符為基礎(chǔ)的,可以不考慮數(shù)據(jù)庫出錯的可能性,但同樣也存在一個界面顯示的問題,比如界面上的Address值,希望是100個字符,如果不進(jìn)行中英文字?jǐn)?shù)區(qū)分,最多將輸入100個中文,從而占200個字節(jié)空間,導(dǎo)致Adress在顯示時會超過預(yù)料的空間,界面搞得不易控制。因此,此方案還是有可取之處的。
具體新方案實(shí)現(xiàn):
 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);

//--> 
        </script>


2)在需要控制的控件上添加length="n"(n為要控制的字?jǐn)?shù))即可,如:
 
<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就可以了。

 好了,大家可以體驗(yàn)一下了哦:http://www.cnblogs.com/Files/tintown/stringLenth3.rar (已經(jīng)修改復(fù)了“沒有l(wèi)ength無法輸入的問題”)

個人建議:1)可以把這個腳本塊放在js文件中,進(jìn)行引用即可
                2)可以把腳本放在BasePage中,這樣每個頁面都可以使用了
               3)可以使用這些腳本塊,開發(fā)專門的服務(wù)器端控件,我沒有時間開發(fā),如果有朋友可以開發(fā)了發(fā)布一下哦!

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多