解决 android 高低版本 webView 里内容 自适应屏幕的终极方法
2015-11-01 10:50
1516 查看
转载请声明出处(http://www.cnblogs.com/linguanh/)
一,先说下我的情况,大家可以对号入座(嫌无聊请跳过)
我的项目要求是这样的,先从数据库里面拿出来html标签,因为加载到移动端的网页内容是用户在网页编辑好了之后提交到服务器的,即网页内容是 b/s 交互,我在网页前段编辑器里面设置了只保存编辑的 html 标签,即是没有头部和后面的,形式是:
<html>
<body>
只保存这里的标签到数据库
</body>
</html>
移动端有两个activity,这时候是 c/s 交互了,页面一负责加载前置数据,例如一张封面图之类的,然后用户点击进入webView主体,我上面说了,我的目标html标签是保存到db的,所以我在第一个页面的时候就把db里面的html下载保存到内存了,String即可,用户点击时,跳转传递。看到这里,相信你知道我是加载到webView的了,没错,就是组合,再load。注意了,我这里并不是直接加在一个链接,不是 webView.loadUrl() 是组合好 html 后再使用 loadDataWithBaseUrl。
二,说下标签不同的影响(很重要,因为某些方法对某些表情有用)
通常,我们加载后超出屏幕宽度的一般是 img 或者 video 标签或者文字,这类标签可以使用css 或者 网上盛行的三个设置做到适配,这三个盛行的设置是:
法二:使用三种setting设置:
看到这里,你很可能会说,这和 css 有什么区别?区别可大了,我使用 css 改变table的失败了,使用它成功了。
说明一下: 上面使用 js 脚步适配,请写到 内容加载之后,即是 <body> 内容 <写后面></body>,为什么呢?有基础的人都知道,html 是解析性语言,从上到下,你要先加载好 html 再使用 js 改变,除非js 包在函数里面。
四,打完收工
有问题请留言。
一,先说下我的情况,大家可以对号入座(嫌无聊请跳过)
我的项目要求是这样的,先从数据库里面拿出来html标签,因为加载到移动端的网页内容是用户在网页编辑好了之后提交到服务器的,即网页内容是 b/s 交互,我在网页前段编辑器里面设置了只保存编辑的 html 标签,即是没有头部和后面的,形式是:
<html>
<body>
只保存这里的标签到数据库
</body>
</html>
移动端有两个activity,这时候是 c/s 交互了,页面一负责加载前置数据,例如一张封面图之类的,然后用户点击进入webView主体,我上面说了,我的目标html标签是保存到db的,所以我在第一个页面的时候就把db里面的html下载保存到内存了,String即可,用户点击时,跳转传递。看到这里,相信你知道我是加载到webView的了,没错,就是组合,再load。注意了,我这里并不是直接加在一个链接,不是 webView.loadUrl() 是组合好 html 后再使用 loadDataWithBaseUrl。
二,说下标签不同的影响(很重要,因为某些方法对某些表情有用)
通常,我们加载后超出屏幕宽度的一般是 img 或者 video 标签或者文字,这类标签可以使用css 或者 网上盛行的三个设置做到适配,这三个盛行的设置是:
setting.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN); setting.setUseWideViewPort(true); setting.setLoadWithOverviewMode(true); 我先说明,这三个设置不一定有效,android 4.4 后就很可能没效,为什么是很可能?你都不敢确定?上面说过,和标签及其设置有关系。 如果出现了 table 这种标签,即 table 适配屏幕,很可能css都失效,怎么办?,我就是遇到了它,所以有了这篇文章。 三,三种解决方法(重点)。 针对我的自己情况,自己组合html显示的。 法一: 使用 Css 适配,它比上面的三种 setting 有效,对img 和video 绝壁有效,我给出个例子:
"<style>"+ "img{" + "max-width:100%;" + "height:auto}" + "video{"+ "max-width:100%;"+ "height:auto}"+ "</style>" +
法二:使用三种setting设置:
setting.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN); setting.setUseWideViewPort(true); setting.setLoadWithOverviewMode(true); 这种方法的失败可能性很大,但是,也可以一试 法三:使用javaScript脚本,暂时给它定义成功率是 100%(因为我用它没失效过) 我这里给一个例子,例如我上面说到的 table。
"<script type=\"text/javascript\">" "var tables = document.getElementsByTagName('table');" + // 找到table标签 "for(var i = 0; i<tables.length; i++){" + // 逐个改变 "tables[i].style.width = '100%';" + // 宽度改为100% "tables[i].style.height = 'auto';" + "}" + "</script>"+
看到这里,你很可能会说,这和 css 有什么区别?区别可大了,我使用 css 改变table的失败了,使用它成功了。
说明一下: 上面使用 js 脚步适配,请写到 内容加载之后,即是 <body> 内容 <写后面></body>,为什么呢?有基础的人都知道,html 是解析性语言,从上到下,你要先加载好 html 再使用 js 改变,除非js 包在函数里面。
四,打完收工
有问题请留言。
相关文章推荐
- Android 窃取手机中微信聊天记录
- android应用开发之spinner控件的简单使用
- android--(图片 双缓存实例)
- Ljava.lang.Object;@ba8a1dc
- android--(Bitmap处理较大的位图、缓存位图)
- spring读取applicationContext.xml获得BeanFactory的方法
- Android SDK 国内下载代理设置
- android studio(documentation list 模式)
- 【android】listview与adapter用法
- android常见错误之 No resource found that matches the given name
- Android 学习笔记之AndBase框架学习(二) 使用封装好的进度框,Toast框,弹出框,确认框...
- IOS实用技术之手势缩放图片
- Android之路-启程1:前言以及为什么看好Android
- android屏幕问题
- 11_常见对象(Object类的使用)
- 《JavaScript高级编程》学习笔记之object和array引用类型
- iOS自定义转场动画(2)——自定义Pop转场动画并加入手势驱动
- android 68 单元测试
- iOS 中利用 Masonry 进行代码适配的基本方法
- Android 侧滑菜单的实现