裝飾者模式

裝飾者模式

裝飾者模式可以在不改對象自身的基礎(chǔ)上,在程序運(yùn)行期間給對象動(dòng)態(tài)添加職責(zé)
,裝飾者是一種即用即付的方式
舉個(gè)例子:就像我們經(jīng)常需要給手機(jī)戴個(gè)保護(hù)套防摔一樣,不改變手機(jī)自身,給手機(jī)添加了保護(hù)套提供防摔功能。

在 react 中裝飾者模式使用較多

import { connect } from "react-redux";
class MyComponent extends React.Component {
  // ...
}
export default connect(mapStateToProps)(MyComponent);

es7 裝飾器就是使用的裝飾者模式

function readonly(target, key, descriptor) {
  descriptor.writable = false;
  return descriptor;
}

class Test {
  @readonly
  name = "qqq";
}

let t = new Test();

t.qqq = "222"; // 不可修改

具體裝飾器的使用方法參考阮一峰文檔:https://es6.ruanyifeng.com/#docs/decorator
簡單總結(jié)一下:裝飾器模式就是在原本對象(函數(shù)或者 es6 類)功能不變的情況下,添加新的功能,

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容