Rumah >hujung hadapan web >tutorial js >Memahami corak MVC dalam petua javascript_javascript

Memahami corak MVC dalam petua javascript_javascript

WBOY
WBOYasal
2016-05-16 15:17:031301semak imbas

Corak MVC ialah corak seni bina perisian dalam kejuruteraan perisian Corak perisian secara amnya dibahagikan kepada tiga bahagian, Model, View dan Controller;

Model: Model digunakan untuk merangkum data yang berkaitan dengan logik perniagaan aplikasi dan kaedah untuk pemprosesan data. Model mempunyai akses terus kepada data. Model ini tidak bergantung pada "paparan" dan "pengawal", yang bermaksud bahawa model tidak mengambil berat tentang cara halaman dipaparkan dan cara ia dikendalikan.

Paparan: Perkara paling penting dalam lapisan paparan ialah memantau perubahan data pada lapisan model dan mengemas kini halaman html dalam masa nyata. Sudah tentu, ia juga termasuk beberapa pendaftaran acara atau operasi permintaan ajax (penerbitan acara), yang semuanya dilakukan dalam lapisan paparan.

Pengawal: Pengawal menerima operasi pengguna, perkara yang paling penting ialah melanggan peristiwa lapisan paparan, dan kemudian memanggil model atau pandangan untuk menyelesaikan operasi pengguna sebagai contoh: apabila peristiwa dicetuskan pada halaman, pengawal tidak mengeluarkan apa-apa dan bertindak balas Halaman tidak melakukan pemprosesan, ia hanya menerima permintaan dan memutuskan kaedah mana dalam model untuk dipanggil untuk mengendalikan permintaan, dan kemudian menentukan kaedah dalam paparan untuk dipanggil untuk memaparkan data yang dikembalikan; .

Mari kita laksanakan kawalan kotak lungsur mudah, yang boleh kita tambah dan padamkan seperti yang ditunjukkan dalam rajah di bawah:

Kod adalah seperti berikut:

/*
 模型用于封装与应用程序的业务逻辑相关的数据以及对数据处理的方法。模型有对数据直接访问的权利。
 模型不依赖 "视图" 和 "控制器", 也就是说 模型它不关心页面如何显示及如何被操作.
*/
function Mode(elems) {
  // 所有元素
  this._elems = elems;
 
  // 被选中元素的索引
  this._selectedIndex = -1;
 
  // 增加一项
  this.itemAdd = new Event(this);
 
  // 删除一项
  this.itemRemoved = new Event(this);
 
  this.selectedIndexChanged = new Event(this);
}
 
Mode.prototype = {
 
  constructor: 'Mode',
 
  // 获取所有的项
  getItems: function(){
    return [].concat(this._elems);
  },
  // 增加一项
  addItem: function(elem) {
    this._elems.push(elem);
    this.itemAdd.notify({elem:elem});
  },
  // 删除一项
  removeItem: function(index) {
    var item = this._elems[index];
    this._elems.splice(index,1);
    this.itemRemoved.notify({elem:item});
 
    if(index === this._selectedIndex) {
      this.setSelectedIndex(-1);
    }
  },
  getSelectedIndex: function(){
    return this._selectedIndex;
  },
  setSelectedIndex: function(index){
    var previousIndex = this._selectedIndex;
    this._selectedIndex = index;
    this.selectedIndexChanged.notify({previous : previousIndex});
  }
};
/*
 下面是观察者模式类,它又叫发布---订阅模式;它定义了对象间的一种一对多的关系,
 让多个观察者对象同时监听某一个主题对象,当一个对象发生改变时,所有依赖于它的对象都将得到通知。
*/
function Event(observer) {
  this._observer = observer;
  this._listeners = [];
}
Event.prototype = {
  constaructor: 'Event',
  attach : function(listeners) {
    this._listeners.push(listeners);
  },
  notify: function(objs){
    for(var i = 0,ilen = this._listeners.length; i ) {
      this._listeners[i](this._observer,objs);
    }
  }
};
 
/*
 * 视图显示模型数据,并触发UI事件。
 */
function View(model,elements){
  this._model = model;
  this._elements = elements;
 
  this.listModified = new Event(this);
  this.addButtonClicked = new Event(this);
  this.delButtonClicked = new Event(this);
  var that = this;
 
  // 绑定模型监听器
  this._model.itemAdd.attach(function(){
    that.rebuildList();
  });
  this._model.itemRemoved.attach(function(){
    that.rebuildList();
  });
 
  // 将监听器绑定到HTML控件上
  this._elements.list.change(function(e){
    that.listModified.notify({index: e.target.selectedIndex});
  });
  // 添加按钮绑定事件
  this._elements.addButton.click(function(e){
    that.addButtonClicked.notify();
  });
  // 删除按钮绑定事件
  this._elements.delButton.click(function(e){
    that.delButtonClicked.notify();
  });
}
View.prototype = {
  constructor: 'View',
  show: function(){
    this.rebuildList();
  },
  rebuildList: function(){
    var list = this._elements.list,
      items,
      key;
    list.html("");
    items = this._model.getItems();
    for(key in items) {
      if(items.hasOwnProperty(key)) {
        list.append('' +items[key]+ '');
      }
    }
    this._model.setSelectedIndex(-1);
  }
};
/*
 控制器响应用户操作,调用模型上的变化函数
 负责转发请求,对请求进行处理
*/
function Controller(model,view) {
  this._model = model;
  this._view = view;
  var that = this;
 
  this._view.listModified.attach(function(sender,args){
    that.updateSelected(args.index);
  });
  this._view.addButtonClicked.attach(function(){
    that.addItem();
  });
  this._view.delButtonClicked.attach(function(){
    that.delItem();
  });
}
Controller.prototype = {
  constructor: 'Controller',
 
  addItem: function(){
    var item = window.prompt('Add item:', '');
    if (item) {
      this._model.addItem(item);
    }
  },
 
  delItem: function(){
    var index = this._model.getSelectedIndex();
    if(index !== -1) {
      this._model.removeItem(index);
    }
  },
 
  updateSelected: function(index){
    this._model.setSelectedIndex(index);
  }
};

