比如我們就用vue仿着淘寶寫一個項目,我最近做了一個仿淘寶
首先打包你的 vue 項目 生成 dist 文件夾,教程請移步 https://www.cnblogs.com/taohuaya/p/10256670.html
看完上面的教程,請確保 你是 將:
項目目錄下的config
文件夾里的index.js
文件中,將build
對象下的assetsPublicPath
中的“/”
,改為“./”后,打包生成的 dist 文件。
開始使用 HBuiderX 打包。(工具下載地址:http://www.dcloud.io/)
設置沉浸狀態欄:(什么是沉浸狀態欄和設置方法 請移步: http://ask.dcloud.net.cn/article/32 地址里的 http://ask.dcloud.net.cn/article/1150)
上圖中添加位置的代碼:
"statusbar": { //應用可視區域到系統狀態欄下透明顯示效果 "immersed": true },
解決打包成App后,單擊 手機返回鍵退出應用的bug。(可以直接把這段代碼放到你vue項目中,重新打包,再放回來,也可以直接修改這個index.html)
上圖中的代碼:
1 <script type="text/javascript"> 2 //如下代碼主要是解決, 打包后的app點擊返回鍵直接退出的bug. 3 /* 自己寫的 toast 提示框 */ 4 //下面用的是調的 Android 自身的 toast方法。 我把我自己寫的toast 注釋掉 5 /* 6 let flag = false; 7 function toast(tip){ 8 if(flag) return; 9 let oDiv = document.createElement('div'); 10 let oBody = document.getElementsByTagName('body')[0]; 11 oDiv.innerText = tip; 12 oDiv.style.background = 'rgba(50, 50, 51, 0.88)'; 13 oDiv.style.color = '#fff'; 14 oDiv.style.textAlign = 'center'; 15 oDiv.style.fontSize = '14px'; 16 oDiv.style.lineHeight = '30px'; 17 oDiv.style.width = '200px'; 18 oDiv.style.borderRadius = '4px'; 19 oDiv.style.position = 'fixed'; 20 oDiv.style.left = '50%'; 21 oDiv.style.transform = 'translateX(-50%)'; 22 oDiv.style.bottom = '100px'; 23 oDiv.style.zIndex = '1000'; 24 oBody.appendChild(oDiv); 25 flag = true; 26 setTimeout(function(){ 27 oBody.removeChild(oDiv); 28 flag = false; 29 },1000); 30 } 31 */ 32 /* 自己寫的 toast 提示框---END--- */ 33 34 document.addEventListener('plusready', function(a) { //等待plus ready后再調用5+ API: 35 //// 在這里調用5+ API 36 var first = null; 37 plus.key.addEventListener('backbutton', function() { //監聽返回鍵 38 //首次按鍵,提示‘再按一次退出應用’ 39 if (!first) { 40 first = new Date().getTime(); //獲取第一次點擊的時間戳 41 // console.log('再按一次退出應用');//用自定義toast提示最好 42 // toast('雙擊返回鍵退出應用'); //調用自己寫的吐絲提示 函數 43 plus.nativeUI.toast("雙擊退出", {duration:'short'}); //通過H5+ API 調用Android 上的toast 提示框 44 setTimeout(function() { 45 first = null; 46 }, 1000); 47 } else { 48 if (new Date().getTime() - first < 1000) { //獲取第二次點擊的時間戳, 兩次之差 小於 1000ms 說明1s點擊了兩次, 49 plus.runtime.quit(); //退出應用 50 } 51 } 52 }, false); 53 }); 54 </script>
上面這段代碼:我參考的文章和文檔鏈接:
https://blog.csdn.net/qq_25252769/article/details/76913083
這個是 H5+ API 的(通過js調取Android等平台的原生方法)學習鏈接:http://ask.dcloud.net.cn/docs/
https://www.cnblogs.com/taohuaya/p/10263519.html