1.在webView初始化时则循环去掉水平及竖直滑动条
2.每次页面加载完成,均会调用webViewDidFinishLoad代理方法,在此判断链接是否是首页,如果是首页则不显示左上角按钮,否则显示
这里非常卡顿,尤其是界面第一次加载时特别缓慢,造成的用户使用效果就是:界面显示出好一会了,左上角的按钮才会出现或者消失
3.在点击左上角返回按钮时,判断当前WebView是否可以返回,如果可以直接返回,如果不可以直接跳回首页面
区别
1.需要导入头文件
2.没有获取title,是自己写死的
1.因为后续涉及了分享,分享出去的标题不能是写死的,需要获取H5的title
2.需要有进度条
3.当用户初次安装打开首页的时候(此时H5已经请求了),会d出是否使用数据,当你未选择的时候,H5是停止请求的空白的页面,当选择了允许,但H5已经停止了请求,所以必须加一个下拉刷新
4.H5中有跳转AppStore的链接,WKWebView不会自动识别并去跳转
1.为对象属性注册观察者
observer: 观察者对象
keyPath: 被观察的属性,其不能为nil
options: 设定通知观察者时传递的属性值,是传改变前的呢,还是改变后的
context: 一些其他的需要传递给观察者的上下文信息,通常设置为nil
2.观察者接收通知,并做出处理:观察者通过实现下面的方法,完成对属性改变的响应
keyPath: 被观察的属性,其不能为nil.
object: 被观察者的对象.
change: 属性值,根据上面提到的Options设置,给出对应的属性值
context: 上面传递的context对象。
3.移除观察者
推荐两个html5在手机app开发方面好的框架:phonegap + sencha。sencha touch是一个html5的重型框架,自带组件较多,一般应用可以凑合着使。
phonegap可以将html5的应用本地化。解决了纯html5应用不能调用本地机器接口的问题。
两者结合蛮好用的。
1 概述HTML5 SDK 可以按照“独立应用”、“Widget”和“WebView”三种方式进行集成,三种集成方式各有优点。
独立应用集成方式:使用独立应用方式,开发者需要将HTML5 SDK生成的首页面设置为当前View的subView。HTML5 SDK将对应用进行管理。
Widget集成方式:运行方式和独立运行方式类似,开发者在集成时可在需要的位置启动HTML5 SDK,显示指定的HTML5 应用。
Webview集成方式:用户可在任何页面将HTML5 SDK的页面以Webview的形式独立显示,显示的Webview页面。
2 导入SDK Lib文件和头文件
在工程中引入HTML5+ SDK扩展功能的.a文件,开发者可以根据需求添加不同的扩展插件。必须要引入的是liblibPDRCore.a,liblibPDRCore.a库是HTML5+SDK运行的基础库文件。
在引入lib文件时需要将Debug-iphoneos、Release-iphoneos和Release-iphonesimulator引入,分别为真机调试,真机编译和模拟器调试使用。
工程中引入HTML5 SDK 中提供的头文件。
3 添加代码编译测试
独立应用集成的方式比较简单,请安如下步骤实现
在应用的Controller实现文件的- (void)viewDidLoad方法中实现如下代码
1. 开发者初始化PDRCore句柄。
2. 设置指定的View为HTML5 SDK的父View,用于显示HTML5 SDK的页面
3. 调用PDRCore句柄的start接口启动应用,HTML5 Runtime将会根据用户配置的control.xml文件指定的APPID启动指定的应用。
#import "DcViewController.h"
#import "PDRCore.h"
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad]
PDRCore* pCoreHandle = [PDRCore Instance]
[pCoreHandle setContainerView:self.view]
[pCoreHandle start]
}
4 导入应用并配置
4.1 添加应用
在离线打包之前,用户需要将已经开发完成的HTML5 应用导入到Xcode工程中。
4.1.1 应用导入
需要将开发完成的HTML5 应用拷贝到Pandora/apps/[appid]/www目录下。
4.1.2 manifes.json文件编写
请参考manifest.json 文件配置指导手册
4.2 配置应用的插件功能
开发者需要将html5 SDK里的PandoraAPI.bundle引入到开发中的工程中。开发者如开发了HTML5 扩展插件,需要修改PandoraAPI.bundle下的WebFeature.plist文件,在文件中添加扩展插件JS类名和原生类名的对应关系。
5 添加Control.xml
在工程中创建文件control.xml 文件,control.xml文件用来指定默认启动应用的APPID。
Control.xml文件放在工程的资源目录下即可。
<msc debug="true" version="0.1.0.0" >
<apps>
<app appid="HelloH5" appver="1.0" />
</apps>
</msc>
6 常用类说明
PDRCore
常用接口说明:
(PDRCore*)Instance
获取Core单例对象
返回值:
PDRCore 单例的PDRCore对象
- (int)setAppsRunPath:(NSString*)workPath
设置应用运行时目录,应用运行时产生的文件在该目录下生成,当应用 runmode为liberate时将把资源拷贝到该目录
参数说明:
workPath 应用运行时目录
返回值:
int 0 成功
- (int)setAppsInstallPath:(NSString*)installPath
设置runtime应用的安装目录,该地址为安装包中携带的应用资源位置
参数说明:
installPath 应用的安装目录
返回值:
int 0 成功
- (void)setInnerVersion:(NSString*)innerVersion
设置HTML5 SDK运行版本
参数说明:
innerVersion HTML5 SDK运行版本号
- (int)setDocumethPath:(NSString*)documentPath
设置HTML5 SDK文档目录
参数说明:
documentPath 应用的文档目录
返回值:
int 0 成功
- (int)setDownloadPath:(NSString*)downlaodPath
设置runtime下载目录
参数说明:
downloadPath 应用下载文件的路径
返回值:
int 0 成功
- (int)setAutoStartAppid:(NSString*)appid
设置runtiem启动时自动运行的APP
参数说明:
appid 默认启动应用的APPID
返回值:
int 0 成功
- (int)setContainerView:(UIView*)containerView
设置runtime根视图的父亲View
参数说明:
containerView 要显示HTML5 SDK的父View
返回值:
int 0 成功
- (int)setApp:(NSString*)appid documentPath:(NSString*)doucmentPath
设置指定app的文档目录
参数说明:
appid 要设置的appid
doucmentPath 要设置的路径
返回值:
int 0 成功
- (int)regPluginWithName:(NSString*)pluginName
impClassName:(NSString*)impClassName
type:(PDRExendPluginType)pluginType
javaScript:(NSString*)javaScript
注册第三方扩展的HTML5 插件
参数说明:
pluginName 插件名称JS文件中定义的名字
impClassName 插件对应的实现类名
pluginType 插件类型 详情:PDRExendPluginType
javaScript js实现 为javascript文本
返回值:
int 0 成功
- (int)start
正常启动runtime,使用改方法启动runtime具有全部功能,包括具有应用管理、窗口管理、插件管理、权限管理、资源管理等功能
- (int)startAsWebClient
启动runtime,使用该方法启动的runtime不具有应用管理窗口管理功能,当需要显示页面时,需要自己创建PDRCoreAppFrame
PDRCoreAppFrame
常用接口说明
- (PDRCoreAppFrame*)initWithId:(NSString*)frameID loadURL:(NSString*)pagePath frame:(CGRect)frame
创建runtime页面
参数说明:
frameID 页面标示
pagePath 页面地址 支持http:// file:// 本地地址
frame 页面位置
@property(nonatomic, readonly)UIWebView *webView
应用页面的WebView对象
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)