javascript 模擬實現C# String.format 函數


 前段時間浪費了不少時間解析博客園列表頁和詳情頁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, 不做進一步處理。 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM