>웹 프론트엔드 >JS 튜토리얼 >JS 책임 체인 모델에 대한 자세한 설명

JS 책임 체인 모델에 대한 자세한 설명

小云云
小云云원래의
2018-02-28 14:22:421696검색

책임 체인 패턴은 요청을 처리하려면 여러 개체가 필요하므로 요청 발신자와 수신자 간의 결합 관계를 피하는 것을 의미합니다. 이러한 객체는 체인으로 연결되며 요청은 객체가 처리할 때까지 체인을 따라 전달됩니다.

실생활의 예를 보면 특정 요청에 대해 여러 사람의 승인이 필요할 수 있습니다. 기술 관리자가 승인했더라도 여전히 다음 단계의 승인이 필요할 수 있습니다. 예를 들어, 회사에서의 휴가가 3일 미만인 경우 직속 리더가 승인할 수 있으며, 3일에서 7일 사이인 경우 프로젝트 관리자의 승인이 필요합니다. 기술 이사의 승인. 삶의 책임 사슬 패턴에 대한 많은 예를 소개한 결과, 객체 지향 책임 사슬 패턴의 정의는 다음과 같습니다.

책임 체인 모델에 포함된 개체에는 핸들러 역할만 있지만 핸들러가 여러 개 있으므로 요청을 처리하는 공통 방법이 있으므로 여기서는 코드 재사용을 위해 추상 핸들러 역할을 추상화합니다.

JS 책임 체인 모델에 대한 자세한 설명

구현

  • 요청 클래스

    // 采购请求
    let PurchaseRequest = function (amount, productName) {
        this.amount = amount;
        this.productName = productName;
    };
  • 프로세서 인터페이스 클래스

    // 审批人,Handler
    let Approver = function (name, nextApprover) {
        this.name = name;
        this.nextApprover = nextApprover;
    };
    Approver.prototype.processRequest = function () {
        throw new Error();  
    };
  • 프로세서 클래스

    // ConcreteHandler
    let Manager = function (name, nextApprover) {
        Approver.call(this, name, nextApprover);
    };
    extend(Manager, Approver);
    Manager.prototype.processRequest = function (request) {
        if (request.Amount < 10000.0)
        {
            console.log('ok');
        }
        else if (NextApprover != null)
        {
            this.nextApprover.ProcessRequest(request);
        }   
    };    
        
    // ConcreteHandler,副总
    let VicePresident = function (name, nextApprover) {
        Approver.call(this, name, nextApprover);
    };
    extend(VicePresident, Approver);
    VicePresident.prototype.processRequest = function (request) {
        if (request.Amount < 25000.0)
        {
            console.log('ok');
        }
        else if (NextApprover != null)
        {
            this.nextApprover.ProcessRequest(request);
        }   
    };
    
    
    // ConcreteHandler,总经理
    let President = function (name, nextApprover) {
        Approver.call(this, name, nextApprover);
    };
    extend(President, Approver);
    President.prototype.processRequest = function (request) {
        if (request.Amount < 100000.0)
        {
            console.log('ok');
        }
        else if (NextApprover != null)
        {
            this.nextApprover.ProcessRequest(request);
        }   
    };

Test

let requestTelphone = new PurchaseRequest(4000.0, "Telphone");
let requestSoftware = new PurchaseRequest(10000.0, "Visual Studio");
let requestComputers = new PurchaseRequest(40000.0, "Computers");

let manager = new Manager("LearningHard");
let Vp = new VicePresident("Tony");
let Pre = new President("BossTom");

// 设置责任链
manager.NextApprover = Vp;
Vp.NextApprover = Pre;

// 处理请求
manager.ProcessRequest(requestTelphone);
manager.ProcessRequest(requestSoftware);
manager.ProcessRequest(requestComputers);

사용 시나리오

  • 시스템 승인에는 여러 개체가 필요합니다. 휴가제도 등 처리가 완료됩니다.

  • 코드에 if-else 문이 여러 개 있는 경우 책임 사슬 패턴을 사용하여 코드를 리팩터링하는 것을 고려할 수 있습니다.

기능

  • 요청 발신자와 수신자 간의 결합을 줄입니다.

  • 여러 조건부 판단을 다양한 처리 클래스로 분산하여 코드를 더 명확하게 하고 책임을 더 명확하게 만듭니다.

 책임 사슬 모델에도 다음과 같은 특정 단점이 있습니다.

  • 올바른 처리 개체를 찾기 전에 모든 조건부 판단을 한 번 실행해야 합니다. 책임 사슬이 너무 길면 성능이 저하될 수 있습니다. 문제가 발생하면 요청이 처리되지 않을 수 있습니다.

요약

  • 책임 체인은 요청자와 수신자 간의 연결을 줄여 여러 개체에 특정 요청을 처리할 수 있는 기회를 제공합니다. 책임 분할을 보다 구체적으로 만들어

관련 권장 사항:

JavaScript 책임 체인 패턴 소개

Java 디자인 패턴의 책임 체인 패턴 분석 예

공통 디자인의 책임 패턴 체인 패턴과 PHP 구현

위 내용은 JS 책임 체인 모델에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.