设置沉浸式状态栏体验比较好,而且有些页面设计需要频繁的改变状态栏的颜色,如果不使用沉浸式,就需要页面离开和进入单独设置状态栏背景色,这就导致会有一个非常明显的过度问题,但是使用沉浸式就可以避免这个问题,因为沉浸式状态下状态栏是透明的,只需要设置ion-header的背景色就可以了。
ponent.ts中设置:
this.statusBar.styleLightContent(); // 深色文本this.statusBar.overlaysWebView(true);
到这一步,IOS就可以了,不用再设置其他的东西,但是Android还需要,如不设置,在Android中,页面头部就会和状态栏重叠,还需要设置padding-top将内容顶下来,我是使用指令来实现的:
import {Directive, ElementRef, Input, OnInit } from '@angular/core';import {Platform } from '@ionic/angular';@Directive({selector: '[appOverlayPadding]',exportAs: 'appOverlayPadding'})export class StatuabrOverlayPaddingDirective implements OnInit {@Input('appOverlayPadding') options: {top?: string;};constructor(private ele: ElementRef,private platform: Platform,) {}ngOnInit() {this.setPaddingTop();}// 适配 沉浸式状态下 statusbar将header遮住的情况,setPaddingTop() {if (this.platform.is('android')) {this.ele.nativeElement.style.paddingTop = this.options && this.options.top ? this.options.top : '25px';}}}
引用:
<ion-header><ion-toolbar color="primary" appOverlayPadding><ion-buttons slot="start"><ion-back-button></ion-back-button></ion-buttons><ion-title>商品描述</ion-title></ion-toolbar></ion-header>
然后,有的Android机中,页面一打开,不会立即切换成沉浸式,需要手动触发,比如input获取焦点,所以需要在statusbar插件源码中加点东西:
platforms/android/app/src/main/java/org/apache/cordova/statusbar/Statusbar.java中59行加入:
window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);window.setStatusBarColor(Color.TRANSPARENT);window.setNavigationBarColor(Color.WHITE); // 设置底部虚拟导航栏的背景色