• 用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('plusready', function(a) { //等待plus ready后再调用5+ API:
                    //// 在这里调用5+ API
                    var first = null;
                    plus.key.addEventListener('backbutton', function() { //监听返回键
                            //首次按键,提示‘再按一次退出应用’
                            if (!first) {
                                first = new Date().getTime(); //获取第一次点击的时间戳
                                // console.log('再按一次退出应用');//用自定义toast提示最好
                                // toast('双击返回键退出应用'); //调用自己写的吐丝提示 函数
                                plus.nativeUI.toast("双击退出", {duration:'short'}); //通过H5+ API 调用Android 上的toast 提示框
                                setTimeout(function() {
                                    first = null;
                                }, 1000);
                            } else {
                                if (new Date().getTime() - first < 1000) { //获取第二次点击的时间戳, 两次之差 小于 1000ms 说明1s点击了两次,
                                    plus.runtime.quit(); //退出应用
                                }
                            }
                        }, false);
                });
    </script>

     上面这段代码:我参考的文章和文档链接:

    https://blog.csdn.net/qq_25252769/article/details/76913083

    这个是 H5+ API 的(通过js调取Android等平台的原生方法)学习链接:http://ask.dcloud.net.cn/docs/

     至此就基本上完成了,但是还会有一下bug,我时间我再弄。

     这里是我效果图:

     

     现纯的bug 是 进入详情页 ,点击返回也只能提示    双击退出, 而不是后退一步。

  • 相关阅读:
    解决 el-table在ie11中默认状态下不是百分百展开的问题
    在vue中使用lexible.js 通过props传的style样式无法转换成rem
    解决 el-select 与 el-radio 组合字体发生闪烁问题
    解决element生成的下拉菜单,不在父级之下,而是在body之下,通过父级控制该下拉菜单的样式,达到不跟别的地方冲突的目的
    解决nvm use提示切换node版本成功,实际却没有切换过对应版本
    vue-element-admin安装失败的问题
    今天转正了,感谢博客园让我找到工作!
    electron-vue中点击按钮,实现打开程序目录里面的某个文件
    项目实战---模拟站酷网站
    vue实现选项卡切换效果
  • 原文地址:https://www.cnblogs.com/taohuaya/p/10263519.html
Copyright © 2020-2023  润新知