前段時間浪費了不少時間解析博客園列表頁和詳情頁html ,用以生成win8客戶端數據源, 感謝園友ThinkWang在《博客園win8客戶端開發記錄2 - 界面初稿》評論中提供的博客園open api 的鏈接信息, 這兩天在做用博客園wcf服務替換舊的html解析代碼工作, 盡管博客園open api服務開放的功能有限並且數據不是很統一 , 但還是大大的減少了代碼量和解析異常情況的發生, 比如有的人加了自定義的樣式, 代碼, 有的博客用了自定義url,不是自己親自使用測試, 很多問題還真難發覺,這也導致代碼判斷條件特別多, 如果不加注釋和說明, 過兩天再回頭看那些代碼, 頭都會隱隱作痛 。。
博客園open api 服務鏈接格式都是如: http://wcf.open.cnblogs.com/blog/sitehome/paged/{PAGEINDEX}/{PAGESIZE} 或 http://wcf.open.cnblogs.com/blog/sitehome/recent/{ITEMCOUNT}的格式, 這樣將這些url傳給dataprovider處理, dataprovider得內部維護當前頁索引和每頁的數目,最后通過xmlHttpRequest 或 backgroundTransfer得到xml數據, 所以每次建立dataprovider都是以http://wcf.open.cnblogs.com/blog/sitehome/paged/{0}/{1} 的格式初始化,這時每次http請求時就需要將{0}替換為pageindex,{1}替換為pagesize , 在.net c#中有非常簡單易用的string.Format 靜態函數可以做到:
string.Format("http://wcf.open.cnblogs.com/blog/sitehome/paged/{0}/{1}", pageIndex, pageSize);
因為string.format這個功能用到的地方比較多, 所以就用js實現了一個簡單的版本 :
String.format = function () { var formatStr = arguments[0]; if ( typeof formatStr === 'string' ) { var pattern, length = arguments.length; for ( var i = 1; i < length; i++ ) { pattern = new RegExp( '\\{' + ( i - 1 ) + '\\}', 'g' ); formatStr = formatStr.replace( pattern, arguments[i] ); } } else { formatStr = ''; } return formatStr; };
以上代碼給javascript String類加了一個靜態方法 format, 然后其用法就和c#的 string.format一模一樣了, 測試如下:
String.format('http://wcf.open.cnblogs.com/blog/sitehome/paged/{0}/{1}',1,20)
輸出: "http://wcf.open.cnblogs.com/blog/sitehome/paged/1/20"
String.format('{0}+{0}+{1}={2}',1,2,1+1+2)
輸出: "1+1+2=4"
String.format({name:'leonwang'},'hello,world')
輸出: ""
如果第一個參數不是string類型, 就簡單返回空string, 不做進一步處理。