佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 淺談html5與APP混合開發(fā)遇到的問題總結

淺談html5與APP混合開發(fā)遇到的問題總結

熱門標簽:智能手機 網(wǎng)站建設 硅谷的囚徒呼叫中心 美圖手機 阿里云 百度競價點擊價格的計算公式 使用U盤裝系統(tǒng) 檢查注冊表項

背景

在公司參與一個原生APP和h5混合開發(fā)的項目,本人在項目中負責h5部分,現(xiàn)將項目中遇到的問題總結如下:

具體問題

問題1:頁面滾動條問題

問題描述

web頁面在PC瀏覽器上瀏覽時有滾動條;但是,在移動端瀏覽器打開時,沒有滾動條

解決方法

將頁面的最外層(我一般在寫頁面時,會在body標簽內寫一個大容器,用于存放頁面的內容)設置overflow:auto/scroll;并且不能設置height屬性的值(height:100%也不行)

例子

<body>
 <div style="overflow:scroll/auto;">
  //網(wǎng)頁內容
 </div>
</body>

問題2:touchstart 和 touchend 事件的使用

問題描述

引入touch.js文件,使用touchstart和touchend事件實現(xiàn)交互效果時,在部分手機出現(xiàn)事件觸發(fā)失效的問題[例如:低版本的榮耀手機]

解決方法

方法1:"removeEventListener"和"addEventListener"一起使用

方法2:添加e.preventDefault(); 阻止部分手機默認跳轉

法3:Jquery的on實現(xiàn)事件綁定

說明:法1與法2都是原生JS使用addEventListener實現(xiàn)事件監(jiān)聽;并且dom元素使用touchstart和touchend事件時,需要結合事件綁定或者事件監(jiān)聽一起使用,否則js部分會拋出異常

代碼

//法一:
document.getElementById('list5').addEventListener('touchstart',callback, false);
document.getElementById('list5').removeEventListener('touchstart',callback, false);
document.getElementById('list5').addEventListener('touchend',callback, false);
document.getElementById('list5').removeEventListener('touchend',callback, false);

//法二:
document.getElementById('list5').addEventListener('touchstart',function(e){
 e.preventDefault();
}, false);

document.getElementById('list5').addEventListener('touchend',function(e){
 e.preventDefault();
}, false);

問題3:長按閃退的問題

情景還原

有一個XXX列表頁,長按列表頁的列表項時(觸摸到文字),在低版本手機中會出現(xiàn)閃退的情況

解決方法

js部分:在事件觸發(fā)時添加e.preventDefault();,用于阻止默認行為

css部分:添加禁止文本文本復制的代碼

代碼

//js部分:
e.preventDefault();

//css部分:
-webkit-touch-callout: none; //解決閃退
//禁止復制
-moz-user-select: none;
-khtml-user-select: none;
user-select: none;

問題4: 移動端1px的問題

問題描述

由于不同的手機有不同的像素密度,css中的1px并不等于移動設備的1px。項目中使用js和rem做移動端的屏幕適配,所以產(chǎn)生0.5px的情況,導致低版本的手機展示不了0.5px的邊框。

解決方法

使用css解決1px的問題,并且給需要設置成1px的dom元素直接寫上:border-width:1px;

代碼

//HTML部分:
<div class='class1'></div>

//css部分:
.class1{
 border: 1px solid #ccc;
}

//css部分
/*移動端正常展示1px的問題 start*/
%border-1px{
    display: block;
    position:absolute;
    left: 0;
    width: 100%;
    content: ' ';
}
.border-1px{
    position: relative;
    &::after{
        @extend %border-1px;
        bottom: 0;
        border-top: 1px solid #ccc;
    }
    &::before{
        @extend %border-1px;
        top: 0;
        border-bottom: 1px solid #ccc;
    }
}

@media (-webkit-min-device-pixel-ratio:1.5),(min-device-pixel-ratio:1.5){
    .border-1px{
        &::after{
            -webkit-transform: scaleY(0.7);
            transform: scaleY(0.7);
        }
    }
}

@media (-webkit-min-device-pixel-ratio:2),(min-device-pixel-ratio:2){
    .border-1px{
        &::after{
            -webkit-transform: scaleY(0.5);
            transform: scaleY(0.5);
        }
    }
}
/*移動端正常展示1px的問題 end*/

問題5:js無法正確解析到url包含"="號的參數(shù)值

問題描述

項目中,由于數(shù)據(jù)請求的參數(shù)值是從url地址中獲取的參數(shù)值,并且參數(shù)值包含"="號,導致無法正確解析到參數(shù)值(ps:js使用"="號分割url的參數(shù))

解決方法

將url進行轉碼,再解碼【本項目中,APP端提供轉碼后的url地址,前端使用geturlparams插件,獲得url地址的參數(shù)值】

代碼

//解碼"="號
dom.token = decodeURI($.query.get("token"));//插件
//獲取無需解碼的值
dom.msgid = $.query.get("msgid");

問題6:原生js的事件監(jiān)聽和jquery的事件綁定在ios中失效

問題描述

使用事件監(jiān)聽或事件綁定時,由于父元素選擇body或document元素,導致在ios中事件觸發(fā)無效

解決方法

不使用body和document元素作為父級元素

問題7:ios中日期顯示為NaN

問題描述

Date的日期格式,在ios中有兼容性問題,ios的日期會顯示成:NaN

解決方法

解決方法:在ios中支持"2017/12/26 19:36:00",而不支持"2017-12-26 19:36:00"格式,后面一種格式,在ios中顯示Nan (Android中都可以顯示正常)

代碼

var time = "2017-12-26 19:36:00";
time = time.replace(/\-/g, "/");//將時間格式的'-'轉成'/'形式,兼容iOS

問題8:click事件在ios中有問題

問題描述

click事件在ios點擊觸發(fā)時,會選中事件委托的父級元素模塊【即:由于事件冒泡,并且父級有默認樣式】,并且有一個透明層,例如

<ul>
 <li>列表項1</li>
 <li>列表項2</li>
 <li>列表項3</li>
</ul>

解析:例如ios用戶點擊"列表項1"時,父層的ul會有一個透明的樣式

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:懷化 賀州 通遼 煙臺 山南 湖北 黃山 湘潭

巨人網(wǎng)絡通訊聲明:本文標題《淺談html5與APP混合開發(fā)遇到的問題總結》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    依兰县| 信阳市| 枞阳县| 罗城| 鄯善县| 界首市| 隆尧县| 滦平县| 长汀县| 纳雍县| 九龙坡区| 五莲县| 宁晋县| 兴业县| 余姚市| 临桂县| 星子县| 城步| 西城区| 宝丰县| 焉耆| 航空| 南昌县| 罗平县| 清河县| 镇巴县| 洮南市| 阜平县| 鄂州市| 西林县| 重庆市| 西平县| 北海市| 奉新县| 金昌市| 廉江市| 北宁市| 新闻| 黄浦区| 射洪县| 临西县|