vue (读音 /vjuː/, 类似于 view) 是一套用于构建用户界面的渐进式框架. 与其它大型框架不同的是, Vue 被设计为可以自底向上逐层应用. Vue 的核心库只关注视图层, 方便与第三方库或既有项目整合.
vue.js 是一个构建数据驱动的 web 界面的渐进式框架. Vue.JS 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件. 核心是一个响应的数据绑定系统.
Vue 的核心库只关注视图层, 不仅易于上手, 还便于与第三方库或既有项目整合. 另一方面, 当与现代化的工具链以及各种支持类库结合使用时, Vue 也完全能够为复杂的单页应用提供驱动.
vue 的优点
(1)双向数据绑定
也就是所谓的响应式数据绑定. 这里的响应式不是 @media 媒体查询中的响应式布局, 而是指 vue.JS 会自动对页面中某些数据的变化做出同步的响应.
也就是说, vue.JS 会自动响应数据的变化情况, 并且根据用户在代码中预先写好的绑定关系, 对所有绑定在一起的数据和视图内容都进行修改. 而这种绑定关系, 就是以 input 标签的 v-model 属性来声明的, 因此你在别的地方可能也会看到有人粗略的称 vue.JS 为声明式渲染的模版引擎.
这也就是 vue.JS 最大的优点, 通过 MVVM 思想实现数据的双向绑定, 让开发者不用再操作 dom 对象, 有更多的时间去思考业务逻辑.
(2)组件化开发
在前端应用, 我们是否也可以像编程一样把模块封装呢? 这就引入了组件化开发的思想.
Vue.JS 通过组件, 把一个单页应用中的各种模块拆分到一个一个单独的组件 (component) 中, 我们只要先在父级应用中写好各种组件标签(占坑), 并且在组件标签中写好要传入组件的参数(就像给函数传入参数一样, 这个参数叫做组件的属性), 然后再分别写好各种组件的实现(填坑), 然后整个应用就算做完了.
(3)Virtual DOM
现在的网速越来越快了, 很多人家里都是几十甚至上百 M 的光纤, 手机也是 4G 起步了, 按道理一个网页才几百 K, 而且浏览器本身还会缓存很多资源文件, 那么几十 M 的光纤为什么打开一个之前已经打开过, 已经有缓存的页面还是感觉很慢呢? 这就是因为浏览器本身处理 DOM 也是有性能瓶颈的, 尤其是在传统开发中, 用 jQuery 或者原生的 JavaScript DOM 操作函数对 DOM 进行频繁操作的时候, 浏览器要不停的渲染新的 DOM 树, 导致页面看起来非常卡顿.
而 Virtual DOM 则是虚拟 DOM 的英文, 简单来说, 他就是一种可以预先通过 JavaScript 进行各种计算, 把最终的 DOM 操作计算出来并优化, 由于这个 DOM 操作属于预处理操作, 并没有真实的操作 DOM, 所以叫做虚拟 DOM. 最后在计算完毕才真正将 DOM 操作提交, 将 DOM 操作变化反映到 DOM 树上.
(4)轻量高效
Vue.JS 通过简洁的 API 提供高效的数据绑定和灵活的组件系统
其他优点:
(1)动画系统
Vue.JS 提供了简单却强大的动画系统, 当一个元素的可见性变化时, 用户不仅可以很简单地定义对应的 CSS Transition 或 Animation 效果, 还可以利用丰富的 JavaScript 钩子函数进行更底层的动画处理.
更多 Web 前端开发 https://www.html.cn/ 知识, 请查阅 HTML 中文网 !!
来源: http://www.css88.com/qa/vue-js/16961.html