JavaScript設(shè)計模式組合設(shè)計模式案例_第1頁
JavaScript設(shè)計模式組合設(shè)計模式案例_第2頁
JavaScript設(shè)計模式組合設(shè)計模式案例_第3頁
JavaScript設(shè)計模式組合設(shè)計模式案例_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

第JavaScript設(shè)計模式組合設(shè)計模式案例目錄前言組合設(shè)計模式的業(yè)務(wù)場景組合設(shè)計模式小案例

前言

組合設(shè)計模式是用于將多個部分通過組合的方式行成一個整體,就比如我們?nèi)コ燥?,點了一份米飯和一份魚香肉絲,這些東西可以看成一個部分,通過組合的方式可以組成一個新的產(chǎn)品,魚香肉絲蓋飯,這就是組合設(shè)計模式

組合設(shè)計模式的業(yè)務(wù)場景

表單用于收集用戶數(shù)據(jù),比如登錄,注冊,或者一些信息填報,由于這些表單都是類似的,如果我們一個一個去做,里面充滿了很多重復(fù)的東西,增加了工作量,我們可以使用組合設(shè)計模式

組合設(shè)計模式小案例

一個餐館的運轉(zhuǎn)需要一些雇傭一些人手,但是這些雇傭的人手都有一個共同點,我們需要對其支付一定的薪酬作為勞動的回報,其次他們還需擔(dān)負(fù)某些任務(wù)職責(zé),可能需要向某人匯報餐館情況,也有可能會擁有下屬等等,我們來實現(xiàn)一下

聲明一個員工類,我們對于新招聘員工需要提供三個參數(shù),員工姓名,員工薪資和員工所任職崗位,還可進(jìn)行獲取員工姓名,對員工的薪資進(jìn)行獲取和修改以及獲取員工當(dāng)前任職職位和對員工進(jìn)行調(diào)崗的操作

classStaff{

//員工名員工薪資員工崗位

constructor(name,salary,position){

=name;

this.salary=salary;

this.position=position;

//獲取員工名字

getName(){

return;

//修改員工薪資

setSalary(salary){

this.salary=salary;

//獲取員工薪資

getSalary(){

returnthis.salary;

//設(shè)置員工崗位

setPosition(position){

this.position=position;

//獲取員工崗位

getPosition(){

returnthis.position;

在聲明一個店鋪類,店鋪類是對新招聘員工進(jìn)行添加到該店鋪人員中,以及對于該店鋪員工的職位信息進(jìn)行查看和對當(dāng)前用工成本進(jìn)行統(tǒng)計

classStoreMembers{

constructor(){

//店鋪人員總職員

this.employees=[];

//往店鋪總職員添加員工

addEmployee(employee){

this.employees.push(employee);

//獲取店鋪職員總開銷

getNetSalaries(){

letnetSalary=0;

netSalary=this.employees.reduce((total,currt)=total.getSalary()+currt.getSalary())

returnnetSalary;

//獲取店鋪職員信息名單

getPositionList(){

return(this.employees.map(res=({name:res.getName(),position:res.getPosition(),salary:res.getSalary()})))

我們對新招聘員工進(jìn)行添加到店鋪總職員中并且獲取到該店鋪對于職員的總開銷以及獲取店鋪總職員信息名單

//創(chuàng)建倆個員工類實例

constxh=newStaff("小紅",12000,'服務(wù)員');

constxm=newStaff("小明",10000,'收銀員');

//創(chuàng)建店鋪類

conststoreMembers=newStoreMembers();

//往店鋪中添加新的職員

storeMembers.addEmployee(xh);

storeMembers.addEmployee(xm);

//獲取店鋪職員的總薪資

console.log("職員薪資總額:",storeMembers.getNetSalaries());

//獲取店鋪職員總職位信息

console.log("職員總職位信息:",storeMembers.getPosit

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論