Kod HTML adalah seperti berikut:

<select id="list" size="10" style="width: 10rem">select>br/>
<button id="plusBtn"> + button>
<button id="minusBtn"> - button>

Kod permulaan halaman adalah seperti berikut:

$(function () {
  var model = new Mode(['PHP', 'JavaScript']),
   view = new View(model, {
    'list' : $('#list'), 
    'addButton' : $('#plusBtn'), 
    'delButton' : $('#minusBtn')
    }),
    controller = new Controller(model, view);    
    view.show();
});

Analisis kod adalah seperti berikut:

Mari kita analisa dahulu jenis fungsi yang ingin kita capai Fungsi asas ialah:

Kotak lungsur turun yang membolehkan pengguna menambah item dan memadam item selepas memilihnya melalui operasi input pengguna;
Sudah tentu, acara untuk pengguna beralih kepada item itu juga ditambah;

Sebagai contoh, apabila kami menambah sekeping data sekarang, tambahkan acara mendengar pada lapisan paparan, seperti yang ditunjukkan dalam kod berikut:


// 添加按钮绑定事件
this._elements.addButton.click(function(e){
  that.addButtonClicked.notify();
});
Kemudian panggil kaedah pemberitahuan dalam acara kelas pemerhati (terbitkan acara) yang.addButtonClicked.notify(); acara tertentu pada masa yang sama objek tema, apabila objek tema berubah, semua objek yang bergantung padanya akan dimaklumkan; Oleh itu, dalam lapisan kawalan (Controller) kita boleh menggunakan kod berikut untuk memantau penerbit:



this._view.addButtonClicked.attach(function(){
  that.addItem();
});
Kemudian panggil kaedahnya sendiri addItem(); kodnya adalah seperti berikut:


addItem: function(){
  var item = window.prompt('Add item:', '');
  if (item) {
    this._model.addItem(item);
  }
}
Panggil kaedah addItem() lapisan model (model); masukkan sekeping data ke dalam kotak pilihan;


Kod di atas menambah item, menerbitkan mesej melalui this.itemAdd, dan kemudian memantau mesej melalui kod berikut pada lapisan paparan (Lihat kod adalah seperti berikut:
// 增加一项
addItem: function(elem) {
  this._elems.push(elem);
  this.itemAdd.notify({elem:elem});
},
).


Selepas akhirnya memantau data pada model (Model), ia segera memanggil kaedahnya sendiri rebuildList() untuk mengemas kini data pada halaman
// 绑定模型监听器
this._model.itemAdd.attach(function(){
   that.rebuildList();
});
Lapisan model (Model) bertanggungjawab terutamanya untuk operasi pengkapsulan data perniagaan. Lapisan paparan (Lihat) terutamanya menerbitkan operasi acara dan memantau data pada lapisan model Jika data pada lapisan model berubah, ia akan mengemas kini operasi halaman dalam masa dan akhirnya memaparkannya pada halaman Lapisan kawalan (Pengawal). memantau lapisan paparan (Lihat peristiwa, panggil kaedah lapisan model (Model) untuk mengemas kini data pada model Selepas data lapisan model dikemas kini, mesej akan diterbitkan. mengemas kini halaman dengan memantau perubahan data lapisan model (Model Paparan di atas adalah proses asas MVC).

Kelebihan MVC:


 
1. Gandingan rendah:
Lapisan paparan dan lapisan perniagaan diasingkan Jika paparan pada halaman berubah, ia boleh ditukar terus dalam lapisan paparan tanpa menyentuh model lapisan dan kawalan Kod pada lapisan; iaitu lapisan paparan, lapisan model dan lapisan kawalan Sudah dipisahkan; jadi mudah untuk menukar lapisan data dan peraturan perniagaan lapisan aplikasi.  
2. Kebolehselenggaraan:
Memisahkan lapisan paparan dan lapisan logik perniagaan juga menjadikan aplikasi WEB lebih mudah untuk diselenggara dan diubah suai. Kelemahan MVC:
Secara peribadi saya fikir ia sesuai untuk projek besar, dan ia tidak sesuai untuk projek kecil dan sederhana, kerana untuk mencapai operasi penambahan, pemadaman dan pengubahsuaian yang mudah, hanya sedikit kod JS diperlukan, tetapi jumlah kod mod MVC telah meningkat dengan ketara. Kos pembelajaran juga akan meningkat Sudah tentu, adalah lebih baik jika anda menggunakan beberapa perpustakaan atau rangka kerja MVC yang terkandung.
Di atas adalah analisis terperinci kaedah pelaksanaan corak MVC dalam JavaScript, kelebihan dan kekurangannya, saya harap ia akan membantu pembelajaran semua orang.

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn