移動端的知識點不少,可是咱們公司不大,並且對移動web的相關細節並非過重視,只是整理了這些。
按照這個順序學習下來,相信簡單的項目應該就能應付了。注:相關理論不作詳細介紹,附上學習連接
javascript
包括內容: css初始化、css全局設置、經常使用meat標籤、rem適配、flex佈局、相關技巧(手勢庫使用、多行截字、1像素邊線、點擊狀態、placeholder居中等)css
reset 引用 normalize.css
html
css全局設置 包括字體、行高、默認webkit瀏覽器屬性重置前端
meta標籤(禁用長按下載保存、禁止數字識別爲號碼等)java
rem公式和sass函數(如何根據設計稿換算單位,而且寫好sass函數 pxTorem) 參考, Sass基礎——Rem與Px的轉換android
flex佈局 參考騰訊isux的 移動端全兼容的flexbox速成班ios
單行、多行的截字git
按鈕active狀態 白色橡樹的博客中提到了 模擬按鈕hover效果github
手勢庫使用(hammerJS)web
高清屏1像素邊框 移動web 1像素邊框 瞧瞧大公司是怎麼作的
placeholder屬性設置的文字向上偏移的厲害 placeholder屬性設置的文字向上偏移的厲害
Normalize介紹 - 下載地址 瀏覽器支持狀況:Chrome, Firefox, Opera, Safari 6+, IE 8+
Normalize.css 是一個能夠定製的CSS文件,它讓不一樣的瀏覽器在渲染網頁元素的時候形式更統一。
行高字號顏色什麼的就根據項目的視覺規範本身來定義,比較重要的是移動端的字體
和a連接以及表單元素
的初始化樣式。
body { font-family: "Helvetica Neue", Helvetica, STHeiTi, sans-serif; } a,button,input,textarea{ -webkit-tap-highlight-color: rgba(0,0,0,0;) -webkit-user-modify:read-write-plaintext-only; } input[type=number]::-webkit-textfield-decoration-container { background-color: transparent; } input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; } input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; } input{-webkit-appearance:none;}
主要是定義了比例
,蘋果全屏顯示
、狀態條顏色、禁止數字識別爲電話號碼、禁止郵件識別爲連接
具體根據需求增長。
<meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport"> <meta content="yes" name="apple-mobile-web-app-capable"> <meta content="black" name="apple-mobile-web-app-status-bar-style"> <meta content="telephone=no" name="format-detection"> <meta content="email=no" name="format-detection">
一、頁面加上js (通用代碼)
二、根據公式算出數值 (設計稿寬度/320)*20
三、編寫sass函數 函數中 40 就根據公式2算出來的結果 能夠參考《Sass基礎——Rem與Px的轉換》
四、在sass 文件中 直接調用:height:px(492)
//sass 方法 @function px($px){ @return ($px/40)+rem; }
//js代碼 ;(function(win, doc){ function change(){ doc.documentElement.style.fontSize=20*doc.documentElement.clientWidth/320+'px'; } change(); win.addEventListener('resize', function(){ change(); }, false); })(window, document);
網上關於flex的介紹不少,此處再也不展開 參考《移動端全兼容的flexbox速成班》
/* ============================================================ flex:定義佈局爲盒模型 flex-v:盒模型垂直佈局 flex-1:子元素佔據剩餘的空間 flex-align-center:子元素垂直居中 flex-pack-center:子元素水平居中 flex-pack-justify:子元素兩端對齊 兼容性:ios 4+、android 2.3+、winphone8+ ============================================================ */ .flex{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;} .flex-v{-webkit-box-orient:vertical;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;} .flex-1{-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;} .flex-align-center{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;} .flex-pack-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;} .flex-pack-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;}
//單行css截字 div{ overflow: hidden; text-overflow:ellipsis; white-space: nowrap; }
//多行截字 div{ display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden; }
本身按照網上的方式作了例子,雖然都有active的效果了,可是響應速度
不同,最快的仍是js的方式。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport"> <meta content="yes" name="apple-mobile-web-app-capable"> <meta content="black" name="apple-mobile-web-app-status-bar-style"> <meta content="telephone=no" name="format-detection"> <meta content="email=no" name="format-detection"> <style type="text/css"> a{-webkit-tap-highlight-color: rgba(0,0,0,0);} .btn-blue{display:block;height:42px;line-height:42px;text-align:center;border-radius:4px;font-size:18px;color:#FFFFFF;background-color: #4185F3;} .btn-blue-on{background-color: #357AE8;} </style> </head> <body> <div class="btn-blue">按鈕</div> <script type="text/javascript"> var btnBlue = document.querySelector(".btn-blue"); btnBlue.ontouchstart = function(){ this.className = "btn-blue btn-blue-on" } btnBlue.ontouchend = function(){ this.className = "btn-blue" } </script> </body> </html>
hammer是一個移動端是手勢庫, http://hammerjs.github.io/ 這是他們的官網,這些英文不是太難,利用翻譯軟件應該就能輕鬆學習,具體細節再也不展開,只貼一個簡單的demo代碼吧。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>hammer.js</title> <style> #div{ width: 100px; height: 100px; background: red;transition:transform 1s; margin:100px auto;} </style> <script src="hammer.min.js"></script> </head> <body> <div id="div"></div> <script type="text/javascript"> var el = document.getElementById('div'); Hammer(el).on('swipeleft',function(e){ // alert('快速左滑成功'); console.log(e.deltaX); el.style.transform='translateX('+e.deltaX+'px)'; }); </script> </body> </html>
實現方式不少,主要原理仍是經過調整viewpor的縮放比或者將1px的元素壓縮0.5來實現,移動web 1像素邊框 瞧瞧大公司是怎麼作的,文章寫得比較詳細,看完就能明白了,下邊的代碼是用 border-images 使用base64的圖片實現的。
.border-image-1px { border-width: 1px 0px; -webkit-border-image: url("") 2 0 stretch; }
在查看京東、糯米、美團等一些webapp的時候也發現有蘋果和安卓不居中的狀況,並且很嚴重,網上所設置這個屬性,可是沒有效果並很差,建議使用padding的形式,我抽時間研究研究其餘框架後再
//placeholder屬性設置的文字向上偏移的厲害 Android4.x部分機型 inpu{ line-height:normal }
AlloyTeam 騰訊移動Web前端知識庫 《面向億萬用戶級的移動端Web解決方案》
騰訊微信支付設計中心白樹的博文 【原】移動web資源整理
手Q開發 Mobile開發經驗沉澱
參考白色橡樹的移動web資源整理