温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么用JavaScript模拟实现简单的MVC

发布时间:2023-05-06 09:46:03 来源:亿速云 阅读:108 作者:iii 栏目:开发技术

本篇内容主要讲解“怎么用JavaScript模拟实现简单的MVC”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用JavaScript模拟实现简单的MVC”吧!

MVC是一种常见的软件架构模式,将一个应用程序分为三个核心的部分:模型(Model)、视图(View)和控制器(Controller)。MVC模式的目的是将应用程序的数据、用户界面和控制逻辑分离,提高代码的可维护性,可拓展性和可重用性。

在我们前端看来:

  • Model模型层,用来获取、存放所有的对象的数据

  • View表现层,呈现信息给用户

  • Controller控制层,模型和视图之间的纽带。

下面我们就按照这三层划分用js实现一个MVC

场景

这里我们就来模拟一个场景。

怎么用JavaScript模拟实现简单的MVC

点击increase按钮,就增加,点击decrease就减少

<body>
	<div id="num"></div>
	<button id="increase">increase</button>
	<button id="decrease">decrease</button>
</body>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.js"></script>
<script src="./index.js"></script>

为了方便操作dom我们引入了jquery。创建一个index.js代码逻辑放到index.js

核心思想

环境已经准备好,下面给我开始搞!

在搞之前,我们首先要知道MVC的核心思想是个啥?开头的时候已经讲过了三个核心的部分,那如何让这三个核心的部分串起来呢?

首先代码运行起来要有一个初始化的过程。Controller是模型和视图之间的枢纽。首先需要对Controller,并且需要在Controller里面对ModelView之间建立关系。初始化的时候将Model中的数据,渲染到View中,同时View层对界面中的行为事件进行监听,如果界面想要修改数据则触发View层中的监听行为,需要在Controller中通知Model层修改数据,然后再展示到界面。

init

const myApp = {};

myApp.Model = function () {}

myApp.View = function () {}

myApp.Controller = function () {}

(function () {
  var controller = new myApp.Controller();
  controller.init();
})();

Controller

myApp.Controller = function () {
  var view, model;

  this.init = function () {
    model = new myApp.Model();
    view = new myApp.View(this);

    model.register(view);
    model.notify();
  };

  this.increase = function () {
    model.add(1);
    model.notify();
  };

  this.decrease = function () {
    model.sub(1);
    model.notify();
  };
};

当执行init的时候,会对ModelView进行初始化,在初始化View时,需要将Controller本身传入。为什么要传入呢?下面看View的时候会介绍。在model中有个register的方法,需要将初始化的view注册到model中,同时需要触发modelnotify完成初始化的整个过程。

View

// View
myApp.View = function (controller) {
  var $num = $("#num"),
    $inc = $("#increase"),
    $dec = $("#decrease");

  this.render = function (model) {
    $num.text(model.getVal() + "rem");
  };

  $inc.click(controller.increase);
  $dec.click(controller.decrease);
};

view中,获取界面需要操作的dom。定义一个render方法,这个方法初始化的时候,会获取model中的数据,渲染到界面上。当数据发生变化的时候,render方法会重新执行,重新渲染。下面两个按钮监听了两个事件,是controllerincreasedecrease方法。这就是为什么需要将controller传入到view中。

Model

//Model
myApp.Model = function () {
  var val = 0;

  this.add = function (v) {
    val += v;
  };

  this.sub = function (v) {
    val -= v;
  };

  this.getVal = function () {
    return val;
  };

  var self = this,
    views = [];

  this.register = function (view) {
    views.push(view);
  };

  this.notify = function () {
    for (var i = 0; i < views.length; i++) {
      views[i].render(self);
    }
  };
};

Model层中,定义了初始值valadd对值增加,sub对值减少。getVal对值的读取。还定义了一个数组views。还记得上面controller的时候model.register(view)吗?初始化的时候,将view存入到modelviews中。notify就是通知view更新的。执行notify的时候,对views中的每个view遍历,然后执行viewrender方法,这就是发布订阅模式。

到此,相信大家对“怎么用JavaScript模拟实现简单的MVC”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI