# 其他

# css safe-area-inset-bottom 解释

  • env(safe-area-inset-bottom)
  • env(safe-area-inset-top)

他们属于CSS中的变量,用于获取设备底部和顶部安全区域的大小

所谓的安全区域就是指在iPhone X及以上的设备中,为避免被屏幕的“刘海”和“Home Indicator”所遮挡或者覆盖的有效区域区域,以确保内容在安全区域内显示。

# 和padding的结合

padding-bottom: env(safe-area-inset-bottom);

# 如果想让安全区域再靠上20px,则结合calc使用如下

padding-bottom: calc(20px + env(safe-area-inset-bottom));

# 和height的结合

height: calc(100vh - 144px - env(safe-area-inset-top) - env(safe-area-inset-bottom)) ;

# 注意

以上写法貌似在兼容iphoneX的工程上宣告结束了...然而...在某些机型上识别不出env(safe-area-inset-bottom)和env(safe-area-inset-top),导致高度等失效,需要再做一次兼容,兼容某些不识别这些变量的机型。拿和height结合举例说明,可做如下兼容

/*
    兼容普通机型,不识别变量的机型:
*/
height: calc(100vh - 144px);
/*
    兼容苹果手机
*/
height: calc(100vh - 144px - env(safe-area-inset-top) - env(safe-area-inset-bottom));

/*
    constant 已被废弃
*/
constant(safe-area-inset-bottom); /*兼容 IOS<11.2*/

如果识别这两个变量,则执行第二句,覆盖第一句;如果不识别这两个变量呢,则不识别第二句,执行第一句。这就是一个完美的兼容写法!