| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136 | /*此函数区域用于常用的通用函数 如位置 大小 计时器等*/Namespace.register("U.M");//#region 通用函数区域/*** 属性添加处理 这里处理例如chrome取消innerText等** @param  {object} 需要添加属性的对象* @param  {string} 类型名字* @param  {function} get函数处理* @param  {function} set函数处理*/U.M.HEPropert = function (UDE, UDN, UGCB, USCB) {    if (UDE.__defineGetter__) {//W3C兼容        UDE.__defineGetter__(UDN, UGCB);        UDE.__defineSetter__(UDN, USCB);    }    else if (Object.defineProperty) {//ie8+        Object.defineProperty(UDE, UDN, { get: UGCB, set: USCB, configurable: true });    }    else { //ie6 7        UDE[UDN] = UGCB; //[^\w]([A-Za-z_][\w]*)\s*\(\s*[\w]+\s*(,\s*[\w]+\s*)*\)        UDE[UDN].toString = UGCB; //获取的时候自动执行用户调用        UDE.attachEvent("onpropertychange", U.M.apply(UDE, [[U.M.HEPropert.OPJL, [UDE, UDN, UGCB, USCB]]]));    }}/*** 上述函数的子函数 用于ie兼容** @param  {object} 需要添加属性的对象* @param  {string} 类型名字* @param  {function} get函数处理k* @param  {function} set函数处理*/U.M.HEPropert.OPJL = function (UDE, UDN, UGCB, USCB) {    if (event.propertyName == UDN) { //判断变化的属性        var _UCB = arguments.caller.caller;        UDE.detachEvent("onpropertychange", _UCB);        USCB(UDE[UDN]);        UDE[UDN] = UGCB;        UDE[UDN].toString = USCB;        UDE.attachEvent("onpropertychange", _UCB); //重新设置    }}/*** 对象添加原型方法,添加新的数据类型,或者在已有数据类型上扩充功能,例如:String,Number,Array,Object,Guid等** @param  {object} 数据类型,例如String,Number等。* @param  {string、 object} 当这个参数为string的时候下述函数有效* @param  {function} string => function 原型对应的函数*/U.M.Setprototype = function (UDE, UAE, UCB) {    if (typeof UAE == "string") {  //大量的添加原型方法        UDE.prototype[UAE] = UCB;    }    else { //单个添加        for (var i in UAE) {            UDE.prototype[i] = UAE[i];        }    }}/*** 获取元素的定位位置** @param  {element} 元素* @return  {array} 返回元素的位置 ----------[0] 元素的top----------[1] 元素的left*/U.M.pageXY = function (UDOD) {    var _UTP,    _UDE = [0, 0]; //需要返回的元素的位置    while (UDOD) {        _UTP = U.M.GetStyle(UDOD, "position"); //元素的position        if (_UTP != "static") {            _UDE[0] += UDOD.offsetTop; //元素的上距            _UDE[1] += UDOD.offsetLeft; //元素的左距        }        UDOD = UDOD.offsetParent;    }    return _UDE; //返回}/*** 获取元素真实大小** @param  {element} 元素* @param  {string} 获取长或者宽的属性---------[width] 长---------[height] 宽* @return  {} 返回元素的位置 ----------[0] 元素的top----------[1] 元素的left*/U.M.GETHW = function (UDOD, UTF) {    var i, //用于循环    _UWH, //用于记录元素的offset属性    _UCS, //用于记录元素的style属性    _UCE = [0, 2], //用于设置循环的范围    _UDE = ["Top", "Bottom", "Right", "Left"], //用于连接字符串 获得offset属性    _UFN = U.M.GetStyle, //获取元素所使用的样式    _UD = _UFN(UDOD, "display"), //获取元素的display属性    _UH = _UFN(UDOD, UTF); //获取元素的UTF(width,height...)属性    (_UD == "none" && _UH.indexOf("px") == -1) && (_UCS = UDOD.style.cssText, UDOD.style.cssText += ";display:block;visibility:hidden;", _UH = null);    if (_UH == null || _UH.indexOf("%") > -1 || isNaN((_UH = Number(_UH.toInt())))) { //百分比和number使用        _UWH = UDOD["offset" + (UTF.charAt(0).toUpperCase() + UTF.substr(1))]; //获取长获取宽        if (UTF == "width") { //            for (i = 0; i < _UCE.length; i++) {                _UCE[i] += i;            }        }        for (i = _UCE[0]; i < _UCE[1]; i++) {            _UWH -= (((_UH = _UFN(UDOD, "padding" + _UDE[i]).toInt()).length ? 0 : _UH) + ((_UH = _UFN(UDOD, "border" + _UDE[i] + "Width").toInt()).length ? 0 : _UH));        };        (_UCS != null) && (UDOD.style.cssText = _UCS);    }    else { //非百分比处理        _UWH = _UH;    }    return _UWH;}/*** 获取元素的位置大小** @param  {element} 元素* @return  {object} 返回元素的位置  函数内有详细的注释*/U.M.GetElementAllInfo = function (UDOD) {    //    UDOD要获取位置的元素        if (UDOD) {        var i, //用于循环        _USE, //存放所有数据的集合        _UVE, //用于获取元素的border属性        _UPE = [], //用于获取元素的padding属性        _UBE = [], //储存变量         _UAE = ["Top", "Right", "Bottom", "Left"], //用于连接字符串 获得offset属性        _UCE = UDOD.getBoundingClientRect(), //返回一个矩形对象        _UDE = U.M.pageXY(UDOD), //获取UDOD的位置        _UDPD = U.M.TOSP(UDOD); //获取元素offsetParent        for (i = 0; i < _UAE.length; i++) {  //筛选 padding 和 border            _UPE[i] = U.M.GetStyle(UDOD, "padding" + _UAE[i]).toInt();            _UBE[i] = (_UVE = U.M.GetStyle(UDOD, "border" + _UAE[i] + "Width").toInt()).length ? 0 : _UVE;        }        _USE = {            PD: _UPE, //元素的padding            BD: _UBE, //元素的border            PXT: (document.documentElement.scrollTop) + _UDPD.scrollTop, //滚动条top位置            PXL: (document.documentElement.scrollLeft) + _UDPD.scrollLeft, //滚动条left位置            SH: UDOD.scrollHeight,  //包含滚动掉的高度            SW: UDOD.scrollWidth, //包含滚动条的长度            SL: UDOD.scrollLeft, //滚动条向左的位置            ST: UDOD.scrollTop, //滚动条向右的位置            CH: UDOD.clientHeight, //页面不包含 border padding宽度            CW: UDOD.clientWidth, //页面不包含 border padding长度            CT: UDOD.clientTop, //页面margin + top的高度            CL: UDOD.clientLeft, //页面margin + left的长度            OH: UDOD.offsetHeight, ///页面包含 border padding宽度            OW: UDOD.offsetWidth,  //页面包含 border padding长度            OL: UDOD.offsetLeft, //页面left的长度             OT: UDOD.offsetTop, //页面top的高度            BCRH: _UCE.bottom - _UCE.top, //元素的显示高度            BCRW: _UCE.right - _UCE.left, //元素的显示长度            BCRT: _UCE.top, //元素的显示top            BCRL: _UCE.left, //元素的显示left            BCRB: _UCE.bottom, //元素的显示bottom            BCRR: _UCE.right, //元素的显示right            TX: _UDE[1], //元素的显示高度            TY: _UDE[0]//元素的显示高度        };        _USE.H = _USE["OH"] - _USE["PD"][1] - _USE["PD"][3] - _USE["BD"][1] - _USE["BD"][3]; //原宽度 不包含所有的border padding margin        _USE.W = _USE["OW"] - _USE["PD"][0] - _USE["PD"][2] - _USE["BD"][0] - _USE["BD"][2]  //原长度 不包含所有的border padding margin        //        U.Ut.AddObj(_USE, {        //            H: _USE["OH"] - _USE["PD"][1] - _USE["PD"][3] - _USE["BD"][1] - _USE["BD"][3], //原宽度 不包含所有的border padding margin        //            W: _USE["OW"] - _USE["PD"][0] - _USE["PD"][2] - _USE["BD"][0] - _USE["BD"][2]  //原长度 不包含所有的border padding margin        //        });        return _USE;    }    return {};}/*** 获取元素的位置大小** @param  {element} 元素* @return  {object} 返回元素的位置  函数内有详细的注释*/U.M.GetElementInfo = function (UDOD) {    var _UCE = UDOD.getBoundingClientRect(); //返回一个矩形对象    return {        SH: UDOD.scrollHeight,  //包含滚动掉的高度        SW: UDOD.scrollWidth, //包含滚动条的长度        SL: UDOD.scrollLeft, //滚动条向左的位置        ST: UDOD.scrollTop, //滚动条向右的位置        CH: UDOD.clientHeight, //页面不包含 border padding宽度        CW: UDOD.clientWidth, //页面不包含 border padding长度        CT: UDOD.clientTop, //页面margin + top的高度        CL: UDOD.clientLeft, //页面margin + left的长度        OH: UDOD.offsetHeight, ///页面包含 border padding宽度        OW: UDOD.offsetWidth,  //页面包含 border padding长度        OL: UDOD.offsetLeft, //页面left的长度         OT: UDOD.offsetTop, //页面top的高度        BCRH: _UCE.bottom - _UCE.top, //元素的显示高度        BCRW: _UCE.right - _UCE.left, //元素的显示长度        BCRT: _UCE.top, //元素的显示top        BCRL: _UCE.left, //元素的显示left        BCRB: _UCE.bottom, //元素的显示bottom        BCRR: _UCE.right //元素的显示right    }}/*** 获取大小位置** @param  {element} 元素* @return  {object} 获取元素的大小 */U.M.GetPDWH = function (UDOD) {    var i, _UST,    _UDTD = $(UDOD),    _UPE = [],    _UBE = [],    _UAE = ["Top", "Right", "Bottom", "Left"];    //获取padding border    for (i = 0; i < _UAE.length; i++) {        _UPE[i] = _UDTD.css("padding" + _UAE[i]).toInt();        _UBE[i] = _UDTD.css("border" + _UAE[i] + "Width").toInt();        (_UBE[i].length) && (_UBE[i] = 0);    }    //获取长宽    _UAE = ["width", "height"];    for (i = 0; i < _UAE.length; i++) {        _UST = _UAE[i]; _UAE[i] = _UDTD[_UST]();    }    //返回大小处理    return {        "PD": _UPE, //padding         "BD": _UBE, //border        "OW": _UAE[0] + _UPE[1] + _UPE[3] + _UBE[1] + _UBE[3], //包含padding border 的长        "OH": _UAE[1] + _UPE[0] + _UPE[2] + _UBE[0] + _UBE[2], //包含padding border 宽        "CW": _UAE[0], //不包含padding border 宽        "CH": _UAE[1]//不包含padding border 宽    };}/*** 获取元素offsetParent 兼容ie8-** @param  {element} 元素* @param  {boolean} 是否从上级开始找起* @param  {string}  规定的position值* @return  {elememt}  offsetParent*/U.M.TOSP = function (UDOD, UTF, UPT) {    var _UTP, _UDBD = document.body;    (!UTF) && (UDOD = UDOD.offsetParent);    while (UDOD && UDOD != _UDBD) {        _UTP = U.M.GetStyle(UDOD, "position");        if ((!UPT && _UTP != "static") || (_UTP == UPT)) {            break;        }        UDOD = UDOD.offsetParent;    }    return UDOD || _UDBD;}/*** 根据ID获取指定的子元素** @param  {element} 父级元素* @param  {string} 传进来的ID* @return  {element} 获取子元素id相等的 */U.M.GetCById = function (UDOD, UDID) {    var i, //用于循环    _UDAD = $(UDOD).Child(); //该UDOD元素的子元素    for (i = 0; i < _UDAD.length; i++) {        if (_UDAD[i].id == UDID) { return _UDAD[i]; }    }}/*** 根据ID获取自定的父亲元素** @param  {element} 当前元素* @param  {string} 父亲的id* @return  {object} 获取元素的大小 */U.M.GTPN = function (UDOD, UTID) {    while (UDOD && !(UDOD == UTID || UDOD.id == UTID)) { //递归寻找父级        UDOD = UDOD.parentNode;    }    return UDOD;}/*** 获取children不为文本** @param  {element} 当前元素* @param  {string} 父亲的id* @return  {array} 获取所有的子节点 */U.M.GTCN = function (UAE, UTP) {    var i, //用于循环    _UDE = []; //用于存放数据且返回    for (i = 0; i < UAE.length; i++) {        if (UAE[i].nodeType == 1 && (!UTP || UTP.indexOf(UAE[i].tagName.toLowerCase()) == -1)) {            _UDE.push(UAE[i])        };    }    return _UDE;}/*** 获取可编辑元素** @param  {element} 当前元素* @param  {string} 父亲的id* @return  {element} 可编辑的元素 */U.M.GetDE = function (UDOD) {    var _UDBD = document.body;    while (UDOD && _UDBD != UDOD) {        if (UDOD.tagName) {            if ("textarea,input".indexOf(UDOD.tagName.toLocaleLowerCase()) > -1 || UDOD.contentEditable == "true") { //可编辑元素                break;            }        }        UDOD = $(UDOD).Parent();    }    return UDOD;}/*** 判断元素是否是制定的子元素** @param  {element} 该元素为父元素* @param  {element} 需要判断的元素* @return  {boolean} 获取元素的大小 */U.M.EISE = function (UDOD, UDTD) {    if (UDOD && UDTD) {        if (UDOD.contains) { //ie chrome 兼容            if (UDOD.contains(UDTD)) {                return true;            }        }        else if (UDOD.compareDocumentPosition) { //firefox            if (!(!!(UDOD.compareDocumentPosition(UDTD)))) {                return true;            }        }    }    return false;}/*** 判断元素的位于第几个** @param  {element} 当前元素* @return  {number} 位置 */U.M.IndexOfParent = function (UDOD) {    var _UDAD = $($(UDOD).Parent()).Child();    return _UDAD.indexOf(UDOD); //判断元素在指定的位置第几个}/*** 判断元素的属性是否是制定属性函数固有属性 true自定义 false固有** @param  {element} 当前元素* @param  {string} 为元素的各属性* @return  {number} 位置 */U.M.Arrt = function (UDOD, UTP) {    UDOD = UDOD || $$("div");    var _UAE = UDOD.attributes; //_UAE 为UDOD的属性集合    if (_UAE) {        if (_UAE[UTP]) { //IE6-7判断是否是自定义属性            return _UAE[UTP].expando == true;        }        else { //是否为自定义属性            return UDOD.getAttribute(UTP) !== null || UDOD[UTP] === void 0;        }    }}/*** 浏览器全屏** @param  {element} 需要全屏的元素,例如视频.* @param  {string}  全屏或者取消全屏,true全屏,false是取消全屏* @return  {number} 成功或者失败。U.M.fullScreen(document,true);U.M.cancelfullScreen(document,false);*/U.M.fullScreen = function () {    var _funcname = U.M.GetFullSreeenName("requestFullScreen"); //全屏函数名    if (_funcname != null)        document[_funcname](); //执行全屏函数}//取消浏览器全屏U.M.cancelfullScreen = function () {    var _funcname = U.M.GetFullSreeenName("cancelFullScreen") || U.M.GetFullSreeenName("exitFullScreen"); //全屏函数名    if (_funcname != null)        document[_funcname](); //执行全屏函数}/*** 获取各个浏览器全屏函数的名称** @return  {string} 全屏功能的函数名 */U.M.GetFullSreeenName = function (funcname) {    var i, _functionname;    //各个浏览器的全屏函数名称是不一样的,用数组把各个全屏函数包装起来。    //注:各个浏览器全屏函数名如数组: _full = ["requestFullscreen", "mozRequestFullScreen", "webkitRequestFullscreen", "msRequestFullscreen", "oRequestFullscreen"];    //各个浏览器还有不同的取消全屏,退出全屏功能"cancelFullScreen","exitFullScreen"     var _full = ["", "webkit", "moz", "ms", "o"]; //所有浏览器的兼容字符串集    for (i = 0; i < _full.length; i++) {        if (_full[i])            _functionname = _full[i] + funcname.capitalizeFirstLetter();        else            _functionname = funcname;        //判断拼接的浏览器兼容函数名在文档中是否存在。存在则返回函数,不存在返回null。        if (_full[i] in document.documentElement || _full[i] in document) {            return _full[i];        }    }    return null;}/*** 添加或者删除自定义属性** @param  {array} 所有的需要变化的元素集 * @param  {string} 全屏功能的函数名 * @param  {boolean} 判断是删除属性还是添加属性 * @param  {array} 二级属性 */U.M.SRAttr = function (UDE, USN, UTV, UCE) {    var i, //用于循环    j, //用于循环    _UAE,    _UTP = UTV != null ? "setAttribute" : "removeAttribute"; //判断是设置还是删除属性    for (i = 0; i < UDE.length; i++) {//        _UAE = UDE[i];        if (_UAE) {            if (UCE && UCE.length) { //训话属性处理                for (j = 0; j < UCE.length; j++) {                    _UAE = _UAE[UCE[j]];                }            }            _UAE[_UTP](USN, UTV); //执行删除获取添加属性        }    }}/*** 修改设置制定样式后获取所有设置的元素** @param  {element} 元素 * @param  {string} 获取的类型 * @param  {string} 是添加还是移除属性 -----------De 移除属性* @param  {object} 设置的属性 * @return  {array} 通过参数2获取的元素 */U.M.SetElement = function (UDE, UTP, URE, UTF) {    if (UDE) {        (typeof (UDE) == "string") && (UDE = $$("div", { "innerHTML": UDE }));        UDE = UDE || document;        var i, //用于循环        _UFT,        _UAE,        _UDOD,        _UMS = "",        _UCE = [];        UTP = (UTP == "*" || !UTP) ? "&*" : UTP; //需要获取的值        if (UTF) {            for (i in UTF) {                UTP += ("[" + i + (UTF[i] ? ("=" + UTF[i]) : "") + "]"); //属性选择            }        }        if ((_UAE = $(UTP, UDE)) && UTF !== false && URE) { //设置            _UCE = _UAE[(_UFT = URE == "De") ? "remove" : "addAttrArray"](_UFT ? null : URE);        }        (URE == "De") && (_UCE = [_UCE.length > 0 ? _UCE : _UAE, UDE]); //如果为删除返回两个值  一个是选中的值 一个是传入的元素集        return _UCE;    }    return [];}/*** 获取元素所使用的样式** @param  {element} 需要获取样式的元素 * @param  {string} 样式的key */U.M.GetStyle = function (UDOD, UVE) {    if (UDOD && UDOD.style) {        UVE = U.M.CssTHH(UVE);        return (UDOD.style[UVE] || UVE == "cssText") ? UDOD.style[UVE] : (UDOD.currentStyle ? UDOD.currentStyle[UVE] || "" : "");    }    return ""; //获取js对应的style值}/*** 添加删除获取class** @param  {array} 进行操作的对象 * @param  {string} 确定循环范围 * @param  {element} 正则表达式 获取字符 * @param  {string} 获取或删除指令* @return  {boolean} 是否存在改样式*/U.M.ARClass = function (UDE, UIE, UCN, UTF) {    var _UCT, //储存对象样式名    _UFT, //储存索引值    _UIF, //储存索引值    i = UIE || 0; //循环初始化    _UL = UIE + 1 || UDE.length, //确定循环范围    _UL = Math.min(_UL, UDE.length);    _UCE = new RegExp("(\\s|^)" + UCN + "(\\s|$)"); //需要索引的值    for (; i < _UL; i++) {        _UCT = UDE[i].className;        _UFT = _UCT.match(_UCE);        if (UTF == "Add") { (!_UFT) && (UDE[i].className += (_UCT ? " " : "") + UCN); } //添加class        else if (UTF == "RE") { //删除class            (_UFT) && (_UIF = _UCT.indexOf(UCN) + UCN.length, UDE[i].className = _UCT.replace(_UCE, (_UIF == _UCT.length || !_UIF) ? "" : " "));        }    }    return _UFT;}/*** style样式转换 如 text-align => textAlign 或者相反的换** @param  {array} 进行操作的对象 * @param  {string} 确定循环范围 */U.M.CssTHH = function (UST, UTF) {    UTF = UTF ? [/[A-Z]/g, "-", 0, "toLowerCase"] : [/-[a-z ]/g, "", 1, "toUpperCase"]; //转换的样式或者属性    return UST.replace(UTF[0], function (UMS) { //利用正则转换        return UTF[1] + UMS.charAt(UTF[2])[UTF[3]]();    });}/*** 获取 rgb颜色值** @param  {array} 进行操作的对象 * @return  {string} 确定循环范围 */U.M.HexBack = function (UCS) {    var i, //循环初始化    _UAE = "#", //rgb颜色前缀    _USE = UCS.match(U.MS.rgb); //索引值    if (_USE) {        for (i = 1; i < _USE.length; i++) {            _UAE += ("0" + _USE[i].toInt().toString(16)).slice(-2); //转换的方式        }        return _UAE;    }    return UCS;}/*** 获取css3过渡属性** @return  {array} 过渡属性的值-----------[0] 过渡的css -----------[1] 过渡的回调函数 -----------[2] 兼容的前缀 -----------[3] 浏览器过渡的监视属性 -----------[4] 浏览器结束的属性 */U.M.GCssAe = function () {    var i, //遍历初始化    _USE = $$("div").style, //获取div的样式    //css兼容的形式    _UDE = {        "WebkitTransition": ["-webkit-transition", "webkitTransitionEnd", "-webkit-", "webkitRequest", "webkitCancel"], //webkit浏览器的兼容        "OTransition": ["-o-transition", "oTransitionEnd", "-o-", "oRequest", "oCancel"], //Op 浏览的兼容        "MozTransition": ["-moz-transition", "transitionend", "-moz-", "mozRequest", "mozCancel"], //火狐浏览器的兼容        "MsTransform": ["-ms-transition", "transitionend", "-ms-"], //ie低版本的兼容        "transition": ["transition", "transitionend", "", "r", "cancel"] //html5的兼容    }    //循环判断获取    for (i in _UDE) {        if (_UDE.hasOwnProperty(i) && _USE[i] !== undefined) {            _UDE[i].push(i);            return _UDE[i];        }    }}/*** css动画** @return  {array} 过渡属性的值-----------[0] 动画的css -----------[1] 动画的回调函数 -----------[2] 兼容的前缀 -----------[3] 浏览器过渡的监视属性 -----------[4] 浏览器结束的属性 */U.M.CssAm = function () {    var i, //遍历初始化    _USE = $$("div").style; //获取div的样式    //_UDE css动画属性名数组    var _UDE = {        "animation": ["animation", "animationEnd", "", "webkitRequest", "webkitCancel"],        "OTransition": ["-o-transition", "oTransitionEnd", "-o-", "oRequest", "oCancel"],        "MozTransition": ["-moz-transition", "transitionend", "-moz-", "mozRequest", "mozCancel"],        "MsTransform": ["-ms-transition", "transitionend", "-ms-"],        "transition": ["transition", "transitionend", "", "r", "cancel"]    }    for (i in _UDE) { //循环判断兼容        if (_UDE.hasOwnProperty(i) && _USE[i] !== undefined) {            _UDE[i].push(i);            return _UDE[i];        }    }}/*** css动画异步**/U.M.AsynCssEM = function (UDID, UDSD, UCB, UIF, UIF) {    this.removeClass(UDID, UIF);    $(UDSD).remove();    (UCB) && (UCB(UIF));}/*** css动画异步** @return  {array} 过渡属性的值*/U.M.JsEM = function (UDOD, UDE, UHK, UTF) {    var i, //遍历初始化    j, //循环初始化    _UCE, //储存字符串    _USE = [], //初始化数组    _UME = {}, //初始化对象    _UM = /[^\d-|.]+/ig, //正则表达式    _UNUM = /[\d-|.]+/ig; //正则表达式    for (i in UDE) {        if (UDE.hasOwnProperty(i)) {            if (i == "style") {//style的制作                _UCE = U.MS.jsonToStr(U.M.JsEM(UDOD[i], UDE[i], UHK, true));                (_UCE.length > 2) && (_UME[i] = { "cssText": _UCE.replace(/["|{|}]+/ig, "").replace(/,/ig, ";") });            }            else {//普通动画                _USE[0] = UDOD[i] || 0; _USE[1] = UDE[i]; for (j = 0; j < _USE.length; j++) {                    (typeof _USE[j] != "number") && (_USE[j] = Number(_USE[j].replace(_UM, "")));                } //生成位置                if (!isNaN(_USE[0])) { //动画获取                    j = UTF ? U.M.CssTHH(i, true) : i;                    _UME[j] = _USE[0] + ((_USE[1] - _USE[0]) * UHK); _USE[1] = UDOD[i] ? UDOD : UDE;                    (typeof _USE[1][i] == "string") && (_UME[j] = _USE[1][i].replace(_UNUM, _UME[j]));                }            }        }    }    return _UME;}/*** 获取鼠标位置** @param  {element} 相对对象 * @param  {element} 进暂无使用行操作的对象 * @return  {array} 过渡属性的值*/U.M.GetMousep = function (UDOD, UDTD) {    var _UE = U.M.GetEvent(), //获取MouseEvent    _UET = (_UE.touches && _UE.touches[0]) ? _UE.touches[0] : _UE, //如果是手机点击则获取touches[0]对象    _UDE = { "X": _UET.clientX || _UET["pageX"] || 0, "Y": _UET.clientY || _UET["pageY"] || 0 }, //储存坐标的对象    _UGE = { BCRL: 0, PXL: 0, BCRT: 0, PXT: 0 }; //用于储存数据sss    (UDTD || UDOD) && (_UGE = UDTD || U.M.TOSP(UDOD, true),    _UGE = U.M.GetElementAllInfo(_UGE)); //获取相对元素的位置    U.Ut.AddObj(_UDE, { "TX": _UGE.BCRL - _UGE.PXL, "TY": _UGE.BCRT - _UGE.PXT }); //获取位置与上级相对位置    U.Ut.AddObj(_UDE, { "X": _UDE["X"] - (_UDE["TX"] || 0), "Y": _UDE["Y"] - (_UDE["TY"] || 0), "MX": _UDE.X, "MY": _UDE.Y }); //设置值    return _UDE;}//获取事件源 跨iframe搜索U.M.GetEvent = function () {    var i, //循环初始化    _UDOD, //用于储存数据    _UDFD = window.frames; //获取window.frames    var _UE = window.event; //获取window.event    if (!_UE) {        for (i = 0; i < _UDFD.length; i++) { //循环所有的iframe 获取事件源            _UDOD = _UDFD[i];            try {                _UE = _UDOD.event;                if (_UE) { break; }            }            catch (e) { continue; };        }    }    return _UE;}/*** 阻止冒泡*/U.M.StopBubble = function () {    var _UE = U.M.GetEvent(); //获取Event    if (_UE) {        if (_UE.stopPropagation) { _UE.stopPropagation(); } // 停止DOM事件层次传播        else { _UE.cancelBubble = true; } //停止向上冒泡传播        return true;    }}/*** 动画初始化** @param  {object} 动画设置对象 */U.M.Animation = function (UDE) { //基础对象    return new U.M.Animation.init(UDE, U.M.Animation.get());}U.M.Animation.get = function () {    var i, j, //循环变量    _UFE,    _UDE = [["r", "cancel"], ["", "moz", "webkit", "o"]]; //兼容    //获取兼容字符串    for (i = 0; i < _UDE[0].length; i++) {        for (j = 0; j < _UDE[1].length; j++) {            if (_UFE = window[_UDE[1][j] + (j ? _UDE[0][i].replace(/\b(\w)|\s(\w)/g, function (e) { //通过循环和获取 每次获取的时候利用首字母大写设置                return e.toUpperCase();            }) : _UDE[0][i]) + "AnimationFrame"]) { _UDE[0][i] = _UFE; break; };        }    }    _UDE = _UDE[0];    (typeof _UDE[0] == "string") && (_UDE[0] = _UDE[1] = null);    return _UDE;}/*** 获取鼠标位置** @param  {object} 对象 */U.M.Animation.init = function (UDE, USE) {//动画初始化    U.Ut.AddObj(this, UDE); //添加动画对象    this.type = USE || U.M.Animation.get();    this.sm = (USE && USE[0]) ? new Date() : Math.ceil(this.ti / 20); //动画开始的时间      this.start(USE); //开始动画}//动画方法U.M.Animation.init.prototype = {    start: function (USE) {//这里开始了动画         var _UFN = (USE || this.type)[0];        this.tm = (_UFN ? _UFN(U.M.apply(this, this.time)) : window.setInterval(U.M.apply(this, [[this.time, [true]]]), 20)); //动画使用开始    },    time: function (UTF) {//动画运行        var _UTI, _UJT, _UST;        if (UTF == true) { //普通计时器动画            _UTI = 20 / this.ti;            (this.ti <= 0) && (this.stop(), _UTI = null);            this.cb(_UTI); this.ti -= 20;        }        else {//利用重绘动画使用            _UTI = new Date(); //据偶去当前的时间            _UJT = _UTI - this.sm;            _UST = _UJT / this.ti;            this.sm = _UTI; //时间的变化            this.ti -= _UJT; //总时间的减少            (this.ti <= 0) && (_UST = null, this.stop()); //调用停止函数            (_UST !== 0) && (this.cb(_UST)); //结束的回调            (_UST !== null) && (this.start()); //重复调用        }    },    stop: function () {//动画结束        (this.type[1] || window.clearInterval)(this.tm);    }}/*** 执行mouseout mouseover不冒泡情况** @param  {element} 需要执行的元素 */U.M.mouseLE = function (UCB) {    if (!U.M.onmouseout(this)) { UCB(); }}/*** mouseout||mouseover 冒泡解决** @param  {element} 需要执行的元素 * @return  {boolean} 是否是冒泡元素 */U.M.onmouseout = function (UDOD) {    if (event && "mouseover,mouseout".indexOf(event.type) > -1) { //判断事件源        var _UDTD = (event.type == "mouseover" ? event.fromElement : event.toElement) || event.relatedTarget; //事件对象        return U.M.EISE(UDOD, _UDTD); //判断是否在该元素下    }    return false;}/*** resize变化处理 包含了resizestart endresize 由于resize会出发多次 所有这里可分为 start 和 end** @param  {object} resize对象*/U.M.resize = function (UDE) {    var _UGE = new U.M.resize.init(UDE); //初始化监视    return U.M.apply(_UGE, _UGE.exec); //设置执行的方式}//resize方法函数U.M.resize.init = function (UDE) {    U.Ut.AddObj(this, this.u = UDE); //添加事件监视}//resize方法U.M.resize.init.prototype = {    exec: function () { //执行resize处理        this.start(); //onresize回调处理        (this.ti) && (clearTimeout(this.ti)); //取消end监视        this.ti = setTimeout(U.M.apply(this, this.end), 0); //end处理         (U.Ut.isFunction(this.u)) && (this.u()); //end事件等待    },    start: function () {        this.iss = true; //设置已经start        (!this.iss && this.s) && (this.s()); //函数回调    },    end: function () {        this.iss = false; //end结束        (this.e) && (this.e()); //resizeend处理    }}/*** 阻止浏览器的默认行为,例如右键菜单,左键选择**/U.M.StopDefault = function () {    var _UE = _UE || window.event; //获取window.event对象    if (_UE) {        if (document.all) { _UE.returnValue = false; } //IE中阻止函数器默认动作的方式         else { _UE.preventDefault(); } //阻止默认浏览器动作(W3C)         return false;    }}/*** 当你点击enter键时触发的函数** @param  {object} resize对象*/U.M.returnkeylogin = function (UEL, UFN) {    var i; //循环初始化    if (event.keyCode == 13 || event.keyCode == 10) {        if (UFN) {//执行函数            U.M.apply(UEL || this, UFN)();        }        else if (UEL) {//元素触发使用            for (i = 0; i < UEL.length; i++) {                UEL[i]["obj"][UEL[i]["event"]]();            }        }        U.M.StopDefault(); //阻止浏览器默认事件    }}/*** 自动触发HTMLElement事件 Mouse事件** @param  {element} 触发的元素* @param  {string} 事件类型* @return  {object} resize对象*/U.M.IEVENT = function (UDOD, UTF) {    if (UDOD.fireEvent) { return UDOD.fireEvent("on" + UTF, window.event); } //触发事件           //注销原事件源    else if (document.createEvent) {        var _UE = document.createEvent("MouseEvents"), _UEV = window.event;  //创建事件事件        _UEV ? _UE.initMouseEvent(UTF, true, true, window, _UEV.detail, _UEV.screenX, _UEV.screenY, _UEV.clientX, _UEV.clientY, _UEV.ctrlKey, _UEV.altKey, _UEV.shiftKey,        _UEV.metaKey, _UEV.button, _UEV.relatedTarget) : _UE.initMouseEvent(UTF, true, true, document.defaultView, 0, 0, 0, 0, 0, false, false, false, false, 0, UDOD); //初始化事件        return UDOD.dispatchEvent(_UE);  //分发事件    }}/*** 自动触发HTMLElement Touch事件** @param  {element} 触发的元素* @param  {string} 事件类型* @return  {object} resize对象*/U.M.TouchE = function (UDOD, UTF, UDE) {    if (UDOD.fireEvent) { UDOD.fireEvent("on" + TF); } //ie事件触发处理    else if (document.createEvent) { //h5事件处理        var i, _USE,        _UEV = UDE || window.event,        _UE = TouchEvent ? new TouchEvent(UTF, _UEV) : document.createEvent("TouchEvent"), //创建一个touch时间的处理        //获取当前touch事件        _UTF = _UE.initTouchEvent ? "initTouchEvent" : "initEvent";        //chrome        _USE = [        //chrome                         [event.touches,                            event.targetTouches,                            event.changedTouches,                            UTF,                            event.view,                            event.screenX,                            event.screenY,                            event.clientX,                            event.clientY,                            event.ctrlKey,                            event.alrKey,                            event.shiftKey,                            event.metaKey],        //safari                          [UTF,                                true,                                event.cancelable,                                event.view,                                event.detail,                                event.screenX,                                event.screenY,                                event.clientX,                                event.clientY,                                event.ctrlKey,                                event.altKey,                                event.shiftKey,                                event.metaKey,                                event.touches,                                event.targetTouches,                                event.changedTouches,                                event.scale,                                event.rotation                                ],        //firefox                                    [UTF,                                    true,                                    event.cancelable,                                    event.view,                                    event.detail,                                    event.ctrlKey,                                    event.altKey,                                    event.shiftKey,                                    event.metaKey,                                    event.touches,                                    event.targetTouches,                                    event.changedTouches],            ];        for (i = 0; i < _USE.length; i++) {            try { _UE[_UTF].apply(_UE, _USE[i]); }            catch (e) { }            if (_UE.type == UTF) { break; }        }    }    return UDOD.dispatchEvent(_UE); //分发事件}/*** 注册函数事件 Internet Explorer 8 及更早IE版本不支持 addEventListener() 方法,,Opera 7.0 及 Opera 更早版本也不支持。 但是,对于这些不支持该函数的浏览器,你可以使用 attachEvent() 方法来添加事件句柄 ** @param  {string} 事件名称* @param  {element} 添加事件的元素* @param  {function} 事件触发后调用的函数* @param  {string} 指定事件是否在捕获或冒泡阶段执行*/U.M.AddEvent = function (UTP, UDOD, UCB, UTF) {    if (UDOD.addEventListener) { //非IE使用        UDOD.addEventListener(UTP, UCB, UTF || false);    }    else if (UDOD.attachEvent) { //IE        UDOD.attachEvent("on" + UTP, UCB);    }    else {//html5处理        UDOD["on" + UTP] = U.M.apply(UDOD, [[UDOD["on" + UTP]], [UCB]]);    }}/*** 取消函数事件** @param  {string} 事件名称* @param  {element} 添加事件的元素* @param  {function} 事件触发后调用的函数* @param  {string} 指定事件是否在捕获或冒泡阶段执行*/U.M.ReEvent = function (UTP, UDOD, UCB, UTF) {    if (UCB) {        UCB = UCB[0] || UCB; //绑定函数默认        if (UDOD.removeEventListener) { //非IE使用            UDOD.removeEventListener(UTP, UCB, UTF || false);        }        else if (UDOD.detachEvent) {//IE使用            UDOD.detachEvent("on" + UTP, UCB);        }        else { UDOD["on" + UTP] = null; } //非元素    }}/*** 对象转化成数组** @param  {object} 需要转换成数组的对象* @return  {string} 指定事件是否在捕获或冒泡阶段执行*/U.M.toArray = function (UDE) {    try {        return Array.prototype.slice.call(UDE);    }    catch (e) {        var i = 0, _UCE = []; //循环创建        for (; UDE[i]; i++) {            _UCE.push(UDE[i]);        }        return _UCE;    }}/*** 屏调ie菜单** @param  {object} 需要转换成数组的对象*/U.M.ShieldedRightAndSelect = function () {    if (window.print) { //判断是否有右键菜单        document.oncontextmenu = U.M.StopDefault; //阻止桌面右键默认菜单        document.onselectstart = function () { //禁止元素选择文字            var _UDOD = U.M.GetDE(event.srcElement), //获取一个可编辑元素            _UTF = !(_UDOD && ((_UDOD.nodeType == 3 || (_UDOD.contentEditable == "true"))) || ((("textarea,input".indexOf(_UDOD.tagName.toLocaleLowerCase()) > -1))));            (_UTF) && (U.M.StopBubble(), U.M.StopDefault());            return (!_UTF);        }        var _UDE = function () {            if (event.keyCode == 8) { //禁止后退网页                if (U.M.GetDE((event.srcElement)) == document.body && !document.body.isContentEditable) { //不允许按下后台键                    U.M.StopDefault();                }            }            (U.M[event.type]) && (U.M[event.type]()); //判断是否具有事件处理        };        U.M.AddEvent("keydown", document, _UDE); //设置键盘事件处理        U.M.AddEvent("keyup", document, _UDE); //设置键盘事件处理    }}/*** 统一处理函数,解决闭包添加事件的问题* 使用apply,把事件与属性添加到对象上,而不是添加到window顶级对象。使用apply而不是call,是因为apply第二个参数可以传递参数数组,代码更少。* 调用方法 U.M.apply(this,'执行函数的事件')  例如 U.M.apply(this,'this.style.display="none"');** @param  {object} 将要绑定事件与属性的对象,如没有,可以传递null或者this,此处还需要优化,很多地方都会调用此函数,会导致速度降低。* @param  {object} 时间和属性组成的参数数组。*/U.M.apply = function (retElement, UDE) {    //retElement 将要绑定事件与属性的对象,如没有,可以传递null或者this,此处还需要优化,很多地方都会调用此函数,会导致速度降低。    //UDE 时间和属性组成的参数数组    return function () {        if (UDE) {            var i, //循环初始化            j, //循环初始化            _URE,            _UAE,            _UTE = (retElement) || this,            _UME = Array.prototype.slice.apply(arguments); //arguments 转化成数组            if (typeof UDE == "string") { _URE = (new Function(UDE)).apply(_UTE, _UME); }            else if (typeof UDE == "function") { _URE = UDE.apply(_UTE, _UME); }            else {                for (i = 0; i < UDE.length; i++) {                    if (UDE[i] && UDE[i][0]) { //函数存在                        _UAE = UDE[i][1];                        (!_UAE) && (_UAE = []);                        (!U.Ut.isEvent(_UME[0]) || _UME.length > 1) && (_UAE = _UAE.concat(_UME)); //event == null ||                        //循环添加至                        for (j = 0; j < _UAE.length; j++) {                            if (typeof _UAE[j] == "string") {                                try {                                    if (_UAE[j].indexOf("this") > -1 || _UAE[j].indexOf("retElement") > -1 || _UAE[j].indexOf("event") > -1) { _UAE[j] = eval("0,(" + _UAE[j] + ")"); } //制定参数解析                                    else if (U.MS.Num.test(_UAE[j])) { _UAE[j] = Number(_UAE[j]); } //数字转化                                } catch (e) { U.M.Console(e); }                            }                        }                        try {                            if (U.Ut.isString(UDE[i][0])) {                                _URE = eval(UDE[i][0]).apply(_UTE, _UAE); //eval效率不高 特殊情况才用                            }                            else if (U.Ut.isFunction(UDE[i][0])) { _URE = UDE[i][0].apply(_UTE, _UAE); }                        }                        catch (e) { U.M.Console(e); } //函数执行错误                    }                }            }            return _URE;        }        //直接掉U.M.apply(),不传递UDE参数时,返回false。        else { return false; }    }}/*** 图片错误处理** @param  {element} 图片元素* @param  {number} 判断的类型*/U.M.ImgError = function (UDOD, UTF) {    var _UIE, //存放参数    _UURL, //存放图片的src    UDOD = UDOD && !UDOD.srcElement ? UDOD : (event ? event.srcElement || this : this); //获取出错的对象    if (UDOD.src != "/img/error.png") { //如果是错误图片就不执行        if (UTF == 2) { //重复请求图片 用于初始上传的图片            _UURL = UDOD.src; //图片的路径            _UIE = _UURL.indexOf("?&n="); //判断是否添加获取            if (_UIE < 0 || _UURL.length - _UIE < 10) {                UDOD.src += (_UIE == -1 ? "?&n=" : "") + 1; //添加缓存过滤                return            }            else {                UTF = 1;            }        }        if (UTF == 1) { //错误图像处理            $(UDOD).addAttrArray({ "src": "/img/error.png", "width": "111px", "height": "111px" });        }        else { //错误头像处理             UDOD.src = UTF || "/img/UserHead/UseHead.jpg";        }    }}/*** 获取头像图片的正确地址** @param  {string}  需要生成正常地址的 由于1473的地址 需要带上 http://fs.1473.cn 无需 这里同时处理了 1473和外链地址* @return  {string} 过滤过的*/U.M.GetImgU = function (url) {    return (!url ? "/img/UserHead/UseHead.jpg" : !url.indexOf("http") ? url : ((url.indexOf("www.1473.cn") > -1 ? url : US.fs + url.replace(new RegExp(US.fs, "gm"), ""))));}/*** 判断是否支持播放** @param  {string}  指定的格式* @return  {number}  是否支持改格式播放-----------[0] 不支持-----------[1] 支持*/U.M.isPlay = function (UTP) {    var _UDE = U.PL.vi(); //获取h5视频播放对象    if (_UDE) {        if (_UDE.isPlay(UTP, $$("video"))) {            return 1;        };        return 0;    }    return _UDE;}/*** 图片预加载方法** @param  {string}  需要加载的图片地址* @param  {function}  预加载回调函数* @param  {function}  加载成功回调* @param  {function}  错误处理回调* @return  {element}  图片元素*/U.M.imgReady = function (url, URD, ULD, UE) {    var _UW,    _UH,    _UNW, //image对象的width属性    _UNH, //image对象的height属性    _UIMG = new Image(); //image对象    _UOR = function () { //预加载        _UIMG = _UIMG || this;        _UNW = _UIMG.width;        _UNH = _UIMG.height; //获取加载图片的长宽        if ((_UNW !== _UW || _UNH !== _UH) || _UNH !== 0) {            (URD) && (URD.call(_UIMG));            _UOR.end = true;        }    };    $(_UIMG).addAttrArray({ "src": url,        "onload": function () { //成功加载回调            setTimeout(function () {                !_UOR.end && _UOR(); (_UIMG) && (_UIMG.onload = _UIMG.onerror = null);                (_UIMG && ULD) && (ULD.call(_UIMG));                _UIMG = null;            }, 0);        },        "onerror": function () { //错误图片处理            if (U.M.IsNetwork()) {                UE && UE.call(_UIMG);            }        }    });    if (_UIMG) { //说明图片还在加载中        _UOR(); //执行预加载处理        if (_UIMG.complete == true) { //判断是否已经成功加载过了 缓存图片处理            _UIMG.onload(); return;        }    }    if (!_UOR.end) { //添加进入图片大小加载事件        U.M.imgReady._UL.push(_UOR);        if (U.M.imgReady._UIT == null) {            U.M.imgReady._UIT = setInterval(U.M.imgReady._URT, 40); //每40毫秒进入        }    }    return _UIMG;}U.M.imgReady._UIT; //计时器初始化U.M.imgReady._UL = []; //需要预加载的图片集//去除预加载计时U.M.imgReady._US = function () {    clearInterval(U.M.imgReady._UIT);    U.M.imgReady._UIT = null;};//计时加载逐个加载处理U.M.imgReady._URT = function () {    for (var i = 0; i < U.M.imgReady._UL.length; i++) {        U.M.imgReady._UL[i].end ? U.M.imgReady._UL.splice(i--, 1) : U.M.imgReady._UL[i]();    }    !U.M.imgReady._UL.length && U.M.imgReady._US();}/*** 滚动条滚动到制定的位置** @param  {string}  指定scrollTop的数值* @param  {function}  需要调整滚动条位置的对象* @param  {function}  加载成功回调* @return  {element}  图片元素*/U.M.SCT = function (UT, UDOD, UTF) {    var _UTP = U.Ut.isNumber(UT); //判断UT是否是数字true 或者 false    if (_UTP && UTF) {        $(UDOD).animate({ "scrollTop": UT }, UTF);    } //动画移动具体的位置    else {        if (typeof UT == "number") {            UDOD.scrollTop = UT;        }        else { UT.scrollIntoView(); }    } //直接移动过}/*** 获取url参数** @param  {string}  QueryString key* @param  {string}  QueryString 默认为window.document.location.search ,可以自己选择字符串进行拆分* @return  {string}  获取key对应的值*/U.M.QueryString = function (UK, USE) {    //UK 获取url的key    var i, //循环初始化    j, //循环初始化    _UV, //储存值的数组    _USV = "", //作为返回值    _USE = (USE || window.document.location.search).substr(1), //获取传参    _UTV = _USE.split("&"); //生成传参数组    if (!UK) { //判断是否传入key        return _UTV;    }    for (i = 0; i < _UTV.length; i++) { //循环传参数组获取值        _UV = _UTV[i].split("=");        if (_UV[0].toUpperCase() == UK.toUpperCase()) { //判断key是否相等            for (j = 1; j < _UV.length; j++) { //返回值                _USV += _UV[j] + (j == _UV.length - 1 ? "" : "=");            }            break;        }    }    return _USV;}/*** 获取用户获取的地址**/U.M.GetUF = function () {    var _UURL = document.location.hash; //地址传参    return _UURL.split("/");}/*** 页面活动监视,当用户离开页面休息时,停止页面活动(计时器)** @param  {function} 页面聚焦回调函数* @param  {function} 页面非聚焦回调函数* @return  {string}  获取key对应的值*/U.M.IsActivity = function (UOE, UTE) {    if (UOE) {        //鼠标在当前body上 说明现在是活动 \(\[(\s*[a-z]+\s*(,\s*[a-z]+\s*)*)\]\) \({\[+[\w]+\]}\)        $(document.body).mouseenter(U.M.apply(null, [[U.M.IsActivity.UFC, [UOE]]]));        U.M.AddEvent("focusin", document, U.M.apply(null, [[U.M.IsActivity.UFC, [UOE]]])); //页面聚焦同时为活动页面    }    if (UTE) {        U.M.AddEvent("focusout", document, U.M.apply(null, [[U.M.IsActivity.UBC, [UTE]]])); //页面休眠中    }}U.M.IsActivity.UTF; //页面变化变量/*** 页面活动监视** @param  {function} 页面聚焦回调函数*/U.M.IsActivity.UFC = function (UCB) {    (!U.M.IsActivity.UTF) && (U.M.IsActivity.UTF = true, UCB());}/*** 离开页面休眠** @param  {function} 页面非聚焦回调函数*/U.M.IsActivity.UBC = function (UCB) {    var _UDTD,    _UX = event.clientX,  //页面x坐标    _UY = event.clientY; //获取event对象的y坐标    if ((!browser.msie || ((_UX < 0 || _UX > US.Width || _UY < 0 || _UY > US.Height))) && U.M.IsActivity.UTF) { //判断鼠标不在页面中        U.M.IsActivity.UTF = false;        UCB();    }}/*** cookie解决方案**/U.M.Cookies = {};/***在iframe中调用此函数,会把主页的cookie传递到子域, 跨域加载cookie,1473子域用,其他跨域不能用,为了兼容ie6,ie7,暂时未用。** @param  {string} 跨域的url* @param  {function} 成功记载后的回调函数*/U.M.Cookies.crossdomain = function (url, cb) {    U.MD.DynamicLoad(url, "js", cb, null, true);    //U.MD.DynamicLoad("/uform.js", "js", cb, null, true);}/***1473cookie格式专用* 把形如:"userid=72854d28-f45c-48d7-92b7-3cd933e03022&username=13928417148&Loginid=fd02976d-993b-4437-bbd9-5efa99802c8f&UserStamp=1364812396"的cookie转换为json对象。函数名有问题。得到的形式为:_UAE.Loginid可得到用户id。** @param  {string} 获取cookie的key对应的值 如usestudio=aa=ff&ss=aa 的usestudio里的 aa=ff&ss=aa* @return  {object} {key:[value1,value2]}*/U.M.Cookies.getarray = function (key) { //获取cookie    var i, //循环初始化    _UAE = {}, //初始化对象 作为返回值    _UCE = U.M.GetCookie("usestudiosso"); //获取用户指定的Cookie值    if (_UCE) { //是否存在        _UCE = _UCE.split("&");        for (i = 0; i < _UCE.length; i++) { //循环对应的值            _UCE[i] = _UCE[i].split("="); //切分key和value            //如果定义了cookie值的接受数组,则不再重复定义。_UCE[i][0]相当于key,例如userid            if (!_UAE[_UCE[i][0]]) {                _UAE[_UCE[i][0]] = [];            }            _UAE[_UCE[i][0]].push(decodeURIComponent(_UCE[i][1])); //生成{key:[value1,value2]}        }    }    return _UAE;}/*** 设置cookie** @param  {string || object} cookie 字符串或者cookie集合。参见例一,例三。* * @param  {object} cookie 的key----------path: null, //cookie地址----------domain: null, //cookie域----------expires: 365, //cookie过期时间----------secure: null //cookie来源* @return  {string}*例一:U.M.Cookies.set("usestudiossso=UserId=aa&UserName=zhangsan");net java模式*例二:U.M.Cookies.set("15hulianwang=userid=123456&username=zhangsan");net java模式*例三:U.M.Cookies.set({15hulianwang:{userid:123456,username:'zhangsan'}});nodejs模式*/U.M.Cookies.set = function (UKE, UDE) {    var i, //循环初始化    j, //循环初始化    k = 0, //用于计数    _UST = ""; //最终的cookie字符串    //如果UKE是字符串,则直接设置cookie,如果为集合,则转换为字符串进行处理。    if (U.Ut.isString(UKE)) {//判断设置的是否是字符串         _UST = UKE; document.cookie = this.setpn(UDE, _UST); //直接设置    }    //以下没有检验,用于nodejs的集合类cookie    else {        for (i in UKE) {            _UST = i + "=";            for (j in UKE[i]) {                //把集合拆分成字符串。                //如果k>0,则添加&号分割符                if (k > 0) {                    _UST += "&";                }                _UST += j + "=" + encodeURIComponent(UKE[i][j]);                k++;            }            //            document.cookie = this.setpn(UDE, _UST);        }    }    return (document.cookie);}/*** 设置指定参数(添加)** @param  {object} cookie 的key----------path: null, //cookie地址----------domain: null, //cookie域----------expires: 365, //cookie过期时间----------secure: null //cookie来源* @param  {string} 需要写入的cookie usestudio=aa=cc* @return  {string} 返回写入的cookie值*/U.M.Cookies.setpn = function (UDE, UST) {    var _UCE = {        path: "/", //cookie地址        domain: document.domain, //cookie域        expires: 365, //cookie过期时间        secure: null //cookie来源    };    //一般不传递第二个参数,这里为空会报错,所以转换为集合    UDE = UDE || {};    for (i in _UCE) { //循环设置        //不去找原型,直接找_UCE中定义的变量和方法        if (i == "expires" && (UDE[i] || _UCE[i])) { //时间过期处理            _UKE = new Date();            //如果用户设置了时间,则用用户的时间,否则默认过期时间为一年            var _etime = (UDE[i] || _UCE[i]) * 24 * 60 * 60 * 1000;            _UKE.setTime(_UKE.getTime() + _etime); //时间变化处理            UDE[i] = _UKE.toUTCString();        }        //判断是否设置cookie属性,如果用户不设置,系统默认为null,则不设置,例如secure: null         if (UDE[i] || _UCE[i]) {            var _pj;            //如果用户设置属性为null,则用系统的,否则用用户设置的属性            if (UDE[i] == null) {                _pj = _UCE[i];            }            else {                _pj = UDE[i];            }            //拼接cookie。            UST += "; " + i + "=" + _pj; //添加cookie        }    };    return UST; //返回cookie}/*** 移除cookie(删除)** @param  {string} cookie 的key* @return  {string}*/U.M.Cookies.del = function (key) {    var i, _UAE, _UST = "",    _UCE = document.cookie.split("; "); //cookie值    //过滤指定的cookie值    for (i = 0; i < _UCE.length; i++) {        _UAE = _UCE[i].split("=");        //如果符合用户传递的cookie的key值,则转换为字符串        if (!key || _UAE[0] == key) {            //多cookie情况下,用分号分割,否则不分割            var _cut = _UST.length ? "; " : "";            _UST += _cut + _UAE[0] + "=";        }    }    //删除指定的cookie    if (_UST) {        U.M.Cookies.set(_UST, { expires: -1 });    }    else {        console.log("not found cookie!");    }}/*** 功能:获取用户指定的Cookie值描述:浏览器cookie形如:"pgv_pvid=3156364456; usestudiosso=userid=72854d28-f45c-48d7-92b7-3cd933e03022&username=13928417148&Loginid=fd02976d-993b-4437-bbd9-5efa99802c8f&UserStamp=1364812396; __qc_wId=563; amvid=319501000bca68c1adab006842344f44"第一步:根据分号拆分成数组.第二部:按照"="拆分第三部:找到"usestudiosso",usestudiosso=userid=72854d28-f45c-48d7-92b7-3cd933e03022&username=13928417148&Loginid=fd02976d-993b-4437-bbd9-5efa99802c8f&UserStamp=1364812396第四步:去掉"usestudiosso",得到userid=72854d28-f45c-48d7-92b7-3cd933e03022&username=13928417148&Loginid=fd02976d-993b-4437-bbd9-5efa99802c8f&UserStamp=1364812396参数一:UKY为cookie名字,云端cookie名为:"usestudiosso"** @param  {string} 获取cookie的key对应的值 如usestudio=aa=ff&ss=aa 的usestudio里的 aa=ff&ss=aa* @param  {string} aa=ff&ss=aa里面的aa对应的值 [ff]* @return  {string, array} 上述参数里说明返回 ---------第二个参数不存在的时候返回string---------第二个参数存在的时候返回array*/U.M.GetCookie = U.M.Cookies.get = function (UKY, UKN) {    var i, //循环初始化    _UAT, //储存字符串的数组    _UTV = "",    _UCK = (document.cookie || document.wincookie || "").split("; "); //从cookie中获取指定的cookie集    for (i = 0; i < _UCK.length; i++) {        _UAT = _UCK[i].split("=");        //如果找到名为"usestudiosso"的cookie,则        if (_UAT[0] == UKY) {            _UAT.splice(0, 1);            _UTV = _UAT.join("=");            break;        } //生成指定的Cookie    }    if (UKN) {//从指定的cookie集里获取cookie值        _UCK = _UTV.split("&");        _UTV = [];        for (i = 0; i < _UCK.length; i++) {            _UAT = _UCK[i].split("=");            if (_UAT[0] == UKN) { _UTV.push(decodeURIComponent(_UAT[1])); } //获取指定的cookie值            else if (_UAT[1] == UKN) { return true; } //判断是否是指定的cookie存在        }    }    return (_UTV.length ? _UTV : false);}/*** 判断Url是否合法** @param  {string} url值* @return  {boolean} 是否盒饭的url*/U.M.IsUrl = function (url) {    if (U.Ut.isString(url)) {        var _UDAD, //新建a标签        _UTF = false; //boolean值        url = ((url.indexOf("://") > 0 ? "" : "http://") + url);        if (U.MS.Url.test(url)) { //正则判断是否是有效的url            _UDAD = $$("a", { "href": url });            _UTF = _UDAD.href ? url : false; //a标签判断 indexOf(url) == 0        }        return _UTF;    }}/*** 获取url** @param  {string} url值* @return  {object} 返回url对象----------[host] 返回域的地址----------[search] 返回search*/U.M.getUrl = function (url) {    //UURL url    var _UDAD = $$("a", { "href": url }); //新建a标签    return { "host": _UDAD.href.replace(_UDAD.search, ""), "search": _UDAD.search };}/*** iframe写入数据** @param  {element} iframe* @param  {string} 写入iframe的值* @param  {function} 成功的回调函数* @return  {element} 返回iframe*/U.M.IFO = function (UIF, UHT, UCB) {    U.MD.IframeLoad(UIF, [[U.M.AsynIFO, [UIF, UHT, UCB]]]); //设置回调    UIF.src = "javascript:void((function(){document.open();document.domain='" + document.domain + "';document.close()})())"; //添加链接 "about:blank";    return UIF;}/*** iframe异步处理** @param  {element} iframe* @param  {string} 写入iframe的值* @param  {function} 成功的回调函数*/U.M.AsynIFO = function (UIF, UHT, UCB) {    (UHT) && (UIF.contentWindow.document.body.innerHTML = UHT);    (UCB) && (U.M.apply(UIF, UCB)()); //回调 }/*** ajax中文加密** @param  {array} 需要加密的字符串数组 这个为url加密* @return  {array} 返回加密成功的url数组*/U.M.SplitArray = function (UDE) {    var i; //循环初始化    for (i = 0; i < UDE.length; i++) {        UDE[i] = encodeURIComponent(encodeURIComponent(UDE[i]));    }    return UDE.join(",");}/*** 文字复制** @param  {string} 需要复制的元素*/U.M.Copy = function (UTH) {    if (window.clipboardData) { //ie        window.clipboardData.setData("text", UTH);    }    else if (event && event.clipboardData) {//html5兼容        event.clipboardData.setData("text/HTML", UTH);    }    else if (event && event.originalEvent && event.originalEvent.clipboardData) { //firfox兼容        event.originalEvent.clipboardData("Text", UTH);    }    else if (document.execCommand) { //基本全兼容除了手机端的safari        document.execCommand("copy");    }    else {        U.Alert("请手动选择复制");    }}/*** 文字粘贴** @param  {string} 需要复制的元素*/U.M.UrlPaste = function () {    if (window.clipboardData) { //ie        return window.clipboardData.getData("text");    }    else if (event.clipboardData) { //html5        return event.clipboardData.getData("text/HTML");    }    else if (event && event.originalEvent && event.originalEvent.clipboardData) { //firfox兼容        return event.originalEvent.clipboardData("Text")    }    else if (document.execCommand) {//基本全兼容除了手机端的safari        document.execCommand("paste");    }    else {        U.Alert("无法粘贴");    }    //http://static.zhihu.com/static/js/v2/ui/editor_plugin_code.js    /*    var _ = this.getStateTuple(), state = _.state, range = _.range, code = _.code    if (state !== Plugin.State.EDITABLE) return    var text, textType = 'text/plain'    var clipboard = e.getBrowserEvent().clipboardData    if (clipboard) { // w3c(webkit,opera...)    if (clipboard.types && goog.array.contains(clipboard.types, textType)) {    e.preventDefault()    text = clipboard.getData(textType)    this.replaceText(range, text)    }    } else if (window.clipboardData) { // IE    text = window.clipboardData.getData('Text')    if (text) {    e.preventDefault()    this.replaceTextIE(range, text)    }    } else { // FF    // TODO:rewrite    var offset = range.getStartOffset()    var selectedLength = range.getText().length    var codeLength = function () {    return code.firstChild ? goog.editor.node.getLength(code.firstChild) : 0    }    var endLength = codeLength() - offset - selectedLength    setTimeout(function () {    Plugin.cleanup(code)    var caretOffset = codeLength() - endLength    if (code.firstChild) {    goog.dom.Range.createCaret(code.firstChild, Math.max(offset, caretOffset)).select()    }    })    }    */}/*** 右键菜单定位** @param  {string} 需要定位的右键菜单*/U.M.RLocate = function (UDOD) {    //UDOD 需要定位的元素    var _UDPD = U.M.TOSP(UDOD), //获取元素offsetParent    _UEV = U.M.GetMousep(_UDPD), //当前鼠标位置    _UW = [UDOD.offsetWidth, _UDPD.offsetWidth], //记录UUOD的offsetWidth属性    _UH = [UDOD.offsetHeight, _UDPD.offsetHeight]; //记录UUOD的offsetHeight属性    _UEV["X"] = ((_UW[0] + _UEV["X"]) > _UW[1]) ? _UEV["X"] - _UW[0] : _UEV["X"]; //设置top最大范围    _UEV["Y"] = ((_UH[0] + _UEV["Y"]) > _UH[1]) ? _UEV["Y"] - _UH[0] : _UEV["Y"]; //设置left最大范围    $(UDOD).addAttrArray({ "style": { "cssText": "top:" + _UEV["Y"] + "px;left:" + _UEV["X"] + "px"} }); //右键菜单的位置}/*** 冒泡排序法的封装** @param  {array} 排序数组* @param  {string} 排序类型* @param  {function} 判断执行函数* @param  {number} 是否是升序降序----------[-1] 升序----------[1] 降序*/U.M.Sequence = function (UDE, UTP, UCB, UIE) {    (UDE) && (UDE.sort(function (UO, UT) {        return ((UCB(UO[UTP], UT[UTP]) ? -1 : 1) * (UIE || 1));    }));}//判断是否支持svgU.M.isSupportSvg = function () {    return !!(document.createElementNS && document.createElementNS("http://www.w3.org/2000/svg", "svg").createSVGRect);}/***浮点数运算函数JavaScript浮点运算的一个bug。 比如:7*0.8 JavaScript算出来就是:5.6000000000000005* 数字计算 解决浮点的bug** @param  {number} 数字1* @param  {number} 数字2* @param  {string} 连系符号 + - * /*/U.M.floatOperate = function (number1, number2, operator) {    var i, //循环初始化    _pow, ////用于存放数据的变量    _strArr = [String(number1), String(number2)]; //用于存放数据的数组    for (i = 0; i < 2; i++) {        _strArr[i + 2] = _strArr[i].length - _strArr[i].indexOf(".") - 1;    }    _pow = Math.pow(10, Math.max(_strArr[2], _strArr[3]));    return (eval("0," + _strArr[0] * _pow + operator + _strArr[1] * _pow)) / _pow;}/*** 获取对象类型** @param  {object} 需要判断的对象* @return  {string} Number,String,Array,Object,Symbol*/U.M.GetType = function (UDOD) {    //UDO D需要判定类型的变量    if (UDOD) {        try {            var _UCE = UDOD.constructor; //求元素的构造函数。            //把构造函数按照字符串格式输出,结果形如:"function String() { [native code] }"。对结果执行执行字符串匹配,得到结果数组,判断结果数组中是否包含"String",得出类型。            var _UDE = (_UCE || UDOD).toString().match(_UCE ? /function\s*(\w+)/ : /\[object (.*?)\]/);            if (_UDE && _UDE.length == 2) {                return _UDE[1].toLowerCase();            }            else {                return typeof UDOD;            }        } catch (e) { }    }}/*** 把json字符串转化成使用对象** @param  {string} 需要判断的对象* @return  {object} 返回成功过生成后的对象 支持无线树*/U.M.toList = function (UDE) {    //UDE json字符串    var i; //循环初始化    (U.Ut.isString(UDE)) && (UDE = UDE.parseJSON()); //转化成Json    if (U.Ut.isArray(UDE)) { //设置数组          for (i = 0; i < UDE.length; i++) {            (U.Ut.isString(UDE[i])) && (UDE[i] = UDE[i].parseJSON());            U.Ut.isArray(UDE[i]) && (U.M.toList(UDE[i]));        }    }    return UDE;}/*** 返回制定的对象类型名** @param  {object} 需要判断的对象* @return  {string} 返回object转化后的的*/U.M.objectToString = function (UDE) {    return Object.prototype.toString.call(UDE);}/*** 判断浏览器是否联网** @param  {function} 需要判断的对象* @return  {boolean} 是否联网*/U.M.IsNetwork = function (UCB) {    //UCB 回调函数 暂未使用    var i, //循环初始化    j, //循环初始化    _UOE = [window, document.body], //存放数据的数组    _UDE = ["offline", "online"]; //存放数据的数组    if (UCB) {        for (i = 0; i < _UOE.length; i++) {            for (j = 0; j < _UDE.length; j++) {                U.M.AddEvent(_UDE[j], _UOE[i], U.M.apply(this, [[U.M.StopBubble], [UCB, [j]]]));            }        }    }    return navigator.onLine;}/*** 错误函数控制台处理,,** @param  {string} 输入控制台的类型 默认log* @return  {object} 输出控制台的值*/U.M.Console = function (err) {    try {        console.log(err);    } catch (e) { }}/*** 滚动到底部处理** @param  {object} 滚动值----------[AF] 回调函数* @return  {object} 滚动对象*/U.M.SSCH = function (UDE) {    //UDE 对象    return new U.M.SSCH.init(UDE);}U.M.SSCH.init = function (UDE) {//滚动方法执行    this.UDOD; //滚动元素    this.CT; //处理多次处理 用来设置 srcollend函数    this.P = 0; //最底部的次数    this.UTF = true;    this.Top = UDE["Top"]; //是否为顶部    this.UCB = UDE["AF"]; //回调函数}U.M.SSCH.init.prototype = {    /**    * 滚动初始使用    *    * @param  {object} 滚动对象 原对象的this    */    SZX: function (UTE) {        UTE.UDOD = this; //滚动对象        clearTimeout(this.CT);        this.CT = setTimeout(U.M.apply(UTE, [[UTE.ZSCH]]), 0); //滚动开始    },    //获取方法    SCH: function () {        return U.M.apply(null, [[this.SZX, [this]]]); //滚动执行    },    /**    * 滚动处理    *    * @param  {object} 滚动对象 原对象的this    */    ZSCH: function () {//执行        var _UDOD = this.UDOD, //滚动掉元素        _UT = _UDOD.scrollTop || document.documentElement.scrollTop; //当前滚动高度        if (this.Top != null) {            if (this.Top == _UT) { //滚动大小是否到底部判断                (this.UCB) && (this.UCB.call(this));                this.P++;            }        }        else {            if (_UT + _UDOD.offsetHeight >= _UDOD.scrollHeight - 2) { //滚动大小是否到底部判断                (this.UCB) && (this.UCB.call(this));                this.P++;            }        }    }}/*** html加载,存储一篇文章,javascritp可以放在任何地方,当把文章追加到div等元素中时,由于没有刷新,导致javascript不能执行。需要把javascript重新移动到head头部才会加载。** @param  {element} 任何html元素 * @param  {string} 文章内容 @return  返回文章内容*/U.M.loadHtml = function (UDOD, UTH) {    if (UTH != null) {        UDOD.innerHTML = UTH;    }    // UDOD.innerHTML += "";    var i, //循环初始化    _UDHD = $("head")[0],    _UDE = $("script", UDOD); //获取script标签    for (i = 0; i < _UDE.length; i++) {        if (_UDE[i].src == "/uform.js") {            U.MD.DynamicLoad(_UDE[i].src, "js");        }        else {            $$("script", { "type": _UDE[i].type, "src": _UDE[i].src }, UDOD, _UDE[i]).text = _UDE[i].text;        }    }    return UTH;}/*** 获取文字简写** @param  {element、 string} 传入的对象或者文字* @param  {number} 截图的长度* @param  {string} 后缀的添加*/U.M.Shorttext = function (UDOD, UL, UST) {    UDOD = U.Ut.isString(UDOD) ? $$("div", { "innerHTML": UDOD }) : UDOD; //截取的对象    UL = UL || 200; //截取的长度    UST = UST || ""; //省略号    return UDOD.innerText.substring(0, UL) + (UDOD.innerText.length > 200 ? UST : "") + $("img", UDOD).outerHTML;}/*** 随机产生一个函数 调用后销毁 类似委托解决跨域问题,以及ajax多个请求,多份实例的问题。** @param  {array} 滚动对象 原对象的this----------[0] 回调函数----------[.....] 传送的参数* @return  {object} 委托对象*/U.M.getFun = function () {    if (arguments.length) {        return new U.M.getFun.init(arguments);    }    else {        throw new Error("cb is null");    }}/***上述函数的初始化函数** @param  {object} 滚动对象 原对象的this*/U.M.getFun.init = function (UDE) { //初始化对象保存    UDE = Array.prototype.slice.call(UDE); //转化成数组    U.Ut.AddObj(this, { //参数        cb: UDE[0], //回调函数        id: "a" + Guid.guidNoDash(), //唯一识别id        isremove: true, //是否移除        parame: UDE.slice(1) //传参    });    window[this.id] = U.M.apply(this, [[this.Invoke, this.parame]]); //设置唯一识别函数使用}U.M.getFun.init.prototype = {    set: function (UDE) { //设置传参        var i; //遍历初始化        for (i in UDE) {            (UDE.hasOwnProperty(i)) && (this[i] = UDE[i]);        }        return this;    },    toString: function () { //返回对象        return this.id;    },    //执行 同时销毁对象    Invoke: function () {        try {            if (U.Ut.isFunction(this.cb)) { //判断是否有回调函数                this.cb.apply(this, arguments);            }            if (this.isremove) { //是否移除对象                window[this.getId()] = null; //设置对象移除                delete window[this.getId()]; //清理对象                delete this;            }        } catch (e) { }    },    //获取ID    getId: function () {        return this.id;    }};/*** HTML模版页面 支持js内置 类似于js上的php ejs** @param  {element} 需要变化的元素* @param  {object} 传参对象*/U.M.Simulation = function (UDOD, UDE) {    new U.M.Simulation.init(UDOD, UDE).exec();}/*** 初始化HTML模版页面 支持js内置 类似于js上的php ejs** @param  {element} 需要变化的元素* @param  {object} 传参对象*/U.M.Simulation.init = function (UDOD, UDE) {    this.el = UDOD; //    U.Ut.AddObj(this, UDE);    return this;}U.M.Simulation.init.prototype = {    //正则配置    config: { m: /^\\<{+([\s\S])+\\}>$/, //  /\+=([\s\S])+?\+$/g        zs: "+=", ze: "+", c: /\\/g,        d: /(?=["])/g, s: "<{", e: "}>",        f: "%",        t: "([\\s\\S])*?"    },    //执行    exec: function () {        try {            var i, _UCS = "",            _UPE = [],            _UT = this,            _UKE = this.key,            _UCE = this.config,            _USE = (this.el.innerHTML || this.el).trim(" ").replace(_UCE.c, "\\\\").replace(_UCE.d, "\\").replace(this.getConfig("\\\\", "", "", "\\\\"),            function (UST) { //配置输出查看                 return UST.replace("\\" + _UCE.s, _UCE.s.replaceHtmlSign()).replace("\\" + _UCE.e, _UCE.e.replaceHtmlSign());            });            //函数匹配区域            _USE = _USE.replace(this.getConfig("", "", _UCE.f), function (UST) {                return UST.replace(_UCE.s + _UCE.f, "\";").replace(_UCE.e, ";uhtml+=\"");            });            _USE = _USE.replace(this.getConfig(), function (UST) {                return "\"+" + ((UST.replace(_UCE.s, "").replace(_UCE.e, "").replace(_UT.re("\\" + _UCE.zs + _UCE.t + "\\" + _UCE.ze),                function (UST) {                    return UST.replace(_UCE.zs, "").replace(_UCE.ze, "").replaceHtmlSign();                })) || "\"\"") + "+\"";            }); //配置html输出区域            _USE = 'var uhtml="' + _USE + '"; return uhtml;';            //变量传参            if (_UKE) {                for (i in _UKE) {                    (_UKE.hasOwnProperty(i)) && (_UCS += (_UCS ? "," : "") + i, _UPE.push(_UKE[i]));                }            };            _USE = Function(_UCS, _USE).apply(this.that || this, _UPE); //利用函数执行回调处理            (this.cb) && (this.cb(_USE)); //获取模版回调        }        catch (e) { throw new Error(e); }    },    /**    * 获取正则    *    * @param  {string} 正则字符串    */    re: function (URE) {        return new RegExp(URE, "g");    },    /**    * 初始化HTML模版页面 支持js内置 类似于js上的php ejs    *    * @param  {string} 正则开头    * @param  {string} 正则结束    * @param  {string} 正则中间的内容    * @param  {string} 正则结束的内容    * @return  {string} 正则内容    */    getConfig: function (US, UE, UOS, UOE) { //获取系统配置        var _UCE = this.config;        return this.re((US || "") + _UCE.s + (UOS || "") + _UCE.t + (UOE || "") + _UCE.e + (UE || ""));    },    getHtml: function () { //获取生成的html代码    },    /**    * 正则对象    *    * @param  {object} 正则设置    */    set: function (UDE) { //设置config        var i, _UCE = this.config;        for (i in _UCE) {            (UDE.hasOwnProperty(i)) && (UDE[i] = _UCE[i]);        }        return this;    }}
 |