初识vue

Posted 吴渣渣

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了初识vue相关的知识,希望对你有一定的参考价值。

Vue是什么

Vue.js是一个渐进式的前端框架,所谓渐进式就是你可以有阶段性地使用Vue,而不必一开始就使用它的所有东西。同时,Vue也改变了传统的前端开发模式,提供了一下常见的高级功能,比如:

  • 解耦视图和数据
  • 可复用的组件
  • 前端路由
  • 状态管理
  • 虚拟DOM(Virtual DOM)

MVVM模式

与知名前端框架Angular、Ember等一样,Vue.js在设计上也使用了MVVM(Model-View-ViewModel)模式。

MVVM模式是由经典的软件架构MVC衍生而来的。当View(视图层)变化时,会自动更新到ViewModel(视图模型),反之亦然,View和ViewModel之间通过双向数据绑定(data-binding)建立联系,如下所示:

Vue.js与Jquery有什么不同

如下代码用jquery操作dom、绑定一个点击事件

var btn = $('<button>Click me</button>');
btn.on('click',function()
   console.log('Clicked!');
)
$('#app').append(btn);

可以看出,虽然操作的内容不复杂,但是此时我们的视图代码已经和业务逻辑代码紧耦合在一起了,随着功能的不断增加,直接通过操作dom的方式会使代码越来越难维护。

而Vue.js通过MVVM模式拆分为视图和数据两部分,并将其分离,因此你只需要关心数据即可,dom的操作Vue会帮你搞定,用Vue.js改写上述代码:

<body>
    <div id="app">
        <button v-if="showBtn" v-on:click="handleClick">Click me</button>
    </div>
    <script>
        new Vue(
            el:'#app',
            data:
                showBtn:true
            ,
            methods:
                handleClick:function()
                    console.log('Clicked!');
                
            
        );
    </script>
</body>

如何使用Vue.js

对比传统前端开发模式和Vue.js的开发模式

  • 传统的前端开发模式

前端技术快速发展,比如EMCAScript6、Node.js、NPM、前端工程化等不断在优化我们的开发模式,常用的用于生产的万金油的技术栈:
Jquery+RequestJs(SeaJs)+artTemplate(doT)+Gulp(Grunt)

RequireJs(SeaJs):模块化代码,解决代码依赖混乱的问题,便于团队协作
doT:前端模板,可以将数据与html模板分离
gulp:自动化构建工具,可以合并压缩代码

传统的开发模式简单高效,但是随着项目扩大和时间推移,出现了更为复杂的业务场景,如SPA(单页面富应用)、组件解耦。为了提高开发效率,降低维护成本,这时候就出现了Angular、React以及Vue.js。

  • Vue.js的开发模式

如果只是开发简单的html5页面或者小应用,可以直接通过script加载csn文件,如

<script type="text/javascript" src="https://unpkg.com/vue/dist/vue.min.js"></script>

接着,在body结束标签前使new Vue()来创建一个实例,这就是Vue.js最基本的开发模式。

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <script type="text/javascript" src="../../assets/js/vue.js"></script>
</head>
<body>
<div id="app">
   <ul>
       <li v-for="item in sortItems">
           item
       </li>
   </ul>
</div>

<script type="text/javascript">
   var app=new Vue(
       el:'#app',
       data:
           items:[20,23,18,65,32,19,5,56,41]
       ,
       computed:
           sortItems:function()
               return this.items.sort(sortNumber);
           
       
   );

   function sortNumber(a,b)
       return a-b
   
</script>
</body>
</html>

对于业务逻辑复杂,对前端工程有要求的项目,可以使用Vue单文件的形式配合webpack使用,必要时候还会使用vuex来管理状态,vue-router来管理路由。

参考文章

  • 《vue.js实战》

以上是关于初识vue的主要内容,如果未能解决你的问题,请参考以下文章

云计算——从传统的linux OS窥云平台

自然语言处理必会万金油工具包-NLTK一小时快速上手!

关于Vue的组件的通用性问题

初识Vue

初识Vue

Vue初识