亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

奇怪的回車換行問題

 更新時(shí)間:2011年11月23日 19:18:46   作者:  
一直對(duì)回車換行問題沒有怎么注意,只知道,在windows中,回車換行是\r\n (0x0D,0x0A)。
在類unix中,是\n (0x0A)。以為沒有什么大的問題,沒想到,這次開發(fā)一個(gè)小程序,卻讓我對(duì)這個(gè)問題大為頭痛。

首先發(fā)現(xiàn)這個(gè)問題是這樣的:

我的這個(gè)程序采用的是Extjs+php的方式,通過ajax進(jìn)行通訊。其中有個(gè)頁(yè)面,如圖:

兩個(gè)文本框,一個(gè)text,一個(gè)textarea,當(dāng)textarea中含有回車換行的時(shí)候,會(huì)出現(xiàn)腳本錯(cuò)誤。后面發(fā)現(xiàn)是因?yàn)槿绻?wù)器端返回的字符串換行了,會(huì)造成js解析出現(xiàn)錯(cuò)誤,可見js在解析json數(shù)據(jù)時(shí)候的語(yǔ)法還是和在本地定義的字符串變量的語(yǔ)法一致的。一個(gè)字符串不能多行,有回車換行的時(shí)候需要轉(zhuǎn)義符號(hào):\n (\r\n)。
不過這個(gè)并不是我要說(shuō)明的問題,我要說(shuō)明的問題是,當(dāng)我在解決這個(gè)問題的時(shí)候,抓包分析的時(shí)候,發(fā)現(xiàn)一個(gè)有趣的現(xiàn)象,就是發(fā)現(xiàn)瀏覽器發(fā)送到服務(wù)器對(duì)回車換行的編碼不一致。
例如上圖中的字符串在通過extjs中的
復(fù)制代碼 代碼如下:

Ext.Ajax.request({
url:'CatMan.php',
form:this.FORM_NAME,
scope:this,
callback:function(o,s,r){
var retObj=Ext.decode(r.responseText);
if(retObj.success){
alert('保存成功!');
}
}
});

進(jìn)行保存時(shí)候,發(fā)現(xiàn)發(fā)送到服務(wù)器的編碼是這樣的:
catdesc=%E6%9E%97%0A%0A%E5%B0%910A%0A%0Aa%E5%8D%8E
注意其中的紅色標(biāo)記的%0A,這是\n的編碼。\r的編碼竟然不見了。
然后我如果采用form submit直接提交,卻發(fā)現(xiàn)編碼是:
%E6%9E%97%0D%0A%0D%0A%E5%B0%91%0D%0A%0D%0A%0D%0Aa%E5%8D%8E
發(fā)現(xiàn)\r(%0D)的編碼是在的。
(以上為在IE9中測(cè)試結(jié)果。)
難道是ExtJs的問題?
如果分析Extjs的源代碼,找到取form值得地方。如下:
復(fù)制代碼 代碼如下:

serializeForm : function(form) {
debugger
var fElements = form.elements || (document.forms[form] || Ext.getDom(form)).elements,
hasSubmit = false,
encoder = encodeURIComponent,
name,
data = '',
type,
hasValue;
Ext.each(fElements, function(element){
name = element.name;
type = element.type;
if (!element.disabled && name) {
if (/select-(one|multiple)/i.test(type)) {
Ext.each(element.options, function(opt){
if (opt.selected) {
hasValue = opt.hasAttribute ? opt.hasAttribute('value') : opt.getAttributeNode('value').specified;
data += String.format("{0}={1}&", encoder(name), encoder(hasValue ? opt.value : opt.text));
}
});
} else if (!(/file|undefined|reset|button/i.test(type))) {
if (!(/radio|checkbox/i.test(type) && !element.checked) && !(type == 'submit' && hasSubmit)) {
data += encoder(name) + '=' + encoder(element.value) + '&';
hasSubmit = /submit/i.test(type);
}
}
}
});
return data.substr(0, data.length - 1);
},

