要CSS僞類 :active 生效,只須要給 document 綁定 touchstart 或 touchend 事件html
<style> a { color: #000; } a:active { color: #fff; } </style> <a herf=foo >bar</a> <script> document.addEventListener('touchstart',function(){},false); </script>
兩個方法git
-webkit-transform-style: preserve-3d; /*設置內嵌的元素在 3D 空間如何呈現:保留 3D*/ -webkit-backface-visibility: hidden; /*(設置進行轉換的元素的背面在面對用戶時是否可見:隱藏)*/
input:-ms-clear{display:none;}
iOS 瀏覽器橫屏時會重置字體大小,設置 text-size-adjust
爲 none
能夠解決 iOS 上的問題,但桌面版 Safari 的字體縮放功能會失效,所以最佳方案是將 text-size-adjust
爲 100%
。web
-webkit-text-size-adjust: 100%;
-ms-text-size-adjust: 100%;
text-size-adjust: 100%;
click 事件廣泛 300ms 的延遲 在手機上綁定 click 事件,會使得操做有 300ms 的延遲,體驗並非很好。 開發者大多數會使用封裝的 tap 事件來代替 click 事件,所謂的 tap 事件由 touchstart 事件 + touchmove 判斷 + touchend 事件封裝組成sublime-text
使用 CSS3 動畫的時儘可能利用3D加速,從而使得動畫變得流暢。動畫過程當中的動畫閃白能夠經過 backface-visibility 隱藏。瀏覽器
-webkit-transform-style: preserve-3d;
-webkit-backface-visibility: hidden;
<meta content="email=no" name="format-detection" />
禁止 iOS 識別長串數字爲電話cookie
<meta content="telephone=no" name="format-detection" />
禁止 iOS 彈出各類操做窗口dom
-webkit-touch-callout:none
-webkit-user-select:none
window.scrollY
window.scrollX
好比要綁定一個 touchmove 的事件,正常的狀況下相似這樣(來自呼吸二氧化碳)佈局
$('div').on('touchmove', function(){ //.….code });
而若是中間的 code 須要處理的東西多的話,FPS 就會降低影響程序順滑度,而若是改爲這樣測試
$('div').on('touchmove', function(){ setTimeout(function(){ //.….code },0); });
把代碼放在 setTimeout 中,會發現程序變快.字體
能夠經過正則去掉
this.value = this.value.replace(/\u2006/g, '');
見圖
Android web視圖,例如在 HTC EVO 和三星的 Galaxy Nexus 中,文本輸入框在輸入時表現的就像佔位符。狀況爲一個相似水印的東西在用戶輸入區域,一旦用戶開始輸入便會消失(見圖片)。
在 Android 的默認樣式下當輸入框得到焦點後,若存在一個絕對定位或者fixed的元素,佈局會被破壞,其餘元素與系統輸入字段會發生重疊(如搜索圖標將消失爲搜索字段),能夠觀察到佈局與原始輸入字段有誤差(見截圖)。 這是一個至關複雜的問題,如下簡單佈局能夠重現這個問題:
<label for="phone">Phone: *</label>
<input type="tel" name="phone" id="phone" minlength="10" maxlength="10" inputmode="latin digits" required="required" />
解決方法
-webkit-user-modify: read-write-plaintext-only
詳細:Androdi開發劉亞超WebView視頻教程 http://www.gooln.com/zip/124870.html 該屬性會致使中文不能輸入詞組,只能單個字。感謝鬼哥與飛(遊勇飛)貢獻此問題與解決方案
解決方法刪除了 overflow-x:hidden;
而後在JS生成下來菜單以後 focus 聚焦,這兩步操做以後解決了問題。(來自島都-小Qi)
這個不是 BUG,因爲自動播放網頁中的音頻或視頻,會給用戶帶來一些困擾或者沒必要要的流量消耗,因此蘋果系統和安卓系統一般都會禁止自動播放和使用 JS 的觸發播放,必須由用戶來觸發才能夠播放。
解決方法思路:先經過用戶 touchstart 觸碰,觸發播放並暫停(音頻開始加載,後面用 JS 再操做就沒問題了)。
解決代碼:
document.addEventListener('touchstart', function () { document.getElementsByTagName('audio')[0].play(); document.getElementsByTagName('audio')[0].pause(); });
input type date 的 placeholder 支持性有必定問題,由於瀏覽器會針對此類型 input 增長 datepicker 模塊,看上去沒那麼必要支持 placeholder。
對 input type date 使用 placeholder 的目的是爲了讓用戶更準確的輸入日期格式,iOS 上會有 datepicker 不會顯示 placeholder 文字,可是爲了統一表單外觀,每每須要顯示。Android 部分機型沒有 datepicker 也不會顯示 placeholder 文字。
簡單的進行了測試:
桌面端(Mac)
移動端
問題解決方法:
先使其 type 爲 text,此時支持 placeholder,當觸摸或者聚焦的時候,使用 JS 切換使其觸發 datepicker 功能。
<input placeholder="Date" class="textbox-n" type="text" onfocus="(this.type='date')" id="date">
平臺:IOS8.1
browser:Safari600.1.4
問題源自於項目須要在瀏覽器中遮罩提示,點擊關閉狀態存儲在localstorage中。Safari瀏覽器關閉後刷新頁面層依舊存在 bug issue 簡單的存儲狀態可使用cookie的方式替代。
系統:IOS8.1
瀏覽器:Chrome 26.0.1410.53
描述信息:頁面包含fixed頂部的tip element,當頁面向下滑動的時候Chrome地址欄自動隱藏,當向上滑動的時候地址欄自動出現。這種交互行爲自己的好處會增大用戶可視、交互區域。可是在Chrome 26這個版本這個瀏覽器UI佈局使用adjustPan的方式,以致於向上滑動之後fixed的元素沒有被自動向下移動(沒有重繪)。
bug fixed 解決辦法在這裏
問題發現於三星手機,這個在特定需求下才會有,所以若是沒有相似問題的能夠不看。首先需求是浮層操做,在三星上被遮罩的元素依然能夠獲取focus、click、change. bug issue ,在查看bug報告list之後,找到了兩種解決方案,第一是經過層顯示之後加入對應的class名控制,第二是經過將可獲取焦點元素加入的disabled屬性,也能夠利用屬性加dom鎖定的方式(disabled的一種變換方式)
有些機型的搜索input控件會自帶close按鈕(一個僞元素),而一般爲了兼容全部瀏覽器,咱們會本身實現一個,此時去掉原生close按鈕的方法爲
#Search::-webkit-search-cancel-button{ display: none; }
若是想使用原生close按鈕,又想使其符合設計風格,能夠對這個僞元素的樣式進行修改。
zepto方式:
$(sltElement).trrgger("mousedown");
原生js方式:
function showDropdown(sltElement) { var event; event = document.createEvent('MouseEvents'); event.initMouseEvent('mousedown', true, true, window); sltElement.dispatchEvent(event); };