• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            js基礎:Javascript 版本的 Sprintf 字符串格式化函數
            [ 來源:js實例 | 作者:js基礎 | 時間:2008-2-22 | 去論壇]
            ??????????????????????????????????
            -
            -

            /***? sprintf.js -- POSIX sprintf(3) style formatting function for JavaScript**? Copyright (c) 2006-2007 Ralf S. Engelschall <rse@engelschall.com>**? Partly based on Public Domain code by Jan Moesen <http://jan.moesen.nu/>**? Licensed under GPL <http://www.gnu.org/licenses/gpl.txt>****? $LastChangedDate$**? $LastChangedRevision$*//*? make sure the ECMAScript 3.0 Number.toFixed() method is available? */if (typeof Number.prototype.toFixed != "undefined") {??? (function(){??????? /*? see http://www.jibbering.com/faq/#FAQ4_6 for details? */??????? function Stretch(Q, L, c) {??????????? var S = Q??????????? if (c.length > 0)??????????????? while (S.length < L)??????????????????? S = c+S;??????????? return S;??????? }??????? function StrU(X, M, N) { /* X >= 0.0 */??????????? var T, S;??????????? S = new String(Math.round(X * Number("1e"+N)));??????????? if (S.search && S.search(/\D/) != -1)??????????????? return ''+X;??????????? with (new String(Stretch(S, M+N, '0')))??????????????? return substring(0, T=(length-N)) + '.' + substring(T);??????? }??????? function Sign(X) {??????????? return X < 0 ? '-' : '';??????? }??????? function StrS(X, M, N) {??????????? return Sign(X)+StrU(Math.abs(X), M, N);??????? }??????? Number.prototype.toFixed = function (n) { return StrS(this, 1, n) };??? })();}/*? the sprintf() function? */sprintf = function () {??? /*? argument sanity checking? */??? if (!arguments || arguments.length < 1)??????? alert("sprintf:ERROR: not enough arguments");??? /*? initialize processing queue? */??? var argumentnum = 0;??? var done = "", todo = arguments[argumentnum++];??? /*? parse still to be done format string? */??? var m;??? while (m = /^([^%]*)%(\d+$)?([#0 +'-]+)?(\*|\d+)?(\.\*|\.\d+)?([%diouxXfFcs])(.*)$/.exec(todo)) {??????? var pProlog??? = m[1],??????????? pAccess??? = m[2],??????????? pFlags???? = m[3],??????????? pMinLength = m[4],??????????? pPrecision = m[5],??????????? pType????? = m[6],??????????? pEpilog??? = m[7];??????? /*? determine substitution? */??????? var subst;??????? if (pType == '%')??????????? /*? special case: escaped percent character? */??????????? subst = '%';??????? else {??????????? /*? parse padding and justify aspects of flags? */??????????? var padWith = ' ';??????????? var justifyRight = true;??????????? if (pFlags) {??????????????? if (pFlags.indexOf('0') >= 0)??????????????????? padWith = '0';??????????????? if (pFlags.indexOf('-') >= 0) {??????????????????? padWith = ' ';??????????????????? justifyRight = false;??????????????? }??????????? }??????????? else??????????????? pFlags = "";??????????? /*? determine minimum length? */??????????? var minLength = -1;??????????? if (pMinLength) {??????????????? if (pMinLength == "*") {??????????????????? var access = argumentnum++;??????????????????? if (access >= arguments.length)??????????????????????? alert("sprintf:ERROR: not enough arguments");??????????????????? minLength = arguments[access];??????????????? }??????????????? else??????????????????? minLength = parseInt(pMinLength, 10);??????????? }??????????? /*? determine precision? */??????????? var precision = -1;??????????? if (pPrecision) {??????????????? if (pPrecision == ".*") {??????????????????? var access = argumentnum++;??????????????????? if (access >= arguments.length)??????????????????????? alert("sprintf:ERROR: not enough arguments");??????????????????? precision = arguments[access];??????????????? }??????????????? else??????????????????? precision = parseInt(pPrecision.substring(1), 10);??????????? }??????????? /*? determine how to fetch argument? */??????????? var access = argumentnum++;??????????? if (pAccess)??????????????? access = parseInt(pAccess.substring(0, pAccess.length - 1), 10);??????????? if (access >= arguments.length)??????????????? alert("sprintf:ERROR: not enough arguments");??????????? /*? dispatch into expansions according to type? */??????????? var prefix = "";??????????? switch (pType) {??????????????? case 'd':??????????????? case 'i':??????????????????? subst = arguments[access];??????????????????? if (typeof subst != "number")??????????????????????? subst = 0;??????????????????? subst = subst.toString(10);??????????????????? if (pFlags.indexOf('#') >= 0 && subst >= 0)??????????????????????? subst = "+" + subst;??????????????????? if (pFlags.indexOf(' ') >= 0 && subst >= 0)??????????????????????? subst = " " + subst;??????????????????? break;??????????????? case 'o':??????????????????? subst = arguments[access];??????????????????? if (typeof subst != "number")??????????????????????? subst = 0;??????????????????? subst = subst.toString(8);??????????????????? break;??????????????? case 'u':??????????????????? subst = arguments[access];??????????????????? if (typeof subst != "number")??????????????????????? subst = 0;??????????????????? subst = Math.abs(subst);??????????????????? subst = subst.toString(10);??????????????????? break;
            case 'x':
            subst = arguments[access];
            if (typeof subst != "number")
            subst = 0;
            subst = subst.toString(16).toLowerCase();
            if (pFlags.indexOf('#') >= 0)
            prefix = "0x";
            break;
            case 'X':
            subst = arguments[access];
            if (typeof subst != "number")
            subst = 0;
            subst = subst.toString(16).toUpperCase();
            if (pFlags.indexOf('#') >= 0)
            prefix = "0X";
            break;
            case 'f':
            case 'F':
            subst = arguments[access];
            if (typeof subst != "number")
            subst = 0.0;
            subst = 0.0 + subst;
            if (precision > -1) {
            if (subst.toFixed)
            subst = subst.toFixed(precision);
            else {
            subst = (Math.round(subst * Math.pow(10, precision)) / Math.pow(10, precision));
            subst += "0000000000";
            subst = subst.substr(0, subst.indexOf(".")+precision+1);
            }
            }
            subst = '' + subst;
            if (pFlags.indexOf("'") >= 0) {
            var k = 0;
            for (var i = (subst.length - 1) - 3; i >= 0; i -= 3) {
            subst = subst.substring(0, i) + (k == 0 ? "." : ",") + subst.substring(i);
            k = (k + 1) % 2;
            }
            }
            break;
            case 'c':
            subst = arguments[access];
            if (typeof subst != "number")
            subst = 0;
            subst = String.fromCharCode(subst);
            break;
            case 's':
            subst = arguments[access];
            if (precision > -1)
            subst = subst.substr(0, precision);
            if (typeof subst != "string")
            subst = "";
            break;
            }

            /* apply optional padding */
            var padding = minLength - subst.toString().length - prefix.toString().length;
            if (padding > 0) {
            var arrTmp = new Array(padding + 1);
            if (justifyRight)
            subst = arrTmp.join(padWith) + subst;
            else
            subst = subst + arrTmp.join(padWith);
            }

            /* add optional prefix */
            subst = prefix + subst;
            }

            /* update the processing queue */
            done = done + pProlog + subst;
            todo = pEpilog;
            }
            return (done + todo);
            }

            ?

            ?

            久久无码人妻精品一区二区三区| 久久综合日本熟妇| 精品久久久久久久中文字幕| 伊人久久综在合线亚洲2019| 好属妞这里只有精品久久| 99久久婷婷免费国产综合精品| 伊人色综合久久天天人手人婷 | 久久九九久精品国产免费直播| 亚洲精品无码久久不卡| 蜜臀久久99精品久久久久久小说| 久久影视国产亚洲| 久久久久99精品成人片欧美| 久久亚洲国产最新网站| 久久久噜噜噜www成人网| 国产成人精品久久一区二区三区av| 久久久久久久久久久| 亚洲国产成人久久精品99| 成人免费网站久久久| 99久久中文字幕| 激情五月综合综合久久69| 国产精品视频久久久| 伊人久久久AV老熟妇色| 久久99精品久久久久久久不卡| 久久精品国产精品亚洲| 亚洲天堂久久久| 久久久久久亚洲AV无码专区| 伊人色综合久久天天| 久久精品国产91久久综合麻豆自制 | 亚洲精品tv久久久久久久久久| 人妻丰满?V无码久久不卡| 久久国产精品国产自线拍免费| 久久人人爽人人人人片av| 一本久久精品一区二区| 久久久综合香蕉尹人综合网| 久久久久久无码国产精品中文字幕| 久久亚洲精品视频| 亚洲精品综合久久| 日本久久久久亚洲中字幕| 久久久久高潮毛片免费全部播放| 久久精品人人做人人妻人人玩| 2021精品国产综合久久|