今天在項目中遇到一個問題,頁面上的數據突然顯示不出來了,查驗後得知是Json數據出現了問題。使用JSON從後台向前台傳輸數據的時候,當數據本身含有一些特殊字符,會導致JSON數據的解析出錯。如果內容中本身就包含了 "\"" 雙引號、"\r\n" 回車換行這時候,數據的解析就會出現問題。
\r,\n,\r\n的區別
\n是換行,英文是New line,表示使光標到行首 \r是回車,英文是Carriage return,表示使光標下移一格 \r\n表示回車換行
"\r\n"與"</br>"的區別
\r\n是輸出的HTML代碼換行(查看html代碼時,代碼換行了) <br />輸出給浏覽器換行(看網頁效果時,文字換行了)
用戶在Textarea輸入內容時,有時候會輸入雙引號,回車或者換行符,保存時,這些特殊符號也也文本內容一起保存到數據庫裡去了,當獲取這些數據時,Json的解析就會出錯
下面是有問題數據:
{ "employees": [ { "firstName":"Bill" , "lastName":"Gates”" }, { "firstName":"George 回車了" , "lastName":"Bush" }, { "firstName":"Thomas" , "lastName":"Carter" } ] }
不改動數據數據,怎樣才能把數據傳到頁面上去呢。思路是後端把 \r\n(回車)轉成<br/>再,前端再把<br/>轉回 \r\n
C# 代碼:
1 public static string EncodeTextareaChar(string str) 2 { 3 if (str == null) return null; 4 return str.Replace("\"", "\\\"").Replace("\r\n", "<br/>").Replace("\n", "<br/>").Replace("\r", "<br/>"); 5 }
Javascript代碼
1 function encodeTextarea(str) { 2 str = str.replace(/</g, "<").replace(/>/g,">"); 3 var str = str.replace(/<br\/>/g, "\r\n"); 4 return str; 5 }
兩種語言都有 replace() 方法,他們也略微有些區別,
Javascript的 replace 只替換一次,如"abcaebacd"中有兩個c,它只替換第一個,replace("c","s"),結果是"absaebacd"
C#的replace替換全部,replace("c","s"),結果是"absaebasd"
注:Javascript 要想實現全部替換,可以 replace(/c/g,"s"), / /之間是要替換的內容,g為全局標志
為什麼要加這一個呢? str.replace(/</g, "<").replace(/>/g,">"); 因為後端傳過來的 <br/> 變成了 <br/>