解決vue 界面在蘋(píng)果手機(jī)上滑動(dòng)點(diǎn)擊事件等卡頓問(wèn)題
用vue編寫(xiě)項(xiàng)目接近尾聲,需要集成到移動(dòng)端中,在webstorm上界面,運(yùn)行效果都很完美,但是在蘋(píng)果手機(jī)上各種問(wèn)題都出現(xiàn)了,原生項(xiàng)目一向滑動(dòng)流暢,事件響應(yīng)迅速,可是蘋(píng)果手機(jī)打開(kāi)這個(gè)項(xiàng)目有兩個(gè)問(wèn)題,
(1).滑動(dòng)頁(yè)面卡頓,
(2).點(diǎn)擊事件響應(yīng)緩慢,百度才發(fā)現(xiàn)在蘋(píng)果手機(jī)上有300ms的延遲。
一.滑動(dòng)頁(yè)面卡頓
//頁(yè)面布局 <template> <div class='content'> 頁(yè)面內(nèi)容 </div> </template>
在對(duì)應(yīng)的組件的最外層div上加上這樣的樣式:
.content{ -webkit-overflow-scrolling: touch; }
-webkit-overflow-scrolling: touch;這句代碼最好可在公共的樣式中添加,防止很多頁(yè)面都需要寫(xiě)的麻煩。這句代碼雖然可以解決滑動(dòng)不流暢的問(wèn)題,但是可能會(huì)引起幾個(gè)小問(wèn)題:
(1).在滑動(dòng)界面之中使用的position:fixed 無(wú)法固定下來(lái),會(huì)隨著界面進(jìn)行一起滾動(dòng)
解決方法:將使用的position:fixed(頭部導(dǎo)航)寫(xiě)在滑動(dòng)部位外部,在使用絕對(duì)定位進(jìn)行布局,以此解決問(wèn)題
(2).vue中使用v-if導(dǎo)致的界面第一次無(wú)法滑動(dòng)
解決方法:將v-if改成v-show進(jìn)行展示,解決界面進(jìn)入之后不能滑動(dòng)的問(wèn)題
二.點(diǎn)擊事件響應(yīng)緩慢
(1).安裝fastclick (npm install fastclick -S)
(2).在main.js中設(shè)置方法
import FastClick from 'fastclick' FastClick.attach(document.body);
在引入fastclick之后,雖然頁(yè)面事件快了很多,但是會(huì)有一個(gè)副作用:input輸入框需要連續(xù)點(diǎn)擊兩次或者長(zhǎng)按才能獲取焦點(diǎn),真是到處是坑啊!
解決方法:在main.js中添加下面的代碼
FastClick.prototype.focus = function(targetElement) { var length; // Issue #160: on iOS 7, some input elements (e.g. date datetime month) throw a vague TypeError on setSelectionRange. These elements don't have an integer value for the selectionStart and selectionEnd properties, but unfortunately that can't be used for detection because accessing the properties also throws a TypeError. Just check the type instead. Filed as Apple bug #15122724. if (deviceIsIOS&& targetElement.setSelectionRange && targetElement.type.indexOf('date') !== 0 && targetElement.type !== 'time' && targetElement.type !== 'month') { length = targetElement.value.length; targetElement.focus(); targetElement.setSelectionRange(length, length); } else { targetElement.focus(); } };
總結(jié)
以上所述是小編給大家介紹的解決vue 界面在蘋(píng)果手機(jī)上滑動(dòng)點(diǎn)擊事件等卡頓問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
Vue resource中的GET與POST請(qǐng)求的實(shí)例代碼
本篇文章主要介紹了Vue resource中的GET與POST請(qǐng)求的實(shí)例代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-07-07Vue.js中this如何取到data和method里的屬性詳解
methods屬性是一個(gè)對(duì)象,通常我們會(huì)在這個(gè)對(duì)象中定義很多的方法,下面這篇文章主要給大家介紹了關(guān)于Vue.js中this如何取到data和method里的屬性,需要的朋友可以參考下2022-12-12通過(guò)實(shí)例解析vuejs如何實(shí)現(xiàn)調(diào)試代碼
這篇文章主要介紹了通過(guò)實(shí)例解析vuejs如何實(shí)現(xiàn)調(diào)試代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07vscode 開(kāi)發(fā)Vue項(xiàng)目的方法步驟
這篇文章主要介紹了vscode 開(kāi)發(fā)Vue項(xiàng)目的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11Vue.js簡(jiǎn)易安裝和快速入門(mén)(第二課)
這篇文章主要為大家詳細(xì)介紹了Vue.js簡(jiǎn)易安裝和快速入門(mén)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài)
這篇文章主要介紹了關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03vue實(shí)現(xiàn)對(duì)highlight-current-row方式整行選中后修改默認(rèn)背景顏色
這篇文章主要介紹了vue實(shí)現(xiàn)對(duì)highlight-current-row方式整行選中后修改默認(rèn)背景顏色方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11vue element-ul實(shí)現(xiàn)展開(kāi)和收起功能的實(shí)例代碼
這篇文章主要介紹了vue element-ul實(shí)現(xiàn)展開(kāi)和收起功能的實(shí)例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11