鍍金池/ 問(wèn)答/HTML5  HTML/ fastclick,tap之類的類庫(kù)還有使用的必要嗎?

fastclick,tap之類的類庫(kù)還有使用的必要嗎?

這些類庫(kù)是為了解決300毫秒延遲以及點(diǎn)透bug出現(xiàn)的.

剛轉(zhuǎn)移動(dòng)開發(fā)的時(shí)候沒(méi)想太多,找了幾篇文章都提到這些問(wèn)題.提出的方案一般都是推薦使用這類插件.因此也就無(wú)腦采納了.

現(xiàn)在回過(guò)頭來(lái)發(fā)現(xiàn)這些類庫(kù)本身也是有很多缺陷的.多次派發(fā),input失效,點(diǎn)擊失靈等等,不一而足.一些庫(kù)的用法更是非常別扭,比如vue-tap,使用指令的方式--v-tap="{methods:handler}";

模仿zepto的tap嘗試自己實(shí)現(xiàn)過(guò)一個(gè)類似的庫(kù).測(cè)試不到位,自己也覺(jué)得問(wèn)題估計(jì)不少.覺(jué)得實(shí)際上走上了死胡同.

剛學(xué)編程的時(shí)候,非常喜歡造輪子.喜歡各種奇技淫巧.但漸漸的,發(fā)現(xiàn)其實(shí)標(biāo)準(zhǔn)才是解決問(wèn)題的正經(jīng)道路.

300毫秒是移動(dòng)開發(fā)方興未艾的時(shí)候的設(shè)計(jì)缺陷.實(shí)際上相關(guān)的標(biāo)準(zhǔn)早就修復(fù)了這個(gè)問(wèn)題.方式如下

1.viewport
<meta name="viewport" content="width=device-width">

瀏覽器檢測(cè)到這個(gè)標(biāo)簽,會(huì)認(rèn)為這是一個(gè)已經(jīng)對(duì)移動(dòng)端做了良好適配的頁(yè)面,會(huì)禁用雙擊縮放.也就不存在點(diǎn)擊延遲問(wèn)題.

2.touch-action
html {
  touch-action: manipulation;
}

這個(gè)屬性用于指定元素對(duì)touch事件的響應(yīng)方式.
詳見MDN
兼容性不錯(cuò)

至于點(diǎn)透,這個(gè)問(wèn)題其實(shí)只要知道了原因,很好解決.

<!-- box定位在鏈接上方 -->
<div class="box" ontouchend="this.style.display='none'">
</div>
<a >百度一下,你就知道</a>

上面的代碼會(huì)導(dǎo)致點(diǎn)擊box隱藏時(shí)跳轉(zhuǎn).
解決方式非常簡(jiǎn)單

<div class="box" ontouchend="setTimeout(()=>{this.style.display='none'})">
</div>

把隱藏操作放在異步回調(diào)里,保證這個(gè)操作在元素派發(fā)click之后執(zhí)行就完全可以避免點(diǎn)透.
實(shí)際上這種會(huì)導(dǎo)致點(diǎn)透的場(chǎng)景在頁(yè)面中并不常見.為了解決這種問(wèn)題引入一些問(wèn)題多多的第三方類庫(kù)實(shí)在是因噎廢食.

當(dāng)然,這只是個(gè)人看法.我正是因?yàn)椴⒉荒艽_定是否還有沒(méi)有考慮到地方,加的群少,也沒(méi)地方問(wèn),因此來(lái)此收集下大家的看法,希望各位不嗇賜教.多謝各位.

回答
編輯回答
歆久

我同意你的看法

2017年5月25日 02:54