如何適配處理iphoneX底部的橫條 ?(轉)

  iphoneX手機取消了實體Home鍵,取而代之的是主界面底部不顯眼的橫條“Home Indicator”。當網頁底部fixed 元素時候,一部分元素可能就被這個橫條遮擋住,怎麼適配解決呢?

  第一步:

    <meta name=“viewport” content=“width=device-width, viewport-fit=cover”>

  第二步:

    頁面主體內容限定在安全區域內,如果不設置這個值,可能存在小黑條遮擋頁面最底部內容的情況

    body { padding-bottom: env(safe-area-inset-bottom); }

  第三步:

    fixed 元素的適配  

    第一種:padding-bottom: env(safe-area-inset-bottom);
        注意元素是否設置box-sizing:border-box;否則不起作用,道理就不說了。
    第二種:height: calc(60px(假設值) + env(safe-area-inset-bottom));
    第三種:margin-bottom: env(safe-area-inset-bottom);

    這三種方式都可解決,視情況而定選擇合適的,也可以靈活爲fixed 元素的子元素添加這些屬性

  

  使用 @supports
    一般只希望 iPhoneX 才需要新增適配樣式,可以配合 @supports 編寫樣式:
    @supports (bottom: env(safe-area-inset-bottom)) {
      div {
        margin-bottom: env(safe-area-inset-bottom);
      }
    }

  

  下面是一些拓展知識點:

    1.iphoneX業界劉海屏幕第一款機型,導致全屏不能正常的全屏顯示了,所以需要對iphonx 適配

      <meta name="viewport" content="viewport-fit=contain">
      <meta name="viewport" content="viewport-fit=cover">
      <meta name="viewport" content="viewport-fit=auto">

      viewport-fit:
        contain: 可視化窗口完全包含網頁內容
        cover: 網頁內容完全覆蓋
        auto: 默認值和 contain 一樣

 

    2.ios11 增加新特性,webkit 的 css 函數

      四個預定義變量爲設定安全區域和邊界的距離,如下:
        safe-area-inset-left:安全區域距離左邊邊界距離
        safe-area-inset-right:安全區域距離右邊邊界距離
        safe-area-inset-top:安全區域距離頂部邊界距離;在劉海全屏的時候 top 爲 44px
        safe-area-inset-bottom:安全區域距離底部邊界距離;劉海全屏的條件下是 34px

      

      css 函數 env() 和 constant()
        上面兩個函數可以直接使用變量函數,只有在 webkit 內核下才支持
        env() 必須在 ios >= 11.2 才支持
        constant() 必須 ios < 11.2 支持
        env 和 constant 只有在 viewport-fit=cover 時候才能生效
        兼容前後版本,例子:
          padding-top: constant(safe-area-inset-top);
          padding-top: env(safe-area-inset-top);

原文鏈接 : http://www.manongjc.com/article/76141.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章