当前位置:   article > 正文

前端面试常问:设计模式(1)_前端面试题 设计模式

前端面试题 设计模式

前端设计模式是一种解决常见前端问题的模板,通常用于提高代码的可读性、可维护性和可扩展性。本文将介绍一些常见的前端设计模式。

1.单例模式

单例模式是一种保证类只被实例化一次的模式。在前端开发中,单例模式通常用于管理全局状态或资源,如 Redux 中的 store。以下是一个使用 JavaScript 实现的单例模式示例:

  1. var Singleton = (function() {
  2. var instance;
  3. function createInstance() {
  4. var object = new Object("I am the instance");
  5. return object;
  6. }
  7. return {
  8. getInstance: function() {
  9. if (!instance) {
  10. instance = createInstance();
  11. }
  12. return instance;
  13. }
  14. };
  15. })();
  16. var instance1 = Singleton.getInstance();
  17. var instance2 = Singleton.getInstance();
  18. console.log(instance1 === instance2); // true

2.观察者模式

观察者模式是一种在对象之间定义一对多依赖关系的模式。当一个对象状态发生改变时,它的所有依赖对象都会收到通知并自动更新。在前端开发中,观察者模式通常用于实现数据绑定,如 Vue.js 中的双向数据绑定。以下是一个使用 JavaScript 实现的观察者模式示例:

  1. function Subject() {
  2. this.observers = [];
  3. }
  4. Subject.prototype.addObserver = function(observer) {
  5. this.observers.push(observer);
  6. };
  7. Subject.prototype.removeObserver = function(observer) {
  8. var index = this.observers.indexOf(observer);
  9. if (index > -1) {
  10. this.observers.splice(index, 1);
  11. }
  12. };
  13. Subject.prototype.notifyObservers = function() {
  14. for (var i = 0; i < this.observers.length; i++) {
  15. this.observers[i].update();
  16. }
  17. };
  18. function Observer() {
  19. this.update = function() {
  20. console.log("Observer updated");
  21. };
  22. }
  23. var subject = new Subject();
  24. var observer1 = new Observer();
  25. var observer2 = new Observer();
  26. subject.addObserver(observer1);
  27. subject.addObserver(observer2);
  28. subject.notifyObservers(); // "Observer updated" x2

3.工厂模式

工厂模式是一种通过创建工厂来创建对象的模式。在前端开发中,工厂模式通常用于创建复杂对象,如组件。以下是一个使用 JavaScript 实现的工厂模式示例:

  1. function Button(text) {
  2. this.text = text;
  3. }
  4. function Input(placeholder) {
  5. this.placeholder = placeholder;
  6. }
  7. function createUI(type, props) {
  8. switch (type) {
  9. case "button":
  10. return new Button(props.text);
  11. case "input":
  12. return new Input(props.placeholder);
  13. }
  14. }
  15. var button = createUI("button", { text: "Click me!" });
  16. var input = createUI("input", { placeholder: "Enter your name" });
  17. console.log(button instanceof Button); // true
  18. console.log(input instanceof Input); // true

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/157596
推荐阅读
相关标签
  

闽ICP备14008679号