下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
【移动应用开发技术】Androidwebview加载HTML,CSS等语言的案例
这篇文章将为大家详细讲解有关Androidwebview加载HTML,CSS等语言的案例,在下觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言这个题目可能取得不大好,想了很久没想出更合适的了。在android开发webview的时候,有的时候后台不一定给的就是一个url,而是把一些HTML,css,js语言代码给你,然后你自行组装出webview能够识别的语言,并加载到页面当中。加载html无非有三种情况:一、存放在assets文件夹下的html文件;二、直接加载某个指定的网页。三、从网络上解析得到的html代码,注意此处是代码,即字符串格式。示例/**
*
body
:
<div
class="main-wrap
content-wrap">...</div>
*
image_source
:
《四月物语》
*
title
:
我喜欢你,但你别喜欢我:囚禁在单相思中的性单恋者
*
image
:
/4d37a2dff96d07f6a01e7b8aabd63032.jpg
*
share_url
:
/story/9100667
*
js
:
[]
*
ga_prefix
:
122713
*
images
:
["/a32e73507ebe9a963f48c3bcc9808773.jpg"]
*
type
:
0
*
id
:
9100667
*
css
:
["/css/news_qa.auto.css?v=4b3e3"]
*/假如后台给你一个url,而url实则是json数据对应的连接,并不能直接加载到webview当中,此时该如何解决。这个问题我可以说是一年前就遇到了,后来一是不知道怎么查,在网上没有找到相应的资料,二是身边没有前端的人来指导,今天问过了前端的同事,才明白了一二。代码分析在往常前端开发当中一般都是自己写HTML和CSS代码,然后显示在浏览器,也就android中的webview。对于android这种情况,只能拼接代码。后台提供相应代码,android开发自己拼接。其实没有那么想象中的那么难,因为说到底都是字符串,对字符串进行一定的格式化就能轻易达到效果。代码实现public
class
HtmlUtil
{
//
css样式,隐藏header
private
static
final
String
HIDE_HEADER_STYLE
=
"<style>div.headline{display:none;}</style>";
//
css
style
tag,
需要格式化
private
static
final
String
NEEDED_FORMAT_CSS_TAG
=
"<link
rel=\"stylesheet\"
type=\"text/css\"
href=\"%s\"/>";
//
js
script
tag,
需要格式化
private
static
final
String
NEEDED_FORMAT_JS_TAG
=
"<script
src=\"%s\"></script>";
public
static
final
String
MIME_TYPE
=
"text/html;
charset=utf-8";
public
static
final
String
ENCODING
=
"utf-8";
public
HtmlUtil()
{
}
/**
*
根据css链接生成Link标签
*
@param
url
String
*
@return
String
*/
public
static
String
createCssTag(String
url)
{
return
String.format(NEEDED_FORMAT_CSS_TAG,
url);
}
/**
*
根据多个css链接生成Link标签
*
@param
urls
List<String>
*
@return
String
*/
public
static
String
createCssTag(List<String>
urls)
{
final
StringBuilder
sb
=
new
StringBuilder();
for
(String
url
:
urls)
{
sb.append(createCssTag(url));
}
return
sb.toString();
}
/**
*
根据js链接生成Script标签
*
*
@param
url
String
*
@return
String
*/
public
static
String
createJsTag(String
url)
{
return
String.format(NEEDED_FORMAT_JS_TAG,
url);
}
/**
*
根据多个js链接生成Script标签
*
*
@param
urls
List<String>
*
@return
String
*/
public
static
String
createJsTag(List<String>
urls)
{
final
StringBuilder
sb
=
new
StringBuilder();
for
(String
url
:
urls)
{
sb.append(createJsTag(url));
}
return
sb.toString();
}
/**
*
根据样式标签,html字符串,js标签
*
生成完整的HTML文档
*/
public
static
String
createHtmlData(String
html,
List<String>
cssList,
List<String>
jsList)
{
final
String
css
=
HtmlUtil.createCssTag(cssList);
final
String
js
=
HtmlUtil.createJsTag(jsList);
return
css.concat(HIDE_HEADER_STYLE).concat(html).concat(js);
}
}这是个工具类,专门用于将HTML,CSS等语言连接成HTML。先来看我们使用的方法createHtmlData,返回的是string连接的一个字符串,concat方法如下:css:将json中的css代码取出来,并加上前缀HIDE_HEADER_STYLE:定义整体HTML的stylehtml:这个直接就是json数据当中的html代码js:将json中的js代码取出来,并加上前缀。加标签前缀就是利用String.format(NEEDED_FORMAT_JS_TAG,url);方法,将前面格式中的%s,替换成后边的代码。引用到webviewString
htmlData
=
HtmlUtil.createHtmlData(entity.getBody(),
entity.getCss(),
entity.getJs())
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 砂石料购销合同中的违约责任部分
- 股权转让定金合同
- 采暖安装施工合同
- 采购合同管理程序
- 2024-2030年中国人工阴道行业市场发展趋势与前景展望战略分析报告
- 2024-2030年中国人体感应报警器行业市场发展分析及发展趋势与投资前景研究报告
- 2024-2030年中国产后保健品市场营销策略探讨与产品销售渠道规划报告
- 2024-2030年中国二手车交易行业市场发展分析及前景趋势与投资风险研究报告
- 2024-2030年中国乙酰丙酮行业发展分析及竞争策略与趋势预测研究报告
- 2024-2030年中国乌木行业市场发展分析及竞争格局与投资前景研究报告
- 客户投诉解决与改进计划三篇
- 养老机构认知症老人非药物干预疗法操作指南
- 装配式建筑施工安全管理
- 2024年国网无人机竞赛考试题库(附答案)
- 2024年湖南省中考英语试题卷(含答案)
- 2024时事政治考试题及一套参考答案
- 市场及客户研究方法
- 小龙虾病害防控技术课件讲解
- python程序设计-说课
- 手术室护理品牌创建
- 国际金融(第七版)全套教学课件
评论
0/150
提交评论