JS设计模式

Module模式

    var timer = (function(){
        let count = 0 // 私有变量
        return {
            add() {
                count++
            },
            getCount() {
                return count
            }
        }
    })()
    timer.add()
    console.log(timer.getCount())
优点:因为闭包原理,实现了私有变量

字面量模式

let baseEvent = {
    el: document.querySelector('#btn'),
    init() {
        this.el.innerHTML = '按钮'
    }
}
baseEvent.init()
优点: 一个字:看起来高级

constructor模式

function Car(name) {
    this.name = name
    this.alert = function() {
        console.log(this.name)
    }
}
let car = new Car('audi')
car.alert()

跟“工厂模式”一样,缺点是alert每次都得初始化,而且没法继承
优化:

function Car(name) {
    this.name = name
}
Car.prototype.alert = function() {
   console.log(this.name) 
}
let car = new Car('audi')
car.alert() // audi
// 覆盖
car.alert = function() {
    console.log(this.name + '!!!')
}
car.alert() // audi!!!

你可能感兴趣的:(javascript)