`
pdsmsf
  • 浏览: 18539 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Mobile Safari css overflow

阅读更多
div需要滚动条在ipad的safari下面失效,mobile safari因为多点触摸的缘故取消了局部区域的滚动条(为了防止和默认的拖动行为冲突)。首先排除了是不是本身布局问题造成的,为此建了一个简单的页面进行测试依然失效,google发现还真是有这样的问题,google reader上也是失效的,mobile safari为此需要使用两个手指才能完成滚动局部的行为。
为了解决这样的问题继续google,最后发现了上述的一篇文章,使用mobile safari的touchmove事件模拟滚动条的效果。废话不多说代码如下:
function isTouchDevice(){
	try{
		document.createEvent("TouchEvent");
		return true;
	}catch(e){
		return false;
	}
}
function touchScroll(id){
	if(isTouchDevice()){ //if touch events exist...
		var el=document.getElementById(id);
		var scrollStartPos=0;
		 
		document.getElementById(id).addEventListener("touchstart", function(event) {
		scrollStartPos=this.scrollTop+event.touches[0].pageY;
		event.preventDefault();
		},false);
		 
		document.getElementById(id).addEventListener("touchmove", function(event) {
		this.scrollTop=scrollStartPos-event.touches[0].pageY;
		event.preventDefault();
		},false);
	}
}

最后使用
touchScroll("MyElement"); 将你需要overflow:auto的元素id调用这个方法即可。
原文:http://www.189works.com/article-55837-1.html
后续开发中发现中间INPUT等DOM在滚动DIV中不能触发事件,修正方法:
	if (target.tagName != 'SELECT' && target.tagName != 'INPUT' && target.tagName != 'TEXTAREA'  && target.tagName != 'A')
        			event.preventDefault();
分享到:
评论

相关推荐

    W3school,jquery,jquerymobile,css

    【标题】中的"W3school"、"jquery"、"jquerymobile"和"css"都是Web开发中的关键元素,它们代表了不同的技术栈和框架。以下是对这些知识点的详细阐述: **W3School**:这是一个非常知名的在线学习平台,提供丰富的...

    jquery.mobile css

    html5 开发 jquery.mobile.theme-1.4.5.min.css 样式表

    layui.mobile.css

    web就餐刷卡页面设计web就餐刷卡页面设计web就餐刷卡页面设计

    jquery mobile css3手机表单页面布局按钮样式

    在移动应用开发中,jQuery Mobile 和 CSS3 是两个非常重要的技术。jQuery Mobile 是一个轻量级的框架,专为触摸设备设计,它提供了一套完整的组件和交互模式,包括表单、页面布局和按钮样式等。CSS3 则是新一代的CSS...

    mobileSelect.css

    mobileSelect.css

    jquery.mobile.css

    jquery.mobile.css

    mobile-safari-fullscreen:修复了移动Safari全屏问题

    应作为项目的dependencies之一安装: npm install --save mobile-safari-fullscreen 用法import FullScreen from 'mobile-safari-fullscreen'import styles from 'mobile-safari-fullscreen/index.module.css';...

    wap站基于Html5和jquery-mobile的demo,去除jquery-mobile.css

    `jquery-mobile.css`是jQuery Mobile的默认样式表,它定义了框架的外观和感觉。然而,为了实现更个性化的设计,开发者可能希望摆脱这些预设样式,这正是这个Demo的目标。`jqm.structure.css`和`you-jqm-themes.css`...

    jqmobile相关js css

    - `jquery.mobile-1.4.5.css` 和 `.min.css` 文件:这是jQuery Mobile的核心样式文件,包含了大部分的布局和组件样式。`.min.css`是压缩版,用于生产环境以减少页面加载时间。 - `jquery.mobile.icons-1.4.5.css` ...

    JQueryMobile js/css/1.2版本/1.4版本

    标题中的“JQueryMobile js/css/1.2版本/1.4版本”指的是该压缩包包含了JQuery Mobile框架的两个主要版本:1.2和1.4。这两个版本在功能和API上有所差异,1.4是较新的版本,可能包含更多改进和新特性。 在描述中提到...

    jquery.mobile-1.4.5.min.css

    移动开发所需要的css文件 jQuery Mobile 1.4.5 | Git HEADhash: 68e55e7 <> 2014-10-31T17:33:30Z | (c) 2010, 2014 jQuery Foundation, Inc. | jquery.org/license */

    (Wrox) Professional Iphone & Ipod Touch Programming--Building Applications For Mobile Safari

    《专业iPhone™与iPod®touch编程:为Mobile Safari™构建应用》这本书是Richard Wagner撰写的一部关于在苹果设备上开发应用程序的专业指南。本书详细介绍了如何利用iPhone和iPod touch平台进行开发,特别关注了如何...

    HTML5+CSS3+jQuery Mobile轻松构造APP与移动网站_陈婉凌.pdf

    HTML5、CSS3和jQuery Mobile是现代Web开发中的三大核心技术,它们共同构建了丰富的、交互式的移动应用和网站。本书《HTML5+CSS3+jQuery Mobile轻松构造APP与移动网站》由陈婉凌撰写,旨在帮助读者掌握这些技术,轻松...

    jQuery Mobile CSS 类

    jQuery Mobile CSS 类 jQuery CSS 类 jQuery Mobile CSS 类来设置不同元素的样式。 以下列表包含了通用的 CSS 样式: 全局类 以下类可以在 jQuery Mobile 小工具中使用 (按钮,工具条,面板,表格,列表等。): ...

    HTML5 CSS3 jQueryMobile-源代码.rar

    HTML5、CSS3和jQuery Mobile是现代Web开发中的三大核心技术,它们共同构建了富互联网应用程序(RIA)的基础。本资源包含HTML5、CSS3和jQuery Mobile的源代码以及相关的视频教程,非常适合初学者和进阶开发者学习使用...

    sui-mobile路由加载js,css问题的解决方案

    4. **公共CSS与组件CSS**:SUI Mobile 的全局CSS应确保在每个页面都可用,而组件级CSS则应该按需加载。确保公共CSS已正确链接到HTML头部,而组件CSS通过路由加载。 5. **缓存策略**:有时,路由加载问题可能是由于...

    doxygen-mobile-css:Doxygen的移动CSS

    Doxygen手机 基于Doxygen 1.8.13 Doxyfile: HTML_EXTRA_STYLESHEET += style/doxygen_mobile.css

    HTML5+CSS3+jQuery Mobile轻松构造APP与移动网站代码

    HTML5、CSS3和jQuery Mobile是现代Web开发的三大核心技术,它们共同为构建功能丰富的APP和移动网站提供了强大的工具集。HTML5作为超文本标记语言的最新版本,引入了诸多新特性,旨在提升网页的交互性和表现力;CSS3...

Global site tag (gtag.js) - Google Analytics