dcloud离线打包内容分享(第三插件开发、h5到原生,原生到h5)

2024-05-26 17:58

本文主要是介绍dcloud离线打包内容分享(第三插件开发、h5到原生,原生到h5),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

dcloud离线打包(第三插件开发、h5到原生,原生到h5)

dcloud 官方文档,怎么说呢,貌似没有完整的提供离线打包方法,只说了如何开发第三方插件,但是如何开发第三方插件,写的又不是很详细,并且开发出了第三方插件,如何集成到项目里,貌似根本没有写,本人,也是新手,刚好最近用dcloud开发了一个app,有一点经验,所以把一些经验分享出来,希望能帮到大家!
1.离线打包和在线打包,大家要明白一点,在线打包,人家帮你做了什么。举个例子,语音这块,用dcloud(h5)开发,就一行代码就搞定,为什么呢?因为在线打包,人家把原生调用的一些内容已经引进去了,所以,我们不需要考虑原生的,但是离线打包呢?
2.有的同学可能会问,那怎么样把自己开发的第三方插件,也同样用在线打包的方式打包进去呢?那你想象一下,这可能吗?你知道在线打包的规则吗?除非dcloud官方同意你这么做。
        3.所以,想要离线打包,前提还是,怎么把你开发的app(h5),集成到原生的android工程中,用eclipse或者android studio 打包你的app,这一块详见 http://ask.dcloud.net.cn/article/526,写的很详细。
       4.按照教程把你的app集成好了之后,先打包测试一下,看是否操作正常,如果没问题,说明你的app集成就对了!此时你再回过头来看第三方插件开发的内容 http://ask.dcloud.net.cn/article/66,你就大概明白怎么回事了,这样第三方插件也就开发出来了,在插件里面,就是java代码开发的内容了,记住Iwebview ,这个很有用,举个例子,你要打开你自己的activity 窗口 ,只需要这样,
GpsSqlLiteConstant.pWebview = pWebview;
Intent localIntent = new Intent(pWebview.getActivity(), OffineMapActivity.class); 这个具体的用法,自己去看源码。
	5.从h5到原生,到这里,大家应该就会搞了,但是从原生到h5,大家应该还是会遇到,所以,我在这里也给大家说明一下,你可以选择在原生activity中集成h5页面,也可以先返回到h5中,再调用h5的页面,个人建议先回到h5中,再调用,因为我们开发就是在h5的app中开发,这样可以保证,引用到的js或者css,都能识别,不需要为了不兼容问题,再花时间,先给大家上一段代码,activity中引用h5页面,
public class SaveInforActivity extends Activity {IWebview webview = null;@Override
    protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// setContentView(R.layout.activity_save_infor);
        final  FrameLayout rootView = new FrameLayout(this);rootView.getViewTreeObserver().addOnGlobalLayoutListener(new OnGlobalLayoutListener() {@Override
            public void onGlobalLayout() {webview.onRootViewGlobalLayout(rootView);}});// 设置单页面集成的appid
        String appid = "tab_sample_index";// 单页面集成时要加载页面的路径,可以是本地文件路径也可以是网络路径
        String url = "file:///android_asset/apps/xxxx/www/views/task/tab_sample_index.html";webview = SDK.createWebview(this, url, appid, new IWebviewStateListener() {@Override
            public Object onCallBack(int pType, Object pArgs) {switch (pType) {case IWebviewStateListener.ON_WEBVIEW_READY:// 准备完毕之后添加webview到显示父View中,设置排版不显示状态,避免显示webview时,html内容排版错乱问题
                        ((IWebview) pArgs).obtainFrameView().obtainMainView().setVisibility(View.INVISIBLE);SDK.attach(rootView, ((IWebview) pArgs));break;case IWebviewStateListener.ON_PAGE_STARTED:// 首页面开始加载事件
                        break;case IWebviewStateListener.ON_PROGRESS_CHANGED:// 首页面加载进度变化
                        break;case IWebviewStateListener.ON_PAGE_FINISHED:// 页面加载完毕,设置显示webview
                        webview.obtainFrameView().obtainMainView().setVisibility(View.VISIBLE);break;}return null;}});setContentView(rootView);final WebView webviewInstance = webview.obtainWebview();// 监听返回键
        webviewInstance.setOnKeyListener(new OnKeyListener() {@Override
            public boolean onKey(View v, int keyCode, KeyEvent event) {if (keyCode == KeyEvent.KEYCODE_BACK) {if (webviewInstance.canGoBack()) {webviewInstance.goBackOrForward(2);return true;}}return false;}});}@Override
    protected void onDestroy() {super.onDestroy();}@Override
    protected void onPause() {super.onPause();}
}
本人亲测,代码完全可靠,可以显示页面,mui.ready,mui.init都可以执行,但是不太推推荐,个人推荐第二种,直接上代码 
Intent intent = new Intent();
intent.setClass(MainActivity.this, io.dcloud.PandoraEntry.class);
startActivity(intent);
如果想跳转之后,直接调用某个方法,这样操作 
GpsSqlLiteConstant.pWebview.evalJS("test('" + 参数 + "')"); 
GpsSqlLiteConstant.pWebview 这个就是Iwebview,test(),这个是h5中写的js方法,大家可以通过 evalJS()方法,调用到h5中写的任何js方法,test方法如下
 function test(tid){		mui.openWindow({
				url: '../task/tab_sample_index.html',
				id: 'tab_sample_index',
				extras:{
					tid:tid
				}
			});}
至此,我想大家应该就都会了,如果觉得写的还不错,而且帮到了你,请点赞吧,如果有不明白的,请留言!代码的话,请谅解,因为是公司的项目,不方便上传,如果小伙伴有需要部分代码,或者想要一起学习交流的话,请加一下这个QQ群,488505459,一起学习,一起探讨,谢谢!

这篇关于dcloud离线打包内容分享(第三插件开发、h5到原生,原生到h5)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1005178

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Flutter打包APK的几种方式小结

《Flutter打包APK的几种方式小结》Flutter打包不同于RN,Flutter可以在AndroidStudio里编写Flutter代码并最终打包为APK,本篇主要阐述涉及到的几种打包方式,通... 目录前言1. android原生打包APK方式2. Flutter通过原生工程打包方式3. Futte

使用Python实现获取网页指定内容

《使用Python实现获取网页指定内容》在当今互联网时代,网页数据抓取是一项非常重要的技能,本文将带你从零开始学习如何使用Python获取网页中的指定内容,希望对大家有所帮助... 目录引言1. 网页抓取的基本概念2. python中的网页抓取库3. 安装必要的库4. 发送HTTP请求并获取网页内容5. 解

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并

Python解析器安装指南分享(Mac/Windows/Linux)

《Python解析器安装指南分享(Mac/Windows/Linux)》:本文主要介绍Python解析器安装指南(Mac/Windows/Linux),具有很好的参考价值,希望对大家有所帮助,如有... 目NMNkN录1js. 安装包下载1.1 python 下载官网2.核心安装方式3. MACOS 系统安

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图