| 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));
 
-     }));
 
- }
 
- //判断是否支持svg
 
- U.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;
 
-     }
 
- }
 
 
  |