- 浏览: 336011 次
- 性别:
- 来自: 上海
-
文章分类
- 全部博客 (59)
- wicket (1)
- java (24)
- js (27)
- xml (3)
- Android (1)
- 服务器 (7)
- 数据库 (7)
- spring (1)
- hibernate (1)
- ssh (6)
- web (25)
- oracle (1)
- 函数 (2)
- mysql (1)
- 手机 (6)
- javascript (21)
- session (3)
- cookie (4)
- struts (1)
- ngnix (1)
- 软件使用 (2)
- linux (1)
- vi (1)
- 前端 (6)
- javascrip (2)
- html (3)
- js css (2)
- 正则 (1)
- ajax (1)
- toast (1)
- 消息提示 (1)
- 确认弹窗 (1)
- springmvc (1)
- 倒计时 (1)
最新评论
-
wenm168:
美观的图片上传前预览效果:http://www.anyrt.c ...
JavaScript 图片的上传前预览(兼容所有浏览器) -
口弦1992:
我的ie9并没有图片预览出来啊。
JavaScript 图片的上传前预览(兼容所有浏览器) -
axie1234567:
分享的东西很有用。
java web中实现同一帐号同一时间只能一个地点登陆(类似QQ登录的功能) -
wyl4728:
32个赞
mysql函数大全 -
yu_long:
seeker.getCountry(ip);
解析出来的 ...
根据IP地址获取所在地
此方式适用和iscroll结合使用,若用于普通加载,可以使用jquery.lazy插件,当时是因为上面领导需要纯js的代码,所以不得不放弃强大的jquery!iscroll适用于高端手机浏览器,不适用于ie !若要用请参考原作者博客:http://www.cnblogs.com/cloudgamer/archive/2010/03/03/ImagesLazyLoad.html
/*! * Cloudgamer JavaScript Library v0.1 * Copyright (c) 2009 cloudgamer * Blog: http://cloudgamer.cnblogs.com/ * Date: 2009-10-15 */ var $$, $$B, $$A, $$F, $$D, $$E, $$CE, $$S; (function(undefined){ var O, B, A, F, D, E, CE, S; /*Object*/ O = function (id) { return "string" == typeof id ? document.getElementById(id) : id; }; O.emptyFunction = function(){}; O.extend = function (destination, source, override) { if (override === undefined) override = true; for (var property in source) { if (override || !(property in destination)) { destination[property] = source[property]; } } return destination; }; O.deepextend = function (destination, source) { for (var property in source) { var copy = source[property]; if ( destination === copy ) continue; if ( typeof copy === "object" ){ destination[property] = arguments.callee( destination[property] || {}, copy ); }else{ destination[property] = copy; } } return destination; }; /*from youa*/ O.wrapper = function(me, parent) { var ins = function() { me.apply(this, arguments); }; var subclass = function() {}; subclass.prototype = parent.prototype; ins.prototype = new subclass; return ins; }; /*Browser*/ /*from youa*/ B = (function(ua){ var b = { msie: /msie/.test(ua) && !/opera/.test(ua), opera: /opera/.test(ua), safari: /webkit/.test(ua) && !/chrome/.test(ua), firefox: /firefox/.test(ua), chrome: /chrome/.test(ua) }; var vMark = ""; for (var i in b) { if (b[i]) { vMark = "safari" == i ? "version" : i; break; } } b.version = vMark && RegExp("(?:" + vMark + ")[\\/: ]([\\d.]+)").test(ua) ? RegExp.$1 : "0"; b.ie = b.msie; b.ie6 = b.msie && parseInt(b.version, 10) == 6; b.ie7 = b.msie && parseInt(b.version, 10) == 7; b.ie8 = b.msie && parseInt(b.version, 10) == 8; return b; })(window.navigator.userAgent.toLowerCase()); /*Array*/ A = function(){ var ret = { isArray: function( obj ) { return Object.prototype.toString.call(obj) === "[object Array]"; }, indexOf: function( array, elt, from ){ if (array.indexOf) { return isNaN(from) ? array.indexOf(elt) : array.indexOf(elt, from); } else { var len = array.length; from = isNaN(from) ? 0 : from < 0 ? Math.ceil(from) + len : Math.floor(from); for ( ; from < len; from++ ) { if ( array[from] === elt ) return from; } return -1; } }, lastIndexOf: function( array, elt, from ){ if (array.lastIndexOf) { return isNaN(from) ? array.lastIndexOf(elt) : array.lastIndexOf(elt, from); } else { var len = array.length; from = isNaN(from) || from >= len - 1 ? len - 1 : from < 0 ? Math.ceil(from) + len : Math.floor(from); for ( ; from > -1; from-- ) { if ( array[from] === elt ) return from; } return -1; } } }; function each( object, callback ) { if ( undefined === object.length ){ for ( var name in object ) { if (false === callback( object[name], name, object )) break; } } else { for ( var i = 0, len = object.length; i < len; i++ ) { if (i in object) { if (false === callback( object[i], i, object )) break; } } } }; each({ forEach: function( object, callback, thisp ){ each( object, function(){ callback.apply(thisp, arguments); } ); }, map: function( object, callback, thisp ){ var ret = []; each( object, function(){ ret.push(callback.apply(thisp, arguments)); }); return ret; }, filter: function( object, callback, thisp ){ var ret = []; each( object, function(item){ callback.apply(thisp, arguments) && ret.push(item); }); return ret; }, every: function( object, callback, thisp ){ var ret = true; each( object, function(){ if ( !callback.apply(thisp, arguments) ){ ret = false; return false; }; }); return ret; }, some: function( object, callback, thisp ){ var ret = false; each( object, function(){ if ( callback.apply(thisp, arguments) ){ ret = true; return false; }; }); return ret; } }, function(method, name){ ret[name] = function( object, callback, thisp ){ if (object[name]) { return object[name]( callback, thisp ); } else { return method( object, callback, thisp ); } }; }); return ret; }(); /*Function*/ F = (function(){ var slice = Array.prototype.slice; return { bind: function( fun, thisp ) { var args = slice.call(arguments, 2); return function() { return fun.apply(thisp, args.concat(slice.call(arguments))); }; }, bindAsEventListener: function( fun, thisp ) { var args = slice.call(arguments, 2); return function(event) { return fun.apply(thisp, [E.fixEvent(event)].concat(args)); }; } }; })(); /*Dom*/ D = { getScrollTop: function(node) { var doc = node ? node.ownerDocument : document; return doc.documentElement.scrollTop || doc.body.scrollTop; }, getScrollLeft: function(node) { var doc = node ? node.ownerDocument : document; return doc.documentElement.scrollLeft || doc.body.scrollLeft; }, contains: document.defaultView ? function (a, b) { return !!( a.compareDocumentPosition(b) & 16 ); } : function (a, b) { return a != b && a.contains(b); }, rect: function(node){ var left = 0, top = 0, right = 0, bottom = 0; //ie8的getBoundingClientRect获取不准确 if ( !node.getBoundingClientRect || B.ie8 ) { var n = node; while (n) { left += n.offsetLeft, top += n.offsetTop; n = n.offsetParent; }; right = left + node.offsetWidth; bottom = top + node.offsetHeight; } else { var rect = node.getBoundingClientRect(); left = right = D.getScrollLeft(node); top = bottom = D.getScrollTop(node); left += rect.left; right += rect.right; top += rect.top; bottom += rect.bottom; }; return { "left": left, "top": top, "right": right, "bottom": bottom }; }, clientRect: function(node) { var rect = D.rect(node), sLeft = D.getScrollLeft(node), sTop = D.getScrollTop(node); rect.left -= sLeft; rect.right -= sLeft; rect.top -= sTop; rect.bottom -= sTop; return rect; }, curStyle: document.defaultView ? function (elem) { return document.defaultView.getComputedStyle(elem, null); } : function (elem) { return elem.currentStyle; }, getStyle: document.defaultView ? function (elem, name) { var style = document.defaultView.getComputedStyle(elem, null); return name in style ? style[ name ] : style.getPropertyValue( name ); } : function (elem, name) { var style = elem.style, curStyle = elem.currentStyle; //透明度 from youa if ( name == "opacity" ) { if ( /alpha\(opacity=(.*)\)/i.test(curStyle.filter) ) { var opacity = parseFloat(RegExp.$1); return opacity ? opacity / 100 : 0; } return 1; } if ( name == "float" ) { name = "styleFloat"; } var ret = curStyle[ name ] || curStyle[ S.camelize( name ) ]; //单位转换 from jqury if ( !/^-?\d+(?:px)?$/i.test( ret ) && /^\-?\d/.test( ret ) ) { var left = style.left, rtStyle = elem.runtimeStyle, rsLeft = rtStyle.left; rtStyle.left = curStyle.left; style.left = ret || 0; ret = style.pixelLeft + "px"; style.left = left; rtStyle.left = rsLeft; } return ret; }, setStyle: function(elems, style, value) { if ( !elems.length ) { elems = [ elems ]; } if ( typeof style == "string" ) { var s = style; style = {}; style[s] = value; } A.forEach( elems, function(elem ) { for (var name in style) { var value = style[name]; if (name == "opacity" && B.ie) { //ie透明度设置 from jquery elem.style.filter = (elem.currentStyle && elem.currentStyle.filter || "").replace( /alpha\([^)]*\)/, "" ) + " alpha(opacity=" + (value * 100 | 0) + ")"; } else if (name == "float") { elem.style[ B.ie ? "styleFloat" : "cssFloat" ] = value; } else { elem.style[ S.camelize( name ) ] = value; } }; }); }, getSize: function(elem) { var width = elem.offsetWidth, height = elem.offsetHeight; if ( !width && !height ) { var repair = !D.contains( document.body, elem ), parent; if ( repair ) {//如果元素不在body上 parent = elem.parentNode; document.body.insertBefore(elem, document.body.childNodes[0]); } var style = elem.style, cssShow = { position: "absolute", visibility: "hidden", display: "block", left: "-9999px", top: "-9999px" }, cssBack = { position: style.position, visibility: style.visibility, display: style.display, left: style.left, top: style.top }; D.setStyle( elem, cssShow ); width = elem.offsetWidth; height = elem.offsetHeight; D.setStyle( elem, cssBack ); if ( repair ) { parent ? parent.appendChild(elem) : document.body.removeChild(elem); } } return { "width": width, "height": height }; } }; /*Event*/ E = (function(){ /*from dean edwards*/ var addEvent, removeEvent, guid = 1, storage = function( element, type, handler ){ if (!handler.$$guid) handler.$$guid = guid++; if (!element.events) element.events = {}; var handlers = element.events[type]; if (!handlers) { handlers = element.events[type] = {}; if (element["on" + type]) { handlers[0] = element["on" + type]; } } }; if ( window.addEventListener ) { var fix = { "mouseenter": "mouseover", "mouseleave": "mouseout" }; addEvent = function( element, type, handler ){ if ( type in fix ) { storage( element, type, handler ); var fixhandler = element.events[type][handler.$$guid] = function(event){ var related = event.relatedTarget; if ( !related || (element != related && !(element.compareDocumentPosition(related) & 16)) ){ handler.call(this, event); } }; element.addEventListener(fix[type], fixhandler, false); } else { element.addEventListener(type, handler, false); }; }; removeEvent = function( element, type, handler ){ if ( type in fix ) { if (element.events && element.events[type]) { element.removeEventListener(fix[type], element.events[type][handler.$$guid], false); delete element.events[type][handler.$$guid]; } } else { element.removeEventListener(type, handler, false); }; }; } else { addEvent = function( element, type, handler ){ storage( element, type, handler ); element.events[type][handler.$$guid] = handler; element["on" + type] = handleEvent; }; removeEvent = function( element, type, handler ){ if (element.events && element.events[type]) { delete element.events[type][handler.$$guid]; } }; function handleEvent() { var returnValue = true, event = fixEvent(); var handlers = this.events[event.type]; for (var i in handlers) { this.$$handleEvent = handlers[i]; if (this.$$handleEvent(event) === false) { returnValue = false; } } return returnValue; }; } function fixEvent(event) { if (event) return event; event = window.event; event.pageX = event.clientX + D.getScrollLeft(event.srcElement); event.pageY = event.clientY + D.getScrollTop(event.srcElement); event.target = event.srcElement; event.stopPropagation = stopPropagation; event.preventDefault = preventDefault; var relatedTarget = { "mouseout": event.toElement, "mouseover": event.fromElement }[ event.type ]; if ( relatedTarget ){ event.relatedTarget = relatedTarget;} return event; }; function stopPropagation() { this.cancelBubble = true; }; function preventDefault() { this.returnValue = false; }; return { "addEvent": addEvent, "removeEvent": removeEvent, "fixEvent": fixEvent }; })(); /*CustomEvent*/ CE = (function(){ var guid = 1; return { addEvent: function( object, type, handler ){ if (!handler.$$$guid) handler.$$$guid = guid++; if (!object.cusevents) object.cusevents = {}; if (!object.cusevents[type]) object.cusevents[type] = {}; object.cusevents[type][handler.$$$guid] = handler; }, removeEvent: function( object, type, handler ){ if (object.cusevents && object.cusevents[type]) { delete object.cusevents[type][handler.$$$guid]; } }, fireEvent: function( object, type ){ if (!object.cusevents) return; var args = Array.prototype.slice.call(arguments, 2), handlers = object.cusevents[type]; for (var i in handlers) { handlers[i].apply(object, args); } }, clearEvent: function( object ){ if (!object.cusevents) return; for (var type in object.cusevents) { var handlers = object.cusevents[type]; for (var i in handlers) { handlers[i] = null; } object.cusevents[type] = null; } object.cusevents = null; } }; })(); /*String*/ S = { camelize: function(s){ return s.replace(/-([a-z])/ig, function(all, letter) { return letter.toUpperCase(); }); } }; /*System*/ // remove css image flicker if (B.ie6) { try { document.execCommand("BackgroundImageCache", false, true); } catch(e) {} }; /*define*/ $$ = O; $$B = B; $$A = A; $$F = F; $$D = D; $$E = E; $$CE = CE; $$S = S; })(); var LazyLoad = function(elems, options) { //初始化程序 this._initialize(elems, options); //如果没有元素就退出 if ( this.isFinish() ) return; //初始化模式设置 this._initMode(); //进行第一次触发 this.resize(true); }; LazyLoad.prototype = { //初始化程序 _initialize: function(elems, options) { this._elems = elems;//加载元素集合 this._rect = {};//容器位置参数对象 this._range = {};//加载范围参数对象 this._loadData = null;//加载程序 this._timer = null;//定时器 this._lock = false;//延时锁定 //静态使用属性 this._index = 0;//记录索引 this._direction = 0;//记录方向 this._lastScroll = { "left": 0, "top": 0 };//记录滚动值 this._setElems = function(){};//重置元素集合程序 var opt = this._setOptions(options); this.delay = opt.delay; this.threshold = opt.threshold; this.beforeLoad = opt.beforeLoad; this._onLoadData = opt.onLoadData; this._container = this._initContainer($$(this.options.container));//容器 }, //设置默认属性 _setOptions: function(options) { this.options = {//默认值 container: window,//容器 mode: "dynamic",//模式 threshold: 0,//加载范围阈值 delay: 100,//延时时间 beforeLoad: function(){},//加载前执行 onLoadData: function(){}//显示加载数据 }; return $$.extend(this.options, options || {}); }, //初始化容器设置 _initContainer: function(container) { var doc = document, isWindow = container == window || container == doc || !container.tagName || (/^(?:body|html)$/i).test( container.tagName ); if ( isWindow ) { container = doc.compatMode == 'CSS1Compat' ? doc.documentElement : doc.body; } //定义执行方法 var oThis = this, width = 0, height = 0; this.load = $$F.bind( this._load, this ); this.resize = $$F.bind( this._resize, this ); this.delayLoad = function() { oThis._delay( oThis.load ); }; this.delayResize = function(){//防止重复触发bug var clientWidth = container.clientWidth, clientHeight = container.clientHeight; if( clientWidth != width || clientHeight != height ) { width = clientWidth; height = clientHeight; oThis._delay( oThis.resize ); } }; //记录绑定元素方便移除 this._binder = isWindow ? window : container; //绑定事件 $$E.addEvent( this._binder, "scroll", this.delayLoad ); isWindow && $$E.addEvent( this._binder, "resize", this.delayResize ); //获取容器位置参数函数 this._getContainerRect = isWindow && ( "innerHeight" in window ) ? function(){ return { "left": 0, "right": window.innerWidth, "top": 0, "bottom":window.innerHeight };} : function(){ return oThis._getRect(container); } ; //设置获取scroll值函数 this._getScroll = isWindow ? function() { return { "left": $$D.getScrollLeft(), "top": $$D.getScrollTop() };} : function() { return { "left": container.scrollLeft, "top": container.scrollTop };}; return container; }, //初始化模式设置 _initMode: function() { switch ( this.options.mode.toLowerCase() ) { case "vertical" ://垂直方向 this._initStatic( "vertical", "vertical" ); break; case "horizontal" ://水平方向 this._initStatic( "horizontal", "horizontal" ); break; case "cross" : case "cross-vertical" ://垂直正交方向 this._initStatic( "cross", "vertical" ); break; case "cross-horizontal" ://水平正交方向 this._initStatic( "cross", "horizontal" ); break; case "dynamic" ://动态加载 default : this._loadData = this._loadDynamic; } }, //初始化静态加载设置 _initStatic: function(mode, direction) { //设置模式 var isVertical = direction == "vertical"; if ( mode == "cross" ) { this._crossDirection = $$F.bind( this._getCrossDirection, this, isVertical ? "_verticalDirection" : "_horizontalDirection", isVertical ? "_horizontalDirection" : "_verticalDirection" ); } //设置元素 var pos = isVertical ? "top" : "left", sortFunction = function( x, y ) { return x._rect[ pos ] - y._rect[ pos ]; }, getRect = function( elem ) { elem._rect = this._getRect(elem); return elem; }; this._setElems = function() {//转换数组并排序 this._elems = $$A.map( this._elems, getRect, this ).sort( sortFunction ); }; //设置加载函数 this._loadData = $$F.bind( this._loadStatic, this, "_" + mode + "Direction", $$F.bind( this._outofRange, this, mode, "_" + direction + "BeforeRange" ), $$F.bind( this._outofRange, this, mode, "_" + direction + "AfterRange" ) ); }, //延时程序 _delay: function(run) { clearTimeout(this._timer); if ( this.isFinish() ) return; var oThis = this, delay = this.delay; if ( this._lock ) {//防止连续触发 this._timer = setTimeout( function(){ oThis._delay(run); }, delay ); } else { this._lock = true; run(); setTimeout( function(){ oThis._lock = false; }, delay ); } }, //重置范围参数并加载数据 _resize: function(change) { if ( this.isFinish() ) return; this._rect = this._getContainerRect(); //位置改变的话需要重置元素位置 if ( change ) { this._setElems(); } this._load(true); }, //加载程序 _load: function(force) { if ( this.isFinish() ) return; var rect = this._rect, scroll = this._getScroll(), left = scroll.left, top = scroll.top, threshold = Math.max( 0, this.threshold | 0 ); //记录原始加载范围参数 this._range = { top: rect.top + top - threshold, bottom: rect.bottom + top + threshold, left: rect.left + left - threshold, right: rect.right + left + threshold }; //加载数据 this.beforeLoad(); this._loadData(force); }, //动态加载程序 _loadDynamic: function() { this._elems = $$A.filter( this._elems, function( elem ) { return !this._insideRange( elem ); }, this ); }, //静态加载程序 _loadStatic: function(direction, beforeRange, afterRange, force) { //获取方向 direction = this[ direction ]( force ); if ( !direction ) return; //根据方向历遍图片对象 var elems = this._elems, i = this._index, begin = [], middle = [], end = []; if ( direction > 0 ) {//向后滚动 begin = elems.slice( 0, i ); for ( var len = elems.length ; i < len; i++ ) { if ( afterRange( middle, elems[i] ) ) { end = elems.slice( i + 1 ); break; } } i = begin.length + middle.length - 1; } else {//向前滚动 end = elems.slice( i + 1 ); for ( ; i >= 0; i-- ) { if ( beforeRange( middle, elems[i] ) ) { begin = elems.slice( 0, i ); break; } } middle.reverse(); } this._index = Math.max( 0, i ); this._elems = begin.concat( middle, end ); }, //垂直和水平滚动方向获取程序 _verticalDirection: function(force) { return this._getDirection( force, "top" ); }, _horizontalDirection: function(force) { return this._getDirection( force, "left" ); }, //滚动方向获取程序 _getDirection: function(force, scroll) { var now = this._getScroll()[ scroll ], _scroll = this._lastScroll; if ( force ) { _scroll[ scroll ] = now; this._index = 0; return 1; } var old = _scroll[ scroll ]; _scroll[ scroll ] = now; return now - old; }, //cross滚动方向获取程序 _getCrossDirection: function(primary, secondary, force) { var direction; if ( !force ) { direction = this[ primary ](); secondary = this[ secondary ](); if ( !direction && !secondary ) {//无滚动 return 0; } else if ( !direction ) {//次方向滚动 if ( this._direction ) { direction = -this._direction;//用上一次的相反方向 } else { force = true;//没有记录过方向 } } else if ( secondary && direction * this._direction >= 0 ) { force = true;//同时滚动并且方向跟上一次滚动相同 } } if ( force ) { this._lastScroll = this._getScroll(); this._index = 0; direction = 1; } return ( this._direction = direction ); }, //判断是否加载范围内 _insideRange: function(elem, mode) { var range = this._range, rect = elem._rect || this._getRect(elem), insideH = rect.right >= range.left && rect.left <= range.right, insideV = rect.bottom >= range.top && rect.top <= range.bottom, inside = { "horizontal": insideH, "vertical": insideV, "cross": insideH && insideV }[ mode || "cross" ]; //在加载范围内加载数据 if ( inside ) { this._onLoadData(elem); } return inside; }, //判断是否超过加载范围 _outofRange: function(mode, compare, middle, elem) { if ( !this._insideRange( elem, mode ) ) { middle.push(elem); return this[ compare ]( elem._rect ); } }, _horizontalBeforeRange: function(rect) { return rect.right < this._range.left; }, _horizontalAfterRange: function(rect) { return rect.left > this._range.right; }, _verticalBeforeRange: function(rect) { return rect.bottom < this._range.top; }, _verticalAfterRange: function(rect) { return rect.top > this._range.bottom; }, //获取位置参数 _getRect: function(node) { var n = node, left = 0, top = 0; while (n) { left += n.offsetLeft; top += n.offsetTop; n = n.offsetParent; }; return { "left": left, "right": left + node.offsetWidth, "top": top, "bottom": top + node.offsetHeight }; }, //是否完成加载 isFinish: function() { if ( !this._elems || !this._elems.length ) { this.dispose(); return true; } else { return false; } }, //销毁程序 dispose: function(load) { clearTimeout(this._timer); if ( this._elems || this._binder ) { //加载全部元素 if ( load && this._elems ) { $$A.forEach( this._elems, this._onLoadData, this ); } //清除关联 $$E.removeEvent( this._binder, "scroll", this.delayLoad ); $$E.removeEvent( this._binder, "resize", this.delayResize ); this._elems = this._binder = null; } } }; var ImagesLazyLoad = $$.wrapper(function(options) { this._initialize( options ); //如果没有元素就退出 if ( this.isFinish() ) return; //初始化模式设置 this._initMode(); //进行第一次触发 this.resize(true); }, LazyLoad); $$.extend( ImagesLazyLoad.prototype, { //初始化程序 _initialize: function(options) { LazyLoad.prototype._initialize.call(this, [], options); //设置子类属性 var opt = this.options; this.onLoad = opt.onLoad; var attribute = this._attribute = opt.attribute; //设置加载图片集合 var getSrc = opt.getSrc, filter = $$F.bind( this._filter, this, opt["class"], getSrc ? function(img){ return getSrc(img); } : function(img){ return img.getAttribute( attribute ) || img.src; }, opt.holder ); this._elems = $$A.filter( opt.images || this._container.getElementsByTagName("img"), filter ); //判断属性是否已经加载的方法 this._hasAttribute = $$B.ie6 || $$B.ie7 ? function(img){ return attribute in img; } : function(img){ return img.hasAttribute( attribute ); }; }, //设置默认属性 _setOptions: function(options) { return LazyLoad.prototype._setOptions.call(this, $$.extend({//默认值 images: undefined,//图片集合 attribute: "data-src",//保存原图地址的自定义属性 holder: "",//占位图 "class": "",//筛选样式 getSrc: undefined,//获取原图地址程序 onLoad: function(){}//加载时执行 }, $$.extend( options, { onLoadData: this._onLoadData }))); }, //筛选整理图片对象 _filter: function(className, getSrc, holder, img) { if ( className && (" " + img.className + " ").indexOf(" " + className + " ") == -1 ) return false;//排除样式不对应的 //获取原图地址 var src = getSrc(img); if ( !src ) return false;//排除src不存在的 if ( src == img.src ) { //排除已经加载或不能停止加载的 if ( img.complete || $$B.chrome || $$B.safari ) return false; img.removeAttribute("src");//移除src } if ( holder ) { img.src = holder; } //用自定义属性记录原图地址 img.setAttribute( this._attribute, src ); return true; }, //显示图片 _onLoadData: function(img) { var attribute = this._attribute; if ( this._hasAttribute( img ) ) { img.src = img.getAttribute( attribute ); img.removeAttribute( attribute ); this.onLoad( img ); } } }); //图片部分懒加载 function lazyLoadImg(){ new ImagesLazyLoad({ container: "wrapper", mode: "vertical", holder: projectImageUrl+"/sftwap/image/loading.gif", onLoad: function(img) {/*alert(img.src);*/} }); }
var myScroll;//图片懒加载 //lazyLoadingImages(); function loaded(){ myScroll = new iScroll("wrapper",{ //useTransform: false, //checkDOMChanges:false, onBeforeScrollStart: function (e) { var target = e.target; while (target.nodeType != 1) target = target.parentNode; if (target.tagName != 'SELECT' && target.tagName != 'INPUT' && target.tagName != 'TEXTAREA') e.preventDefault(); }, onScrollEnd:function(){ lazyLoadImg(); } }); } document.addEventListener('touchmove', function (e) {e.preventDefault();}, false); document.addEventListener('DOMContentLoaded',function(){loaded();lazyLoadImg();},false);
发表评论
-
简单倒计时模板插件
2017-07-12 12:01 658Countdown.js (function() { ... -
简单上传文件插件
2017-07-12 11:46 711team777.upload.js js: ; ... -
简单的toast提示,确认弹窗,显示图片预览插件
2017-07-12 11:29 889JS /** * team777 dialog plu ... -
简单数字键盘
2017-07-12 11:20 640好久没有写博客了,最近有个需求关于数字键盘的,找了下网上的 ... -
简化的原生ajax
2015-03-23 14:25 673/* * * path: seaAjax.js ... -
简单入门-JavaScript正则表达式
2015-03-23 14:19 889什么是正则表达式?这个问题可以参见:“正则表达式30分钟入门 ... -
Fxtpl v1.0 繁星前端模板引擎(非原创)
2014-08-18 13:48 3149Fxtpl 全新的JS模板引擎 Download t ... -
WEB前端开发数据模拟工具JOJO
2014-08-15 18:28 2497注:图片见压缩包中的word文档! 前端数据模拟工 ... -
利用html5进行城市定位!aqi指数的获取
2014-07-08 17:52 21523<html><head> < ... -
seajs打包部署工具spm的使用总结
2014-06-30 14:22 959相信使用seajs的好处大家都是知道的,接触seajs好像 ... -
eclispe 编辑XML时,输入<无法自动提示的修复
2014-02-20 14:40 1031eclispe 当编辑XML时,一 ... -
javaScript的性能优化
2014-01-17 14:05 1306随着网络的发展,网速 ... -
秒杀倒计时控件
2014-01-17 11:20 3186/** * User: yongwang * Da ... -
Nginx 下缓存静态文件(如css js)(转)
2013-05-31 13:48 13969目的:缓存nginx服务器的静态文件。如css,js, ... -
百度地图API文档
2012-11-13 18:31 1172sdfsfsdf -
可以用来解析字符串表达式的包
2012-10-16 10:57 2139import com.singularsys.jep.J ... -
JavaScript 图片的上传前预览(兼容所有浏览器)
2012-10-11 09:17 52571功能描述 通过 JavaScript 实现图片的 ... -
iscroll实现图片的循环滑动
2012-08-31 10:19 2243<div class="gexian" ... -
iScroll框架的修改
2012-06-29 16:05 1840最近做的一个项目,用到了iScroll框架,在使用过程中 ... -
客户端元素滑动和滚动效果实现
2012-06-29 15:55 2775最近一直在搞一些有关元素动态展示的功能,这么做是为了增加 ...
相关推荐
移动开发_Android_基础框架_SAFApi组件开发_1742847786.zip
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
app开发
MobaXterm安装包
智慧园区,作为智慧城市的重要组成部分,正借助5G、云计算、大数据等前沿技术,实现园区的全面智慧化升级。它不仅仅是技术的堆砌,更是园区管理模式和服务理念的革新。智慧园区通过构建统一的大数据平台,实现园区内各类数据的整合与共享,让管理者能够全局掌握园区运营状态,实现人、事、物的穿透式管理。 在5G技术的加持下,智慧园区的特色应用得以更加广泛和深入地开展。从便捷通行到智慧物联,从楼宇自控到企业服务,5G智慧园区为园区内的企业和员工提供了前所未有的便捷与高效。刷脸通行、车牌识别、访客线上预约等技术的应用,不仅提升了园区的安全等级,更让通行变得简单快捷。而智慧垃圾桶、路灯等物联网设备的引入,则让园区的环境管理更加智能化、精细化。此外,5G智慧园区还通过无人机巡检、无人驾驶等创新应用,为园区的安全管理、物资配送等方面带来了全新的解决方案。 值得一提的是,智慧园区的建设并不仅仅局限于硬件设施的升级,更在于服务模式的创新。通过园区APP、在线服务平台等渠道,智慧园区实现了园区服务的线上化、便捷化,让企业和员工能够随时随地享受到园区提供的各类服务。这种以人为本的服务理念,不仅提升了园区的整体服务水平,更增强了园区的吸引力和竞争力。总之,5G智慧园区的建设为园区的可持续发展注入了新的活力,也为未来城市的发展提供了有益的借鉴和启示。
C基础day9 思维导图
内容概要:本文档详细介绍了使用Simulink进行两个物理问题的仿真建模。第一个任务是模拟一个球体从高空落下的终端速度,通过建立重力与空气阻力的平衡模型,利用MATLAB代码构建Simulink模型,最终计算出终端速度。第二个任务是基于提供的加速度数据,通过两次积分计算物体的速度和位置,同样使用MATLAB代码实现了Simulink模型。每个任务都包含了详细的数学公式推导、参数设置以及Simulink模块的具体连接方法。仿真结果显示,终端速度约为53.6 m/s,而1秒后的速度和位置则取决于输入的加速度数据。 适合人群:对Simulink仿真工具感兴趣的工程技术人员、科研工作者以及相关专业的学生。 使用场景及目标:适用于需要进行物理系统仿真、信号处理的研究项目或教学实验。主要目标是帮助读者掌握Simulink的基本操作和应用技巧,同时加深对物理现象的理解。 其他说明:文中提供了完整的MATLAB代码,方便读者直接复制并在自己的环境中运行测试。此外,还给出了详细的中文注释,有助于初学者更好地理解各个步骤的功能和意义。
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
音乐_安卓开发_本地音乐_播放器应用μsic_1742860435.zip
Lightweight and Efficient: The backbone of the TTS Diffusion Transformer has only 0.45B parameters. Ultra High-Quality Voice Cloning: See the demo video below! We also report results of recent TTS models on the Seed test sets in the following table. Bilingual Support: Supports both Chinese and English, and code-switching. Controllable: Supports accent intensity control and fine-grained pronunciation/duration adjustment (coming soon).
博客_ionic20_移动端_应用开发模板_1742847485.zip
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
内容概要:本文详细介绍了复现论文《Fair Semi-distributed Resource Allocation Scheme over Relay-Enhanced OFDMA Networks》的代码实现。主要内容包括系统模型构建(定义基站、中继站、移动终端及其关联关系)、资源分配算法(半分布式资源分配、改进的两阶段资源分配)和公平性调度机制(吞吐量计算、效用函数)。此外,还进行了仿真实验,对比了所提方案与集中式方案和机会主义方案在吞吐量、公平性和反馈开销方面的性能表现。最后,通过随机分布场景下的仿真进一步验证了方案的有效性和实际部署的可行性。 适合人群:通信工程专业研究人员、无线网络优化工程师、对OFDMA技术和资源分配算法感兴趣的学者和技术人员。 使用场景及目标:适用于研究和开发中继增强的OFDMA网络资源分配算法,旨在提高系统的吞吐量和公平性,降低反馈开销。目标是在大规模网络环境中实现高效、公平的资源分配。 其他说明:文中提供了详细的代码实现步骤和仿真结果,有助于读者深入理解算法原理并进行实验验证。
2025大模型训练性能瓶颈定位流程案例
内容概要:本文档提供了20道蓝桥杯Python竞赛真题及其详细解答,涉及质因数分解、分数计算、特别数求和、数字三角形、约数个数、草的生长模拟、工作时长计算、互质数统计、阶乘和判定、公因数匹配、直线计算、分糖果、矩阵填充、旅行计划优化、阶乘末尾零计数、最长递增子序列、最长公共子序列、最长回文子串、最长公共前缀和最长公共后缀等多个经典算法问题。每个题目都附有完整的代码实现和解释,帮助参赛者深入理解和掌握相关知识点。 适合人群:准备参加蓝桥杯或其他编程竞赛的学生和程序员,尤其是对Python编程有一定基础并希望提高算法能力的人群。 使用场景及目标:①作为赛前复习资料,巩固基础知识;②通过实际编程练习提升算法思维和解决问题的能力;③熟悉竞赛常见题型,增强应对复杂问题的信心。 其他说明:文档不仅提供了解答思路,还包含了具体的代码实现,有助于读者更好地理解和应用所学知识。同时,这些问题覆盖了多种数据结构和算法思想,能够全面锻炼编程技能。
网络工程师(中级)是软考(计算机技术与软件专业技术资格考试)的一部分,主要考察计算机网络基础、网络安全、网络管理、操作系统、数据库等内容,考试分为上午的基础知识选择题和下午的案例分析题。
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。