>웹 프론트엔드 >JS 튜토리얼 >각도 학습 채팅 알림(맞춤 서비스)

각도 학습 채팅 알림(맞춤 서비스)

青灯夜游
青灯夜游앞으로
2022-12-01 20:45:522751검색

이 글은 여러분이 angular를 계속 학습하고 Angle의 맞춤 서비스 알림을 간략하게 이해하는 데 도움이 될 것입니다. 모두에게 도움이 되기를 바랍니다!

각도 학습 채팅 알림(맞춤 서비스)

이전 기사에서 다음을 언급했습니다.

서비스는 API 요청을 처리하는 데 사용될 수 있을 뿐만 아니라 다른 용도로도 사용할 수 있습니다.

예를 들어, 이 기사에서 설명할 알림 구현. [관련 튜토리얼 권장 사항: "notification 的实现。【相关教程推荐:《angular教程》】

效果图如下:

각도 학습 채팅 알림(맞춤 서비스)

UI 这个可以后期调整

So,我们一步步来分解。

添加服务

我们在 app/services 中添加 notification.service.ts 服务文件(请使用命令行生成),添加相关的内容:

// notification.service.ts

import { Injectable } from '@angular/core';
import { Observable, Subject } from 'rxjs';

// 通知状态的枚举
export enum NotificationStatus {
  Process = "progress",
  Success = "success",
  Failure = "failure",
  Ended = "ended"
}

@Injectable({
  providedIn: 'root'
})
export class NotificationService {

  private notify: Subject<NotificationStatus> = new Subject();
  public messageObj: any = {
    primary: &#39;&#39;,
    secondary: &#39;&#39;
  }

  // 转换成可观察体
  public getNotification(): Observable<NotificationStatus> {
    return this.notify.asObservable();
  }

  // 进行中通知
  public showProcessNotification() {
    this.notify.next(NotificationStatus.Process)
  }

  // 成功通知
  public showSuccessNotification() {
    this.notify.next(NotificationStatus.Success)
  }

  // 结束通知
  public showEndedNotification() {
    this.notify.next(NotificationStatus.Ended)
  }

  // 更改信息
  public changePrimarySecondary(primary?: string, secondary?: string) {
    this.messageObj.primary = primary;
    this.messageObj.secondary = secondary
  }

  constructor() { }
}

是不是很容易理解...

我们将 notify 变成可观察物体,之后发布各种状态的信息。

创建组件

我们在 app/components 这个存放公共组件的地方新建 notification 组件。所以你会得到下面的结构:

notification                                          
├── notification.component.html                     // 页面骨架
├── notification.component.scss                     // 页面独有样式
├── notification.component.spec.ts                  // 测试文件
└── notification.component.ts                       // javascript 文件

我们定义 notification 的骨架:

<!-- notification.component.html -->

<!-- 支持手动关闭通知 -->
<button (click)="closeNotification()">关闭</button>
<h1>提醒的内容: {{ message }}</h1>
<!-- 自定义重点通知信息 -->
<p>{{ primaryMessage }}</p>
<!-- 自定义次要通知信息 -->
<p>{{ secondaryMessage }}</p>

接着,我们简单修饰下骨架,添加下面的样式:

// notification.component.scss

:host {
  position: fixed;
  top: -100%;
  right: 20px;
  background-color: #999;
  border: 1px solid #333;
  border-radius: 10px;
  width: 400px;
  height: 180px;
  padding: 10px;
  // 注意这里的 active 的内容,在出现通知的时候才有
  &.active {
    top: 10px;
  }
  &.success {}
  &.progress {}
  &.failure {}
  &.ended {}
}

success, progress, failure, ended 这四个类名对应 notification service 定义的枚举,可以按照自己的喜好添加相关的样式。

最后,我们添加行为 javascript 代码。

// notification.component.ts

import { Component, OnInit, HostBinding, OnDestroy } from &#39;@angular/core&#39;;
// 新的知识点 rxjs
import { Subscription } from &#39;rxjs&#39;;
import {debounceTime} from &#39;rxjs/operators&#39;;
// 引入相关的服务
import { NotificationStatus, NotificationService } from &#39;src/app/services/notification.service&#39;;

@Component({
  selector: &#39;app-notification&#39;,
  templateUrl: &#39;./notification.component.html&#39;,
  styleUrls: [&#39;./notification.component.scss&#39;]
})
export class NotificationComponent implements OnInit, OnDestroy {
  
  // 防抖时间,只读
  private readonly NOTIFICATION_DEBOUNCE_TIME_MS = 200;
  
  protected notificationSubscription!: Subscription;
  private timer: any = null;
  public message: string = &#39;&#39;
  
  // notification service 枚举信息的映射
  private reflectObj: any = {
    progress: "进行中",
    success: "成功",
    failure: "失败",
    ended: "结束"
  }

  @HostBinding(&#39;class&#39;) notificationCssClass = &#39;&#39;;

  public primaryMessage!: string;
  public secondaryMessage!: string;

  constructor(
    private notificationService: NotificationService
  ) { }

  ngOnInit(): void {
    this.init()
  }

  public init() {
    // 添加相关的订阅信息
    this.notificationSubscription = this.notificationService.getNotification()
      .pipe(
        debounceTime(this.NOTIFICATION_DEBOUNCE_TIME_MS)
      )
      .subscribe((notificationStatus: NotificationStatus) => {
        if(notificationStatus) {
          this.resetTimeout();
          // 添加相关的样式
          this.notificationCssClass = `active ${ notificationStatus }`
          this.message = this.reflectObj[notificationStatus]
          // 获取自定义首要信息
          this.primaryMessage = this.notificationService.messageObj.primary;
          // 获取自定义次要信息
          this.secondaryMessage = this.notificationService.messageObj.secondary;
          if(notificationStatus === NotificationStatus.Process) {
            this.resetTimeout()
            this.timer = setTimeout(() => {
              this.resetView()
            }, 1000)
          } else {
            this.resetTimeout();
            this.timer = setTimeout(() => {
              this.notificationCssClass = &#39;&#39;
              this.resetView()
            }, 2000)
          }
        }
      })
  }

  private resetView(): void {
    this.message = &#39;&#39;
  }
  
  // 关闭定时器
  private resetTimeout(): void {
    if(this.timer) {
      clearTimeout(this.timer)
    }
  }

  // 关闭通知
  public closeNotification() {
    this.notificationCssClass = &#39;&#39;
    this.resetTimeout()
  }
  
  // 组件销毁
  ngOnDestroy(): void {
    this.resetTimeout();
    // 取消所有的订阅消息
    this.notificationSubscription.unsubscribe()
  }

}

在这里,我们引入了 rxjs 这个知识点,RxJS 是使用 Observables 的响应式编程的库,它使编写异步或基于回调的代码更容易。这是一个很棒的库,接下来的很多文章你会接触到它更多的内容。

这里我们使用了 debounce 防抖函数,函数防抖,就是指触发事件后,在 n 秒后只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数的执行时间。简单来说:当一个动作连续触发,只执行最后一次。

ps: throttle 节流函数:限制一个函数在一定时间内只能执行一次

在面试的时候,面试官很喜欢问...

调用

因为这个一个全局的服务,我们在 app.component.html 中调用此组件:

// app.component.html

<router-outlet></router-outlet>
<app-notification></app-notification>

为了方便演示,我们在 user-list.component.html 中添加按钮,方便触发演示:

// user-list.component.html

<button (click)="showNotification()">click show notification</button>

触发相关的代码:

// user-list.component.ts

import { NotificationService } from &#39;src/app/services/notification.service&#39;;

// ...
constructor(
  private notificationService: NotificationService
) { }

// 展示通知
showNotification(): void {
  this.notificationService.changePrimarySecondary(&#39;主要信息 1&#39;);
  this.notificationService.showProcessNotification();
  setTimeout(() => {
    this.notificationService.changePrimarySecondary(&#39;主要信息 2&#39;, &#39;次要信息 2&#39;);
    this.notificationService.showSuccessNotification();
  }, 1000)
}

至此,大功告成,我们成功模拟了 notificationangular tutorial

"]

렌더링은 다음과 같습니다.

각도 학습 채팅 알림(맞춤 서비스)

🎜UI 나중에 조정할 수 있습니다🎜🎜🎜그래서 단계별로 분석해 보겠습니다. 🎜

서비스 추가

🎜 app/servicesnotification.service.ts 서비스 파일(생성하려면 명령줄을 사용하세요), 관련 콘텐츠 추가: 🎜rrreee🎜이해하기 쉬운가요...🎜🎜<code>notify를 관찰 가능한 객체로 변환한 다음 게시하겠습니다. 각 상태 정보. 🎜

구성요소 생성

🎜공개 구성요소가 있는 app/comComponents에 새로운 알림을 생성합니다. 저장된 구성 요소. 따라서 다음과 같은 구조를 얻게 됩니다: 🎜rrreee🎜 알림의 뼈대를 정의합니다: 🎜rrreee🎜그런 다음 간단히 뼈대를 수정하고 다음 스타일을 추가합니다: 🎜rrreee🎜success, Progress , failure,ended 이 네 가지 클래스 이름은 알림 서비스에서 정의한 열거형에 해당합니다. 자신의 기본 설정에 따라 관련 스타일을 추가할 수 있습니다. 🎜🎜마지막으로 동작 javascript 코드를 추가합니다. 🎜rrreee🎜여기서 rxjs의 지식 포인트를 소개합니다. RxJSObservables를 사용하여 비동기 또는 콜백을 작성하는 반응형 프로그래밍 라이브러리입니다. 기반 코드가 더 쉽습니다. 이것은 훌륭한 라이브러리이며 다음 기사에서 이에 대해 자세히 알아볼 것입니다. 🎜🎜여기서는 debounce 흔들림 방지 기능을 사용합니다. 흔들림 방지 기능은 이벤트가 트리거된 후 이벤트가 다시 트리거되면 한 번만 실행할 수 있음을 의미합니다. n초 이내에 함수의 실행 시간이 다시 계산됩니다. 간단히 말하면, 작업이 연속적으로 트리거되면 마지막 시간만 실행됩니다. 🎜🎜🎜ps: throttle Throttle 기능: 특정 기간 내에 한 번만 실행되도록 기능을 제한합니다. 🎜🎜🎜면접 때 면접관이 자주 하는 질문은...🎜

전화

🎜글로벌 서비스이기 때문에 우리는 전화를 겁니다. app.comComponent.html의 이 구성 요소: 🎜rrreee🎜 데모를 용이하게 하기 위해 user-list.comComponent.html에 버튼을 추가하여 데모를 쉽게 실행할 수 있습니다. 🎜 rrreee 🎜트리거 관련 코드:🎜rrreee🎜이제 우리는 알림 기능을 성공적으로 시뮬레이션했습니다. 실제 요구 사항에 따라 관련 서비스 구성 요소를 수정하고 비즈니스 요구 사항에 맞게 사용자 정의할 수 있습니다. 내부용 시스템을 개발하는 경우 성숙한 UI 라이브러리를 사용하는 것이 좋습니다. 이를 통해 다양한 구성 요소와 서비스를 캡슐화하여 개발 시간을 많이 절약할 수 있습니다. 🎜🎜【끝】✅🎜🎜프로그래밍 관련 지식을 더 보려면 🎜프로그래밍 교육🎜을 방문하세요! ! 🎜

위 내용은 각도 학습 채팅 알림(맞춤 서비스)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제