I am building a ionic 2 app and I am using the following component
http://ionicframework.com/docs/components/#alert
  import { AlertController } from 'ionic-angular';
export class MyPage {
  constructor(public alertCtrl: AlertController) {
  }
  showAlert() {
    let alert = this.alertCtrl.create({
      title: 'New Friend!',
      subTitle: 'Your friend, Obi wan Kenobi, just accepted your friend request!',
      buttons: ['OK']
    });
    alert.present();
  }
}
How can I make sure that when I click outside the box the alert is not dismissed?
As you can see in the AlertController docs, you can use the enableBackdropDismiss (boolean) option when creating the alert:
enableBackdropDismiss: Whether the alert should be dismissed by tapping the backdrop. Default true
import { AlertController } from 'ionic-angular';
// ...
export class MyPage {
  constructor(public alertCtrl: AlertController) {}
  showAlert() {
    let alert = this.alertCtrl.create({
      title: 'New Friend!',
      subTitle: 'Your friend, Obi wan Kenobi, just accepted your friend request!',
      buttons: ['OK'],
      enableBackdropDismiss: false // <- Here! :)
    });
    alert.present();
  }
}
In Ionic 4/5 this property has been renamed to backdropDismiss:
backdropDismiss: If true, the alert will be dismissed when the backdrop is clicked.
import { AlertController } from '@ionic/angular';
//...
export class MyPage {
  constructor(public alertController: AlertController) {}
  async showAlert() {
    const alert = await this.alertController.create({
      header: 'Alert',
      subHeader: 'Subtitle',
      message: 'This is an alert message.',
      buttons: ['OK'],
      backdropDismiss: false // <- Here! :)
    });
    await alert.present();
  }
}
In ionic 4 the option has been renamed to
backdropDismiss: false
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With