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;
- }
- }
|