可以發(fā)現(xiàn)extjs采用的是js中的encodeURIComponent函數(shù)進(jìn)行值的編碼。
難道是encodeURIComponent的問題?
搜索網(wǎng)絡(luò),發(fā)現(xiàn)一篇博文中提到這個(gè)問題,見http://www.yeahxj.com/2011/11/07/enter-code-for-all-browser/ (回車符 \r\n 在各個(gè)瀏覽器中無(wú)恥的表現(xiàn))
于是我在ie6,ie8,ie9中分別進(jìn)行了測(cè)試,發(fā)現(xiàn)果然存在這個(gè)問題。
總結(jié):
這個(gè)問題雖然小,但是在某些場(chǎng)合卻會(huì)讓人和頭痛,這也是搞計(jì)算機(jī)程序設(shè)計(jì)人員的悲哀,大量的不兼容,造成很多程序出現(xiàn)各種各樣奇怪的問題。例如這個(gè)小問題可能造成一個(gè)結(jié)果,例如,我這個(gè)程序,需要在前臺(tái)顯示內(nèi)容的時(shí)候保留回車換行。這種一般有兩種處理方法,一種是采用<pre>標(biāo)簽,但是這個(gè)標(biāo)簽用起來(lái)很不方便的,嘗試發(fā)現(xiàn)格式變化不太好控制。另外一種方法就是將回車換行變?yōu)?lt;br />標(biāo)記。我就是采用的這種方法,剛開始我寫的正規(guī)表達(dá)式是/\r\n/,結(jié)果發(fā)現(xiàn)什么都沒匹配到,后面我就改成/[\r\n]/但是這種造成的問題就是在ie6,7,8中將會(huì)多出一行來(lái)。最后為了統(tǒng)一處理,我改為先替換/\r\n/組合,然后再替換/\n/。問題得到解決。
** 本人原創(chuàng)文章,轉(zhuǎn)摘請(qǐng)保留本段內(nèi)容,萬(wàn)分感謝!
** microdreamsoft(Lin Shaohua):
** 由于本人水平有限,歡迎各位高手指正。

相關(guān)文章

  • POST與GET方法的區(qū)別簡(jiǎn)要分析

    POST與GET方法的區(qū)別簡(jiǎn)要分析

    原理介紹:理論上說(shuō),GET是從服務(wù)器上請(qǐng)求數(shù)據(jù),POST是發(fā)送數(shù)據(jù)到服務(wù)器。事實(shí)上,GET方法是把數(shù)據(jù)參數(shù)隊(duì)列(query string)加到一個(gè)URL上,值和表單是一一對(duì)應(yīng)的。
    2008-10-10
  • 數(shù)據(jù)類型和Json格式分析小結(jié)

    數(shù)據(jù)類型和Json格式分析小結(jié)

    數(shù)據(jù)類型和Json格式,需要的朋友可以參考下。
    2009-10-10
  • Windows系統(tǒng)下安裝GIt及GIT基本認(rèn)識(shí)和配置

    Windows系統(tǒng)下安裝GIt及GIT基本認(rèn)識(shí)和配置

    這篇文章主要介紹了Windows系統(tǒng)下安裝GIt及GIT基本認(rèn)識(shí)和配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Git commit --amend 修改提交信息操作

    Git commit --amend 修改提交信息操作

    這篇文章主要介紹了Git commit --amend 修改提交信息操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2020-09-09
  • 為Jenkins添加SSH全局憑證

    為Jenkins添加SSH全局憑證

    這篇文章介紹了為Jenkins添加SSH全局憑證的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-03-03
  • Hash算法示例應(yīng)用場(chǎng)景解延伸探究

    Hash算法示例應(yīng)用場(chǎng)景解延伸探究

    這篇文章主要為大家介紹了Hash算法示例應(yīng)用場(chǎng)景解延伸探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • Wordpress 忘記密碼的處理方法

    Wordpress 忘記密碼的處理方法

    有時(shí)候不小心忘了wordpress的密碼了,大家可以按照下面的方法試試。
    2009-05-05
  • vscode設(shè)置多行展示文件標(biāo)簽的操作方法

    vscode設(shè)置多行展示文件標(biāo)簽的操作方法

    這篇文章主要給大家介紹了vscode設(shè)置多行展示文件標(biāo)簽的操作方法,文中通過圖文結(jié)合的方式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12
  • 對(duì)Web開發(fā)人員有用的8個(gè)網(wǎng)站小結(jié)

    對(duì)Web開發(fā)人員有用的8個(gè)網(wǎng)站小結(jié)

    本文是由比利時(shí)的Web開發(fā)人員Jean-Baptiste Jung分享的,Jung還在《Web開發(fā)/設(shè)計(jì)人員應(yīng)當(dāng)知道的15個(gè)網(wǎng)站》這篇文章中推薦了15個(gè)相關(guān)網(wǎng)站
    2011-05-05
  • 關(guān)于ANSI轉(zhuǎn)義序列解讀

    關(guān)于ANSI轉(zhuǎn)義序列解讀

    這篇文章主要介紹了關(guān)于ANSI轉(zhuǎn)義序列的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08

最新評(píng)論