- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我正在创建一个全屏网络应用程序,它将包含一些使用新的 iOS 5 溢出:滚动功能的模块/小部件。我想要的是在滚动 html/body 时禁用那种“flex ”效果(因为它是全屏),但只在可滚动元素上保持这种效果。
平滑我拥有的可滚动元素的效果:
html, body { overflow: hidden; }
.scrollable {
overflow: scroll;
-webkit-overflow-scrolling: touch;
}
然后是以下禁用触摸滚动效果的脚本:
$(document).bind('touchmove', function (e) {
if (e.target === document.documentElement) {
e.preventDefault();
}
});
虽然这似乎根本不起作用,因为当将元素滚动到最底部或顶部时,它也会滚动 documentElement
。
有没有办法只对 body html 元素禁用该效果?
这是一个很好的例子,说明这如何影响功能:
最佳答案
不幸的是-webkit-overflow-scrolling
没有更好地处理这个。您需要跟踪 y
使其工作的位置。我把课 scroll
在我想在页面上滚动的任何内容上,例如 <ul>
元素。包装一个 <div>
<ul>
周围用 overflow-y: auto
填充视口(viewport).不要放 overflow
或 height
在 <ul>
上. <ul>
将扩展到它的内容一样高,它是 <div>
这实际上是在做滚动。 -webkit-overflow-scrolling
是继承的,因此请尽可能将其放在 DOM 中。
演示:http://jsfiddle.net/ThinkingStiff/FDqH7/
脚本:
var swipeY = 0;
function onTouchMove( event ) {
var scroll = event.target.closestByClassName( 'scroll' );
if ( scroll ) {
var top = scroll.positionTop - scroll.parentNode.positionTop,
heightDifference = ( 0 - scroll.offsetHeight + scroll.parentNode.offsetHeight );
if( ( top >= 0 ) && ( event.touches[0].screenY > swipeY ) ) {
event.preventDefault(); //at top, swiping down
} else if( ( top <= heightDifference ) && ( event.touches[0].screenY < swipeY ) ) {
event.preventDefault(); //at bottom, swiping up
};
} else {
event.preventDefault();
};
};
function onTouchStart( event ) {
swipeY = event.touches[0].screenY;
};
Element.prototype.closestByClassName = function ( className ) {
return this.className && this.className.split( ' ' ).indexOf( className ) > -1
? this
: ( this.parentNode.closestByClassName && this.parentNode.closestByClassName( className ) );
};
window.Object.defineProperty( Element.prototype, 'positionTop', {
get: function () {
return this.offsetTop - this.parentNode.scrollTop;
}
} );
document.getElementById( 'viewport' ).addEventListener( 'touchmove', onTouchMove, false );
document.getElementById( 'viewport' ).addEventListener( 'touchstart', onTouchStart, false );
HTML:
<div id="viewport">
<div id="scroll-view">
<ul class="scroll">
<li>scroll scroll scroll scroll scroll </li>
<li>scroll scroll scroll scroll scroll </li>
<li>scroll scroll scroll scroll scroll </li>
. . .
</ul>
</div>
</div>
CSS:
#viewport {
border: 1px solid black;
height: 460px;
width: 320px;
-webkit-overflow-scrolling: touch;
}
#scroll-view {
height: 100%;
overflow-y: auto;
width: 100%;
}
关于javascript - 仅针对 html 禁用 flex 滚动,但针对溢出 :scroll 的元素进行维护,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8052919/
我想使用 overflow: scroll(或 auto)完成比屏幕宽的图库预览。在右侧,与最后一张可见图像重叠的阴影应该表示右侧可以看到更多图像。 这是一个 fiddle :http://jsfid
我的网格面板的滚动条有问题。当我滚动到底部并试图再次向上滚动时,滚动条会自动向下滚动,防止我滚动到列表的顶部。。。我试着设置布局“合适”,或给面板一个特定的宽度和高度大小,但这些解决方案都不起作用。。
这段代码的作用是什么? var oldScrollPos = $(window).scrollTop(); $(window).on('scroll.scrolldisabler', fu
..对于这个元素,我会在某个时候烧脑。 10 小时后仍然没有任何消息。 溢出的元素在 Android stock 浏览器(目前在 s3 mini,android 4.1.2 上测试)中没有任何平滑度。
基本上,我想要的是固定标题、卡住 Pane 、表格,例如 http://www.cssplay.co.uk/menu/tablescroll.html 。然而,他的 table 有一个主要弱点。标题不
我在我的一个项目中使用 Twitter Bootstrap,但是我的内容超出了浏览器 View 的问题。通常您会在屏幕右侧看到滚动条,但在我的情况下没有。我在 overflow: hidden; 之后
是否有一个“有效”的解决方案可以使对话框随滚动条滚动,而不是仍然从内部窗口边界的中心固定? 在某些情况下,用户的分辨率可能太小而无法包含对话框,在这种情况下,部分对话框可能会被隐藏。您可能在隐藏部分有
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: hide scrollbar while still able to scroll with mouse/k
我希望能够水平滚动浏览一些文章,但它不起作用。我尝试在内容周围放置一个边框,这样一些内容就会被截断,这样我就可以滚动,但是当我这样做时文章会垂直对齐... 这是我正在使用的代码: HTML:
我已经使用 HSROLL 成功创建了一个组合框,如下所示: HWND find = CreateWindowEx(0, WC_COMBOBOX, _T(""), CBS_DROPDOWN | WS_V
我有一个 定位于 position:fixed .当窗口在水平方向上太小而无法容纳 div 时,不会出现滚动条,div 的右侧会被简单地切断。 如果我更改为 position:absolute,滚动条
我对这两个参数完全感到困惑, es.scroll.size es.scroll.limit 我做了一些测试,仍然不知道。 es.scroll.limit = es.scroll.size * num_
我正在尝试使用 skrollr 构建网站.这是jFiddle link对于我已经尝试过的。但是正如您所见,当 smoothScrolling 设置为 true 时,它不会按预期工作。当设置 smo
最近,我在一个网站上工作,我想在不同的滚动位置拍摄特定的效果。我正在使用 Velocity JS 制作动画。有一个元素我想自动滚动到另一个特定的滚动位置。这可以使用 Velocity JS 轻松实现。
继续追加,您会看到最新的聊天消息出现,但在某个点后它会停止自动向下滚动。我怎样才能解决这个问题?谢谢。 http://jsfiddle.net/VMcsU/ $("#button1").click(f
在我的代码中,y 滚动位置(以像素为单位)是滚动 Pane 的顶部: stage = new Stage(new StretchViewport(480, 800)); Image m
我有一个模态对话框,里面有一个可滚动的 div。 div 设置为 overflow: scroll; 但是,当用户在 div 中一直向下滚动时,弹出窗口后面的内容开始向下滚动。 问题:当弹出窗口打开时
我正在使用 AutoCompleteTextView 让我的 Android 应用程序的用户使用自定义网络服务搜索内容:它按预期工作,但目前我找不到实现“无尽滚动”的方法"在下拉 ListView 上
我在我的应用程序中使用工具栏并使用这个 link我隐藏了工具栏,它按预期完美工作。但是当列表只有一个/两个项目时,不需要滚动工具栏,因为底部有足够的空间。 隐藏工具栏背后的想法是当列表项超出屏幕高度时
我是 Ios 开发的新手,我在导航项中添加了一个 Searchbar我想要实现的是当我向上滚动 tableview我想隐藏 Searchbar 并在向下滚动时显示它 类似于 iPAD/Iphone 上
我是一名优秀的程序员,十分优秀!