之前在網上找那種下拉刷新,上拉加載的插件,有一款IScroll,但是用起來太麻煩,於是就自己寫了款,但依賴於jquery.js,bug肯定有,希望評論提出。
推薦一個簡潔且文檔的插件:傳送門
因為我這個不算一個很穩定的東西,只是大概能用
js:
/* 簡潔的下拉刷新,上拉加載插件 Author:myEsn2E9 QQ:865540141 Date:2016-5-17 */
; !(function () {
var defaultParame = {
positionY: 0,
positionTop: 0,
positionBottom: 0,
screenY: 0,
topSpeed: .6,
animateSpeed: 800,
whenThisHeightExecuteCallback: 50,
refreshDom: {
prop: '.refresh',
startText: '下拉刷新',
ingText: '更新中',
endText: '釋放更新'
},
loadDom: {
prop: '.load',
startText: '上拉加載',
ingText: '加載中',
endText: '釋放加載'
},
isStartRefresh: false,
isStartLoad: false,
isRefreshIng: false,
isLoadIng: false,
moveArray: new Array(),
continueMoveDirection: '',
loadImg: {
src: '',
style: 'width: 15px; height: 15px; vertical-align: middle;'
}
},
parame = {},
prop = ''
callback = {
refresh: null,
load: null
};
function createDom() {
var defaultcss = 'height: 0; display: none; text-align: center; font-size: 12px; ';
$('<div class="' + parame.refreshDom.prop.replace('.', '') + '" style="' + defaultcss + '">' + parame.refreshDom.startText + '</div>').insertBefore($(prop));
$('<div class="' + parame.loadDom.prop.replace('.', '') + '" style="' + defaultcss + '">' + parame.loadDom.startText + '</div>').insertAfter($(prop));
}
var method = {
refreshMove: function () {
if (parame.isStartLoad) {
console.log('已經在加載了,不能刷新');
return;
}
console.log('刷新開始');
parame.isStartRefresh = true;
(parame.continueMoveDirection === 'top') && (parame.positionTop -= parame.topSpeed);
(parame.continueMoveDirection === 'bottom') && (parame.positionTop += parame.topSpeed);
$(prop).prev(parame.refreshDom.prop).fadeIn(parame.animateSpeed);
$(prop).css({ 'position': 'relative' }).animate({ 'top': parame.positionTop }, 0);
$(prop).prev(parame.refreshDom.prop)
.text(parame.positionTop >= parame.whenThisHeightExecuteCallback
? parame.refreshDom.endText : parame.refreshDom.startText);
},
loadMove: function () {
if (parame.isStartRefresh) {
console.log('已經在刷新了,不能加載');
return;
}
parame.isStartLoad = true;
console.log('加載開始');
(parame.continueMoveDirection === 'top') && (parame.positionBottom += parame.topSpeed);
(parame.continueMoveDirection === 'bottom') && (parame.positionBottom -= parame.topSpeed);
$(prop).next(parame.loadDom.prop).fadeIn(parame.animateSpeed);
$(prop).css({ 'position': 'relative' }).animate({ 'bottom': parame.positionBottom }, 0);
$(prop).next(parame.loadDom.prop)
.text(parame.positionBottom >= parame.whenThisHeightExecuteCallback
? parame.loadDom.endText : parame.loadDom.startText);
},
closeRefresh: function () {
parame.isStartRefresh = parame.isRefreshIng = false;
parame.positionTop = 0;//重置偏移量
parame.continueMoveDirection = '';
parame.moveArray = new Array();
$(prop).animate({ 'top': 0 }, parame.animateSpeed, function () {
$(prop).removeAttr('style').prev(parame.refreshDom.prop).fadeOut(parame.animateSpeed);
console.log('刷新結束');
});
},
closeLoad: function () {
parame.isStartLoad = parame.isLoadIng = false;
parame.positionBottom = 0;//重置偏移量
parame.continueMoveDirection = '';
parame.moveArray = new Array();
$(prop).animate({ 'bottom': 0 }, parame.animateSpeed, function () {
$(prop).removeAttr('style').next(parame.loadDom.prop).fadeOut(parame.animateSpeed);
console.log('加載結束');
});
},
refreshIng: function () {
console.log(parame.refreshDom.ingText);
parame.isStartRefresh = parame.isRefreshIng = true;
$(prop).prev(parame.refreshDom.prop)
.html('<img src="' + parame.loadImg.src + '" style="' + parame.loadImg.style + '"/>' + parame.refreshDom.ingText);
$(prop).css({ 'position': 'relative' }).animate({ 'top': parame.whenThisHeightExecuteCallback }, parame.animateSpeed);
callback.refresh();
},
loadIng: function () {
console.log(parame.loadDom.ingText);
parame.isStartLoad = parame.isLoadIng = true;
$(prop).next(parame.loadDom.prop)
.html('<img src="' + parame.loadImg.src + '" style="' + parame.loadImg.style + '"/>' + parame.refreshDom.ingText);
$(prop).css({ 'position': 'relative' }).animate({ 'bottom': parame.whenThisHeightExecuteCallback }, parame.animateSpeed);
callback.load();
},
cancel: function () {
console.log('滑動時受到了傷害');
parame.isStartRefresh = parame.isStartLoad = parame.isRefreshIng = parame.isLoadIng = false;
parame.positionTop = parame.positionBottom = 0;//重置偏移量
parame.continueMoveDirection = '';
parame.moveArray = new Array();
$(prop).animate({ 'top': 0, 'bottom': 0 }, parame.animateSpeed, function () {
$(prop).removeAttr('style');
$(prop).prev(parame.refreshDom.prop).fadeOut(parame.animateSpeed);
$(prop).next(parame.loadDom.prop).fadeOut(parame.animateSpeed);
});
},
isRefreshBug: function () {
return !parame.isRefreshIng
&& $(prop).prev(parame.refreshDom.prop).css('display') != 'none'
&& parame.positionTop < parame.whenThisHeightExecuteCallback;
},
isLoadBug: function () {
return !parame.isLoadIng
&& $(prop).next(parame.loadDom.prop).css('display') != 'none'
&& parame.positionBottom < parame.whenThisHeightExecuteCallback;
}
};
function event() {
$(prop).unbind('touchstart touchmove touchend touchcancel')
.on('touchstart', function (e) {
console.log('開始滑動');
parame.screenY = e.originalEvent.targetTouches[0].screenY;
})
.on('touchmove', function (e) {
console.log('滑動中');
if (parame.isRefreshIng || parame.isLoadIng) {
console.log('已經在刷新/加載了,禁止滑動');
return;
}
parame.positionY = window.scrollY;
parame.moveArray.push(e.originalEvent.targetTouches[0].screenY);
if (parame.moveArray.length > 1) {
if (e.originalEvent.targetTouches[0].screenY > parame.moveArray[parame.moveArray.length - 2]) {//-2是因為本次移動的y軸數值位於該數組的最后一位
parame.continueMoveDirection = 'bottom';
} else if (e.originalEvent.targetTouches[0].screenY < parame.moveArray[parame.moveArray.length - 2]) {
parame.continueMoveDirection = 'top';
} else {
parame.continueMoveDirection = '';
}
} else {
parame.continueMoveDirection = '';
}
console.log(parame.continueMoveDirection);
if (parame.positionY === 0 && (($(document).height() - $(window).height()) == 0)) {//沒有滾動條的時候
//刷新
console.log('刷新么么-無滾動條');
(parame.isStartRefresh || parame.continueMoveDirection === 'bottom') && method.refreshMove();
//加載
console.log('加載么么-無滾動條');
(parame.isStartLoad || parame.continueMoveDirection === 'top') && method.loadMove();
} else {
//刷新
console.log('刷新么么-有滾動條');
(parame.positionY === 0
&& !parame.isStartLoad
&& parame.continueMoveDirection === 'bottom')
&& method.refreshMove();
//加載
console.log('加載么么-有滾動條');
((parame.positionY === ($(document).height() - $(window).height()))
&& parame.continueMoveDirection === 'top'
&& !parame.isStartRefresh)
&& method.loadMove();
}
})
.on('touchend', function () {
console.log('滑動結束');
//刷新
parame.positionTop >= parame.whenThisHeightExecuteCallback && method.refreshIng();
//加載
parame.positionBottom >= parame.whenThisHeightExecuteCallback && method.loadIng();
//解決滑動距離小於刷新/加載距離未重置的bug
method.isRefreshBug() && method.closeRefresh();
method.isLoadBug() && method.closeLoad();
})
.on('touchcancel', function () {
method.cancel();
});
}
function init() {
createDom();
event();
}
window.noName = {
/* config:{ //主要參數 prop:'',//dom元素 refreshCallback:function(){},//刷新回調 loadCallback:function(){}//加載回調 //其他想自定義的參數請看defaultParame變量 } */
init: function (config) {
prop = config.prop;
if (typeof (config.prop) === 'undefined'
|| config.prop === ''
|| typeof (config.refreshCallback) != 'function'
|| typeof (config.loadCallback) != 'function')
throw new Error('必需參數為空');
callback.refresh = config.refreshCallback;
callback.load = config.loadCallback;
parame = $.extend({}, defaultParame, config.config || {});
init();
},
//刷新完成后關閉
closeRefresh: method.closeRefresh,
//加載完成后關閉
closeLoad: method.closeLoad
};
}());
html:
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>index</title>
<link href="~/Content/css/comm/reset.css" rel="stylesheet" />
<style> #content { width: 100%; overflow: hidden; } </style>
</head>
<body>
<div class="wrapper" id="wrapper">
<div id="content"></div>
</div>
<script src="~/Content/js/comm/jquery.min.js"></script>
<script src="~/Content/js/comm/noName.js"></script>
<script> function fillData() { var content = ''; for (var i = 0; i < 5; i++) { content += '<p>這里就是內容' + i + '</p>'; } $('#content').append(content); } fillData(); noName.init({ prop: '', refreshCallback: function () { setTimeout(function () { $('#content').html(''); fillData(); noName.closeRefresh(); }, 3000) }, loadCallback: function () { setTimeout(function () { fillData(); noName.closeLoad(); }, 3000) } }); </script>
</body>
</html>