JavaScript设计模式(二)【工厂模式】

//  安全的工厂方法

var Factory = function (type, content) {
  if (this instanceof Factory) {
    var s = new this[type](content);
    return s;
  } else {
    return new Factory(type, content);
  }
}

// 工厂原型中设置创建所有类型数据对象的基类

Factory.prototype = {
  Java: function (content) {

  },
  UI: function (content) {

  },
  PHP: function (content) {

  },
  JavaScript: function (content) {
    this.content = content;
    (function (content) {
      var div = document.createElement('div');
      div.innerHTML = content;
      div.style.border = '1px solid red';
      document.getElementById('container').appendChild(div);
    })(content);
  },
}

// 使用实例

var data = [
  {type: 'JavaScript',content: 'JavaScript哪家强'},
  {type: 'Java',content: 'Java哪家强'},
  {type: 'UI',content: 'UI哪家强'},
  {type: 'PHP',content: 'PHP哪家强'}
];
console.log(data);
for (var i = 3; i >= 0; i--) {
  Factory(data[i].type, data[i].content);
}

完整html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8"/>
    <title></title>
</head>
<body>
<div id="container"></div>
<script type="text/javascript">
    //  安全的工厂方法
    var Factory = function(type, content) {
        if (this instanceof Factory) {
            var s = new this[type](content);
            return s;
        } else {
            return new Factory(type, content);
        }
    }

    // 工厂原型中设置创建所有类型数据对象的基类
    Factory.prototype = {
        Java: function(content) {

        },
        UI: function(content) {

        },
        PHP: function(content) {

        },
        JavaScript: function(content) {
            this.content = content;
            (function(content) {
                var div = document.createElement('div');
                div.innerHTML = content;
                div.style.border = '1px solid red';
                document.getElementById('container').appendChild(div);
            })(content);
        },
    }

    // 使用实例
    var data = [
        { type: 'JavaScript', content: 'JavaScript哪家强' },
        { type: 'Java', content: 'Java哪家强' },
        { type: 'UI', content: 'UI哪家强' },
        { type: 'PHP', content: 'PHP哪家强' }
    ];
    console.log(data);
    for (var i = 3; i >= 0; i--) {
        Factory(data[i].type, data[i].content);
    }
</script>
</body>
</html>

如图:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值