通過Gyrocode.com給出的解決方案是好的。但在各種設備和瀏覽器上進行測試時會失敗。所以這裏是一個增強版本,可以在觸控設備以及操作系統特定的瀏覽器上使用。
fnInitComplete: function() {
var device = getBrowserInfo(),
horizontalScroll = 0,
tableElement = $(this[0]),
scrollBody = $('.dataTables_scrollBody'),
scrollFoot = $('.dataTables_scrollFoot'),
maxScrollLeft,
start = { x:0 , y:0 },
offset;
// Compute the maxScrollLeft value
tableElement.on('draw.dt', function() {
maxScrollLeft = tableElement.width() - scrollBody.width() + 2;
});
// Disable TBODY scoll bars
scrollBody.css({ 'overflow-x': 'hidden' });
// Enable TFOOT scoll bars
scrollFoot.css('overflow-x', 'auto');
// Sync TFOOT scrolling with TBODY
scrollFoot.on('scroll', function(event) {
horizontalScroll = scrollFoot.scrollLeft();
scrollBody.scrollLeft(horizontalScroll);
});
// Enable body scroll for touch devices
if((device.isAndroid && !device.isChrome) || device.isiPad
|| (device.isMac && !device.isFF)) {
// Enable for TBODY scoll bars
scrollBody.css({ 'overflow-x': 'auto'});
}
// Fix for android chrome column misalignment on scrolling
if(device.isAndroid && device.isChrome) {
scrollBody[0].addEventListener("touchstart", touchStart, false);
scrollBody[0].addEventListener("touchmove", touchMove, false);
scrollFoot[0].addEventListener("touchstart", touchStart, false);
scrollFoot[0].addEventListener("touchmove", touchMoveFooter, false);
}
// Fix for Mac OS dual scrollbar problem
if(device.isMac && device.isFF) {
scrollBody.on('wheel', function(event) {
if(Math.abs(event.originalEvent.deltaY) < 3) {
event.preventDefault();
}
performScroll(event.originalEvent.deltaX);
});
}
/*
* Performs the scroll based on the delta value supplied.
* @param deltaX {Number}
*/
function performScroll(deltaX) {
horizontalScroll = horizontalScroll + deltaX;
if(horizontalScroll > maxScrollLeft) {
horizontalScroll = maxScrollLeft;
} else if(horizontalScroll < 0) {
horizontalScroll = 0;
}
scrollFoot.scrollLeft(horizontalScroll);
}
/*
* Computes the touch start position along with the maximum
* scroll left position
* @param e {object}
*/
function touchStart(e) {
start.x = e.touches[0].pageX;
start.y = e.touches[0].pageY;
}
/*
* Computes the offset position and perform the scroll based
* on the offset
* @param e {Object}
*/
function touchMove(e) {
offset = {};
offset.x = start.x - e.touches[0].pageX;
offset.y = start.y - e.touches[0].pageY;
performScroll(offset.x/3);
}
/*
* Computes the offset position and perform the scroll based
* on the offset
* @param e {Object}
*/
function touchMoveFooter(e) {
e.preventDefault();
touchMove(e);
}
/**
* @getBrowserInfo
* @description
* To get browser information
*
* @return {Object}
*/
function getBrowserInfo() {
return {
isiPad: (/\(iPad.*os (\d+)[._](\d+)/i).test(navigator.userAgent) === true || navigator.platform.toLowerCase() === 'ipad',
isAndroid: (/\(*Android (\d+)[._](\d+)/i).test(navigator.userAgent),
isMac: navigator.platform.toUpperCase().indexOf('MAC') >= 0,
isChrome: !!window.chrome,
isFF: !!window.sidebar
};
};
}
還能夠去除苗條滾動在Mac OS和其他各種移動設備添加
.dataTables_scrollBody::-webkit-scrollbar {
display: none;
}
一個很好的決定!但它不適用於FixedColumn http://jsfiddle.net/djmartini/wce6kqwy/2/ – djmartini
@djmartini,我認爲你的例子中存在FixedColumn和FixedHeader擴展的問題。當我評論我的代碼時,表格仍然出現在固定列和頁腳的下面。也許是因爲你正在使用最新的擴展和較舊的DataTable,我不知道。此外,我建議的代碼更多的是黑客攻擊,並不適用於所有用例。 –
好的一個+1 ..但是,有什麼可以打破這種做法?你似乎沒有充分的信心.. –