用HBuilderX 打包 vue 项目 为 App 的步骤
首先打包你的 vue 项目 生成 dist 文件夹,教程请移步 https://www.cnblogs.com/taohuaya/p/10256670.html
看完上面的教程,请确保 你是 将:
项目目录下的config
文件夹里的index.js
文件中, 将build
对象下的assetsPublicPath
中的“/”
,改为“./”后,打包生成的 dist 文件。
开始使用 HBuiderX 打包。(工具下载地址:http://www.dcloud.io/)
这是我 vue 项目打包后的 dist 文件。
设置沉浸状态栏:(什么是沉浸状态栏和设置方法 请移步: http://ask.dcloud.net.cn/article/32 地址里的 http://ask.dcloud.net.cn/article/1150)
上图中添加位置的代码:
"statusbar": { //应用可视区域到系统状态栏下透明显示效果 "immersed": true },
解决打包成 App 后,单击 手机返回键退出应用的 bug。(可以直接把这段代码放到你 vue 项目中,重新打包,再放回来,也可以直接修改这个 index.html)
上图中的代码:
<script type="text/javascript"> //如下代码主要是解决, 打包后的 app 点击返回键直接退出的 bug. /* 自己写的 toast 提示框 */ //下面用的是调的 Android 自身的 toast 方法。 我把我自己写的 toast 注释掉 /* let flag = false; function toast(tip){if(flag) return; let oDiv = document.createElement('div'); let oBody = document.getElementsByTagName('body')[0]; oDiv.innerText = tip; oDiv.style.background = 'rgba(50, 50, 51, 0.88)'; oDiv.style.color = '#fff'; oDiv.style.textAlign = 'center'; oDiv.style.fontSize = '14px'; oDiv.style.lineHeight = '30px'; oDiv.style.width = '200px'; oDiv.style.borderRadius = '4px'; oDiv.style.position = 'fixed'; oDiv.style.left = '50%'; oDiv.style.transform = 'translateX(-50%)'; oDiv.style.bottom = '100px'; oDiv.style.zIndex = '1000'; oBody.appendChild(oDiv); flag = true; setTimeout(function(){oBody.removeChild(oDiv); flag = false; },1000);} */ /* 自己写的 toast 提示框 ---END--- */document.addEventListener(</span>'plusready', <span style="color: rgba(0, 0, 255, 1)">function</span>(a) { <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">等待plus ready后再调用5+ API:</span> <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">// 在这里调用5+ API</span> <span style="color: rgba(0, 0, 255, 1)">var</span> first = <span style="color: rgba(0, 0, 255, 1)">null</span><span style="color: rgba(0, 0, 0, 1)">; plus.key.addEventListener(</span>'backbutton', <span style="color: rgba(0, 0, 255, 1)">function</span>() { <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">监听返回键</span> <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">首次按键,提示‘再按一次退出应用’</span> <span style="color: rgba(0, 0, 255, 1)">if</span> (!<span style="color: rgba(0, 0, 0, 1)">first) { first </span>= <span style="color: rgba(0, 0, 255, 1)">new</span> Date().getTime(); <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">获取第一次点击的时间戳</span> <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> console.log('再按一次退出应用');//用自定义toast提示最好</span> <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> toast('双击返回键退出应用'); //调用自己写的吐丝提示 函数</span> plus.nativeUI.toast("双击退出", {duration:'short'}); <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">通过H5+ API 调用Android 上的toast 提示框</span> setTimeout(<span style="color: rgba(0, 0, 255, 1)">function</span><span style="color: rgba(0, 0, 0, 1)">() { first </span>= <span style="color: rgba(0, 0, 255, 1)">null</span><span style="color: rgba(0, 0, 0, 1)">; }, </span>1000<span style="color: rgba(0, 0, 0, 1)">); } </span><span style="color: rgba(0, 0, 255, 1)">else</span><span style="color: rgba(0, 0, 0, 1)"> { </span><span style="color: rgba(0, 0, 255, 1)">if</span> (<span style="color: rgba(0, 0, 255, 1)">new</span> Date().getTime() - first < 1000) { <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">获取第二次点击的时间戳, 两次之差 小于 1000ms 说明1s点击了两次,</span> plus.runtime.quit(); <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">退出应用</span>
}
}
}, false);
});
</script>
上面这段代码:我参考的文章和文档链接:
https://blog.csdn.net/qq_25252769/article/details/76913083
这个是 H5+ API 的(通过 js 调取 Android 等平台的原生方法)学习链接:http://ask.dcloud.net.cn/docs/
至此就基本上完成了,但是还会有一下 bug,我时间我再弄。
这里是我效果图:
现纯的 bug 是 进入详情页 ,点击返回也只能提示 双击退出, 而不是后退一步。
作者:暗恋桃花源丫
本人 web 前端小白,只是用博客作为笔记!
转载的文章,如有侵权 24 小时内删除!