zoukankan      html  css  js  c++  java
  • MVC in Javascript

    MVC in Javascript

    From
    http://www.cnblogs.com/tugenhua0707/p/5156179.html

    原博的比我详细 我是以自己的惯用的方式实现了一下

    MVC就是各尽自己的职责,整个视图都是按照数据来渲染的, 视图本身并不保存数据。 发生的事件由Controller控制, Controller也是修改Model中的数据, 之后调用View中的refreshDOM刷新DOM

    
      var doc = document;
      var PubSub = function(){
        this.event = [];
      }
      PubSub.prototype = {
        registerEvent: function(fn){
          this.event.push(fn);
        },
        triggerEvent: function(){
          this.event.forEach(function(fn){
            fn.call(this);
          }.bind(this));
        }
      }
    
        var Model = function(list){
          this.list = list;
          this.addEvent = new PubSub();
          this.delEvent = new PubSub();
        }
        Model.prototype = {
          addItem: function(item){
            if(item){
              this.list.push(item);
            }else{
              var lastData = self.model.list[self.model.list.length-1];
              var num = +lastData.match(/item(d)/)[1];
              this.list.push('item'+(num+1));
            }
          },
          removeItem: function(index){
            this.list.splice(index,1);
          }
        }
        var View = function(model,container){
          var self = this;
          this.model = model;
          this.container = container;
          this.model.addEvent.registerEvent(function(){
            self.model.addItem();
            self.refreshDOM();
          });
          this.model.delEvent.registerEvent(function(){
            if(self.container.selectedIndex != -1){
              self.model.removeItem(self.container.selectedIndex);
              self.refreshDOM();
            }
          });
          this.refreshDOM = function(){
            var listData = this.model.list;
            var selectElem = doc.querySelector('#list');
            selectElem.innerHTML = '';
            listData.forEach(function(item){
              var option = doc.createElement('option');
              option.value = item;
              option.innerHTML = item;
              self.container.appendChild(option);
            });
          }
        }
        var Controller = function(elements, model){
          var self = this;
          this.addButton = elements.addButton;
          this.delButton = elements.delButton;
          this.model = model;
          this.addButton.addEventListener('click', function(){
            self.model.addEvent.triggerEvent();
          });
          this.delButton.addEventListener('click', function(){
            self.model.delEvent.triggerEvent();
          })
        }
        var model = new Model(['item1','item2']);
        var view = new View(model, doc.querySelector('#list'));
        view.refreshDOM();
        var controller = new Controller({
          addButton: doc.querySelector('#addBtn'),
          delButton: doc.querySelector('#delBtn')
        },model)
    
  • 相关阅读:
    Ubuntu忘记密码后强制修改密码
    搭建Jetbrains家族IDE授权服务器
    C#ComboBox绑定List
    字体包文件过大
    JS通过ActiveX读写ini配置文件
    NodeJS + express访问html、css、JS等静态资源文件
    VueJS搭建简单后台管理系统框架 (二) 模拟Ajax数据请求
    VueJS搭建简单后台管理系统框架(一)环境搭建
    ExtJS4.x Grid 单元格鼠标悬停提示
    IE9下Ajax缓存问题
  • 原文地址:https://www.cnblogs.com/cart55free99/p/5180775.html
Copyright © 2011-2022 走看看