学习Vue(第一个Vue程序)

  • Post author:
  • Post category:vue


NO.1、了解什么是MVVM

MVVM(Model-View-ViewModel)是一种软件设计模式,由微软WPF(用于替代WinForm,以前就是用这个技术开发桌面应用程序的)和Silverlight(类似于Java Applet,简单点说就是在浏览器上运行WPF)的架构师Ken Cooper和Ted Peters开发,是一种简化用户界面的事件驱动编程方式。由John Gossman(同样也是WPF和Sliverlight的架构师)与2005年在他的博客上发表。

MVVM源自于经典的MVC(Model-View-Controller)模式。MVVM的核心是ViewModel层,负责转换Model中的数据对象来让数据变得更容易管理和使用。其作用如下:

–该层向上与视图层进行双向数据绑定

–向下与Model层通过接口请求进行数据交互

(M)Model:负责存储数据(模型层);

(N)(V)View:负责显示数据(视图层);

(VM)ViewModel:Vue自带的层(内置)MVVM 不用关注ViewModel如何实现的,它是Vue内置的

最重的是M层,dom操作被极大简化,使用MVVM是面向数据进行编程

在这里插入图片描述

Vue.js就是其中流行的MVVM框架之一。

NO.2、了解Vue、https://cn.vuejs.org/

(官网解释语)Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

简单来说就是:

(1)MVVM模式的实现者

Model:模型层, 在这里表示JavaScript对象

View:视图层, 在这里表示DOM(HTML操作的元素)

ViewModel:连接视图和数据的中间件, Vue.js就是MVVM中的View Model层的实现者

在MVVM架构中, 是不允许数据和视图直接通信的, 只能通过ViewModel来通信, 而View Model就是定义了一个Observer观察者

ViewModel能够观察到数据的变化, 并对视图对应的内容进行更新

ViewModel能够监听到视图的变化, 并能够通知数据发生改变

至此, 我们就明白了, Vue.js就是一个MV VM的实现者, 他的核心就是实现了DOM监听与数据绑定

(2)Vue.js的优点

轻量级, 体积小是一个重要指标。Vue.js压缩后有只有20多kb(Angular压缩后56kb+,React压缩后44kb+)

移动优先。更适合移动端, 比如移动端的Touch事件

易上手,学习曲线平稳,文档齐全

吸取了Angular(模块化) 和React(虚拟DOM) 的长处, 并拥有自己独特的功能,如:计算属性

开源,社区活跃度高

NO.3、第一个Vue程序使用工具IDEA

(1)下载地址

开发版本,

包含完整的警告和调试模式:https://yuejs.org/js/vue.js

删除了警告,30.96KB min+gzip:https://vuejs.org/js/vue.min.js

CDN

(2)代码编写(使用vue)

①新建一个HTML文件。

②导入Vue.js。

③创建Vue实例。

④绑定页面元素

//①新建一个HTML文件。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
//④绑定页面元素
<!--view层,模板-->
  <div id="app"> 
{{message}}
</div>
//②导入Vue.js。
<!--导入Vue.js-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
<script type="text/javascript">
//③创建Vue实例。
    var vm = new Vue({
        el:"#app",
        /*Model:数据*/
        data:{message:"hello,vue!" }
    });
</script>
</body>
</html>

(4)测试

1、在浏览器上运行第一个Vue应用程序(点击箭头中的任意一个浏览器)

在这里插入图片描述

2、F12在控制台输入vm.message=’HelloWorld’, 然后回车, 你会发现浏览器中显示的内容由hello,vue!变成hello world

在这里插入图片描述

控制台直接输入vm.message来修改值, 中间是可以省略data的, 在这个操作中, 我并没有主动操作DOM, 就让页面的内容发生了变化, 这就是借助了Vue的数据绑定功能实现的; MV VM模式中要求View Model层就是使用观察者模式来实现数据的监听与绑定, 以做到数据与视图的快速响应。



版权声明:本文为weixin_44484621原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。