angular刷新或离开页面时提示用户保存数据

最近收到产品提的这样一个需求,用户在页面操作完成后若用户不小心刷线了页面或者点了后退,这时阻止用户的操作并提示用户数据还未保存。
话不多说上代码

可以这样写

ngOnInit(): void {
    window.onbeforeunload = (event) => {
      (event || window.event).returnValue = '还未保存是否离开';
      // 这里写关闭时需要处理的时间,刷新也会执行这里的方法

也可以这样写

import { HostListener } from '@angular/core';
@HostListener('window:beforeunload')
  doSomething(event) {
    (event || window.event).returnValue = '还未保存是否离开';

谷歌搜了好多回答都是让用onbeforeunload 这个方法,但是我发现复制上去没用,但从某个群里得知有个大神也做过类似功能,一问才知道要给方法参数的returnValue赋值。但是赋值之后是这样的
刷新时在这里插入图片描述
离开时在这里插入图片描述

可以发现你赋给returnValue的值根本没卵用,但是returnValue必须需要赋值之后这个弹窗才会出现。
有兴趣的朋友可以深入研究研究。

angular刷新或离开页面时提示用户保存数据最近收到产品提的这样一个需求,用户在页面操作完成后若用户不小心刷线了页面或者点了后退,这时阻止用户的操作并提示用户数据还未保存。话不多说上代码可以这样写ngOnInit(): void { window.onbeforeunload = (event) => { (event || window.event).returnValue = '还未保存是否离开'; // 这里写关闭时需要处理的时间,刷新也会执行这里的方法
假定当前页面为editCata页面,要返回的是cataDetail页面。目前我找到两种方法实现返回上一页并刷新,如果以后有其它方法,再继续添加。 1、在editCataCtrl.js中注入$ionicHistory服务. 使用$ionicHistory.goBack()方法即可返回到上一页面。 JS端代码: $scope.goBack=function(){ $ionicHistory.goBack(); HTML代码: <button class="button button-clear" ng-click="goBack()">返回上一页</button> 如果需要返回上
项目中遇到一个问题,网上说的不清不楚的。 一个列表页面跳转到另一个详细页面传递一个id,要求刷新当前页面用刚才跳转过来的id再访问一遍数据接口,这需要把数据保存到localstorage中 1、新建一个service: localStorage.service.js 1 (function() { 2 'use strict'; 4 an...
import { Component } from '@angular/core'; import { TranslateService } from "@ngx-translate/core"; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.co...
如果你想在 Angular 页面刷新执行某些操作,可以使用 `ngOnInit` 钩子函数。这个函数在 Angular 组件或指令的输入属性初始化后调用,通常是在 Angular 初始化组件的候,也就是页面刷新候。你可以在 `ngOnInit` 函数中编写你想要在页面刷新执行的代码。 ```typescript import { Component, OnInit } from '@angular/core'; @Component({ selector: 'app-my-component', templateUrl: './my-component.component.html', styleUrls: ['./my-component.component.css'] export class MyComponentComponent implements OnInit { constructor() { } ngOnInit() { // 这里是页面刷新执行的代码 你也可以使用其他的钩子函数,如 `ngAfterViewInit`,它在组件的视图及其子视图初始化完成之后调用。但是,如果你只是想在页面刷新执行一些代码,那么 `ngOnInit` 就足够了。