美文网首页前端杂记让前端飞
组合模式实现文件夹操作

组合模式实现文件夹操作

作者: 会飞小超人 | 来源:发表于2018-12-24 10:38 被阅读2次

    组合模式如果运用得当,可以大大简化客户的代码。一般来说,组合模式适用于以下这两种情况。

    • 表示对象的部分-整体层次结构。组合模式可以方便的构造一棵树来表示对象的部分-整体结果。特别是我们在开发期间不确定这棵树到底存在多少层次的时候。在树的构造最终完成之后,只需要通过请求树的最顶层对象,便能对整棵树做同一的操作。在组合模式中增加和删除树的节点非常方便,并且符合开放-封闭原则。
    • 客户希望统一对待树中的所有对象。组合模式使客户可以忽略组合对象和叶对象的区别,客户在面对这棵树的时候,不用关心当前正在处理的是组合对象还是叶对象,也就不用写一堆ifelse语句来分别处理它们。组合对象和叶对象会各自做自己正确的事情,这是组合模式最重要的能力。
      下面用组合模式实现文件夹的操作,包括文件夹的添加文件,删除文件,扫描文件操作。
    const Folder = function (name) {
      this.name = name
      this.parent = null
      this.files = []
    }
    
    Folder.prototype.add = function (file) {
      file.parent = this
      this.files.push(file)
    }
    
    Folder.prototype.scan = function () {
      console.log('开始扫描文件夹: ' + this.name)
      for (let i = 0, file, files = this.files; file = files[i++];) {
        file.scan()
      }
    }
    
    Folder.prototype.remove = function () {
      if (!this.parent) {
        return
      }
      for (let files = this.parent.files, len = files.length - 1; len >= 0; len--) {
        let file = files[len]
        if (file === this) {
          files.splice(len, 1)
        }
      }
    }
    
    const File = function (name) {
      this.name = name
      this.parent = null
    }
    
    File.prototype.add = function () {
      throw new Error('文件下面不能再添加文件')
    }
    
    File.prototype.remove = function () {
      if (!this.parent) {
        return
      }
      for (let files = this.parent.files, len = files.length - 1; len >= 0; len--) {
        let file = files[len]
        if (file === this) {
          files.splice(len, 1)
        }
      }
    }
    
    File.prototype.scan = function () {
      console.log('开始扫描文件: ' + this.name)
    }
    
    let folder = new Folder('学习资料')
    let folder1 = new Folder('JavaScript')
    let folder2 = new Folder('jQuery')
    
    let file1 = new File('JavaScript设计模式与开始实践')
    let file2 = new File('精通jQuery')
    let file3 = new File('重构与模式')
    
    folder1.add(file1)
    folder2.add(file2)
    
    folder.add(folder1)
    folder.add(folder2)
    folder.add(file3)
    
    folder.scan()
    
    folder1.remove()
    
    folder.scan()
    

    但是,组合模式并不是完美的,他可能会产生一个这样的系统:系统中每个对象看起来都与其他对象差不多。它们的区别只有在运行的时候才会显现出来,这会使代码难以理解。此外,如果通过组合模式创建了太多的对象,那么这些对象可能会让系统担负不起。

    相关文章

      网友评论

        本文标题:组合模式实现文件夹操作

        本文链接:https://www.haomeiwen.com/subject/eblmkqtx.html