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

相关文章

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

将Java程序打包成EXE文件的实现方式

《将Java程序打包成EXE文件的实现方式》:本文主要介绍将Java程序打包成EXE文件的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录如何将Java程序编程打包成EXE文件1.准备Java程序2.生成JAR包3.选择并安装打包工具4.配置Launch4

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

PyInstaller打包selenium-wire过程中常见问题和解决指南

《PyInstaller打包selenium-wire过程中常见问题和解决指南》常用的打包工具PyInstaller能将Python项目打包成单个可执行文件,但也会因为兼容性问题和路径管理而出现各种运... 目录前言1. 背景2. 可能遇到的问题概述3. PyInstaller 打包步骤及参数配置4. 依赖

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA