年初隨筆

来源:http://www.cnblogs.com/antelope/archive/2017/01/23/6341562.html
-Advertisement-
Play Games

2017年也已經開始了快一個月的時間了,然而我卻好像沒有跨進新一年的感覺 過去的一年裡,前端開發這個行業的變化給我的感覺實在是快得有點眼花繚亂應接不暇 各種工程化工具,各種新框架占據了這個行業裡人們日常討論的話題 然而反思回自己的團隊,仍然是停留在比較基礎的開發流程。不得不讓我恍然醒悟,自己真是半年 ...


2017年也已經開始了快一個月的時間了,然而我卻好像沒有跨進新一年的感覺

過去的一年裡,前端開發這個行業的變化給我的感覺實在是快得有點眼花繚亂應接不暇

各種工程化工具,各種新框架占據了這個行業裡人們日常討論的話題

然而反思回自己的團隊,仍然是停留在比較基礎的開發流程。不得不讓我恍然醒悟,自己真是半年的經驗湊合用了兩年。

所以選擇在這樣一個時間,記錄下自己的這半年經驗,做為一個分隔線,讓自己突破現在的狀態。

移動開發篇:

最先接觸的移動端自適應的做法,大概是手淘家的flexible.js

具體做法就是通過控制html根元素的font-size值搭配rem單位來實現的適應。有個值得註意的地方是flexible還通過動態生成meta標簽來改變viewport縮放,實現對iphone系列的高度自適應(語文不好真不知道怎麼形容),達到一個在Retina屏幕下頁面顯示質量也不會受太大影響

後來刷論壇的時候,接觸到了一些其他大神的做法,比如我現在也在使用的通過calc屬性來改變html的font-size值來實現的適應,搭配媒體查詢來實現一些低版本瀏覽器的相容,畢竟佈局本來就是html和css的職責,能不用js來實現就儘量不用

flex佈局:

flex在移動端上確實非常好用,基本可以代替float和定位,垂直居中也比以往的display-table來的方便。

唯一要註意的就是flex有一個早期版本的相容寫法

現在的語法:

/*父容器*/
    .box{                                        
        display:-webkit-flex;
        
        display:flex;
        
        /*行內元素也可也用flex*/
        display: inline-flex;
    }
    /*父容器樣式*/
    .box{
        /*主軸方向*/
        flex-direction:row; /*row:從左到右   column:從上到下*/
        
        /*主軸對齊*/
        justify-content:center;/*flex-start:左對齊  flex-end:右對齊   space-between:兩端對齊*/
        
        /*交叉軸對齊*/
        align-items:center;/*flex-start:頂部對齊  flex-end:底部對齊*/
    }
    /*子元素*/
    .item{
        /*排序*/
        order:0; /*數值越小排越前*/
        
        /*元素放大比例,0表示不放大*/
        flex-grow:0;
        
        /*元素縮小比例,0表示不縮小*/
        flex-shrink:1; 
        
        /*固定大小*/
        flex-basis: 1;
    
           /*綜合上面三種的簡寫,預設值0 1 auto*/
        flex:xx;
    }
View Code

舊版本相容語法:(發現有相容問題可以嘗試加上此相容寫法)

/*父容器*/
    .box{                                        
        display:-webkit-box;
        display:box;
    }
    /*父容器樣式*/
    .box{
        /*排列方式*/
        box-orient:horizontal; /*horizontal:水平方向   vertical:垂直*/
        
        /*方向*/
        box-direction:normal; /*normal:預設方向   reverse:反方向*/
        
        /*主軸對齊*/
        box-pack:center;/*start:左對齊  end:右對齊   justify:兩端對齊*/
        
        /*交叉軸對齊*/
        box-align:center;/*start:頂部對齊  end:底部對齊*/
    }
    /*子元素*/
    .item{
        /*排序*/
        box-ordinal-group:0; /*數值越小排越前*/

        box-flex:xx;
    }
View Code

移動端踩坑系列:

click延遲:

說起移動端上的坑,估計第一個都會想到click的延遲,由於我們的採用的框架是zepto,所以可以用tap事件來提高點擊體驗。

早期的zepto上的tap事件還有一個"點透"的問題,可以通過採用類似loading彈出層的方式來阻止後發的click事件作用到我們的目標頁面。不過最新版本的zepto已經解決這個問題,可以放心引用。

目前所知解決延遲的方式還有fastclick.js;如果什麼插件庫都不想引用的話,可以嘗試使用loading彈層的方式來減少用戶的延遲感

元素點擊響應的預設邊框和觸摸遮罩:

-webkit-tap-highlight-color:transparent; 可以將觸摸的遮罩顏色透明化,當然也可而已設置為其他顏色

按鈕點擊的active效果:

移動端上的hover和active事件都是無效的,可以給該元素綁定一個空的touchstart的空事件,可以激活active效果

也可以通過touchstart和touchend來增減類名,不過在性能比較差的機子上會出現長按釋放後樣式一直存在的問題

獲取元素最終應用到的樣式:

前面說過通過改變根元素的font-size值搭配rem單位來做適配的方法,這個時候就需要準確的獲取根元素的font-size值

而element.sytle.fontSize是取不到樣式表上的屬性值的,要去到樣式表上的應用的樣式,必須用getComputedStyle。

border-radius的背景色溢出:

一些舊版本的系統或瀏覽器會出現當border-radius和背景色同時存在的時候,圓角以外的部分也會有背景色溢出

此時可以加上 background-clip:padding-box 來修複

background-clip規定了背景的繪製區域,padding-box表示將背景裁剪到內邊距里

結尾:

碎碎念的東西到這裡就先結束吧,祝全天下新年快樂


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在"初探nodeJS"隨筆中,我們對於node有了一個大致地瞭解,併在最後也通過一個示例,瞭解瞭如何快速地開啟一個簡單的伺服器。今兒,再次看了該篇隨筆,發現該隨筆理論知識稍多,適合初級入門node,固萌生一個想法--想在該篇隨筆中,通過一步步編寫一個稍大一點的node示例,讓我們在整體上更加全面地了... ...
  • A jQuery tabs module for todays web! 實例DEMO 運行一下 Documentation Tabulous.js can be used with any contents you choose in the tabs and it couldn't be mor ...
  • html css css3 javascript html5 jQuery jQuery UI jQuery EasyUI Exits Highcarts Chart Two Jsp Asp.net PHP Python MySql SQL Server Oracle MongDB XML JONG ...
  • 下麵這個是結合css+html5+javascript的一個更複雜的圓環圖形 原文鏈接:HTML5 CSS3如何繪製任意角度的扇形 ...
  • ▓▓▓▓▓▓ 大致介紹 Git是一款免費、開源的分散式版本控制系統,用於敏捷高效地處理任何或小或大的項目,可以有效、高速的處理從很小到非常大的項目版本管理。 Git 是 Linus Torvalds 為了幫助管理 Linux 內核開發而開發的一個開放源碼的版本控制軟體 ▓▓▓▓▓▓ Git的誕生 G ...
  • [1]刷新 [2]搜索 [3]計算樣式 [4]資源映射 [5]當前位置 ...
  • 層次選擇器: $("div li")獲取div下的所有li元素(後代、子、子的子......) $("div>li")獲取div下的直接li子元素。 $(".menuitem+div")獲取樣式名為menuitem之後的第一個div元素(不常用)。 $(".menuitem~div")獲取樣式名為m ...
  • yield next和yield* next之間到底有什麼區別?為什麼需要yield* next?經常會有人提出這個問題。雖然我們在代碼中會儘量避免使用yield* next以減少新用戶的疑惑,但還是經常會有人問到這個問題。為了體現自由,我們在koa框架內部使用了yield* next,但是為了避免 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...