管中窥Vue
博客文章链接:管中窥Vue
Vue
和Angular
、React.js
的相同点和不同点?
与React
的相同:
- 都使用了
Virtual DOM
- 提供了响应式和组件化的视图组件
- 将注意力集中保持在核心库,而将其他功能如路由和全局状态管理交给相关的库。
与React
的区别:
组件的响应式渲染
React
的组件的数据状态发生变化时,它会以该组件为根,重新渲染整个组件子树;而Vue
不只去渲染需要渲染的组件。
HTML+CSS
的编写React
使用的JSX
语法,将HTML
、CSS
和JS
混写;而Vue
使用的是templates
模板方式,完全融合与经典的Web
技术。
与Angular
的区别:
- 与
Angular 1
对比,Vue
的性能更加优越,Angular
性能会随着watcher
的增加而变慢,而且Angular
中一些watcher
会触发另一个更新,使得“脏检查循环”可能会运行多次。 Angular
事实上必须用TypeScript
来开发,而且Angular
对于TS
的支持非常全面,而Vue
暂时对于TS
的支持还在改进阶段。Vue
的体积更小,一个包含了vuex + vue-router
的Vue
项目 (30kb gzipped
) 相比使用了这些优化的angular-cli
生成的默认项目尺寸 (~130kb
) 还是要小得多。
Vue
中的MVVM
模型?
Vue
是以数据为驱动的,Vue
自身将DOM
和数据进行绑定,一旦创建绑定,DOM
和数据将保持同步,每当数据发生变化,DOM
会跟着变化。ViewModel
是Vue
的核心,它是Vue
的一个实例。Vue
实例是作用在某个HTML
元素上的,这个HTML
元素可以是body
,也可以是某个id
所指代的元素。DOM Listeners
和Data Bindings
是实现双向绑定的关键。DOM Listeners
监听页面所有View
层DOM
元素的变化,当View
发生变化,Model
层的数据随之变化;Data Bindings
监听Model
层的数据,当数据发生变化,View
层的DOM
元素随之变化。
v-if
和v-show
指令有什么区别?
v-show
对应的值无论是true
还是false
,对应Html
元素都会存在于浏览器的文档中;而v-if
如果是false
的话,直接不在文档中了。
如何阻止
Vue
中的绑定事件不发生冒泡?
- 可以使用“事件修饰符”来处理事件冒泡,如:
v-on:click.stop
阻止事件冒泡或v-on:submit.prevent
阻止默认事件。
父、子组件间是如何通信的?
- 在
Vue
中,每个组件实例的作用域是孤立的。这也意味着不能(也不应该)在子组件的模板内直接应用父组件的数据。父组件通过Props
向子组件传递数据,而子组件通过Events
向父组件传递数据。
非父子层级的组件如何实现通信?
- 简单的应用场景下,可以使用一个空的
Vue
实例作为中央事件总线。 - 在复杂的情况下,可以考虑使用
Vue
官方提供的状态管理模式——Vuex
来进行管理。
什么是动态组件?它的作用是什么?
- 通过使用保留的
<component>
元素,动态地绑定到它的is
特性,我们让多个组件可以使用同一个挂载点,并可以动态地切换。 - 除此之外,
Vue
还提供了keep-alve
指令。keep-alive
指令允许把切换出去的组件保留在内存中,并保留它的状态或避免重新渲染。
为什么组件中的
data
属性的值必须是一个函数?
- 因为在一个组件被多次引用的情况下,如果
data
的值是一个Object
的话,那么由于Object
是一个引用类型,所以即使是该组件被多次引用,而其实操作的是同一个对象,最终导致了引用该组件的所有位置都同步的显示了。
原文地址:https://segmentfault.com/a/1190000016990339
管中窥Vue的更多相关文章
- webstorm中关于vue的一些问题
在进行vue开发中,我使用了webstorm,但是过程坎坷艰辛,遇到了很多问题,我将问题和解决方案贴上,以作参考. 1.vue项目部署在webstorm中,第一个遇到的问题是,webstorm卡住了, ...
- 在pycharm中开发vue
一.在pycharm中开发vue ''' webstorm(vue) pycharm(python) goland(Go语言) idea(java) andrioStuidio(安卓) Php(PHP ...
- vue生命周期图示中英文版Vue实例生命周期钩子
vue生命周期图示中英文版Vue实例生命周期钩子知乎上近日有人发起了一个 “react 是不是比 vue 牛皮,为什么?” 的问题,Vue.js 作者尤雨溪12月4日正面回应了该问题.以下是尤雨溪回复 ...
- 在webpack构建的项目中使用vue
一.复习在普通网页中使用vue1.使用script引入vue2.在index中创建 id为app的容器3.通过new vue得到vm实例二.在webpack中尝试使用vue://注意 : 在webpa ...
- 在webpack中配置vue.js
在webpack中配置vue.js 这里有两种在webpack中配置vue.js的方法,如下: 1.在main.js中引入vue的包: index.html: <!DOCTYPE html> ...
- IDEA 中使用 Vue 提示 namespace is not bound
今天在 IDEA 中使用 vue.js 时提示我如下错误信息 解决方法: 把这个校验项目去掉就可以了.
- webstorn中的vue文件识别es6代码
webstorn中的vue文件识别es6代码 1.webstorm中es6语法报错,解决方法: 打开 Settings => Languages & Frameworks => J ...
- webpack 中导入 vue 和普通网页使用 vue 的区别(四)
一:在普通网页中使用 vue 使用 script 标签,引入 vue 包 在 ndex 页面中,创建一个 id 为 App 的 div 容器 通过 new Vue 得到一个 vue 实例 二:在 we ...
- Vue+Typescript中在Vue上挂载axios使用时报错
Vue+Typescript中在Vue上挂载axios使用时报错 在vue项目开发过程中,为了方便在各个组件中调用axios,我们通常会在入口文件将axios挂载到vue原型身上,如下: main.t ...
随机推荐
- 天梯赛 - L2-003 月饼
题目链接:https://www.patest.cn/contests/gplt/L2-003 现在只能做水题~ #include <iostream> #include <cstd ...
- c实现的trim函数
功能:去掉字符串首尾的空格,换行符等空白. 代码: #include <string.h> #include <stdio.h> #include <ctype.h> ...
- kafka生产者客户端
kafka的生产者 1. 生产者客户端开发 熟悉kafka的朋友都应该知道kafka客户端有新旧版本,老版本采用scala编写,新版本采用java编写.随着kafka版本的升级,旧版本客户端已经快 ...
- Jenkins构建完成后通过SVN Publisher Plugin上传文件到指定的SVN(教程收集)
SVN Publisher Plugin:https://wiki.jenkins-ci.org/display/JENKINS/SVN+Publisher 构建完成后的文件,比如Maven打的war ...
- 电影TS/TC/SCR/R5/BD/HD/HC版本意思收集(转)
一.版本说明: 1.CAM(枪版) CAM通常是用数码摄像机从电影院盗录.有时会使用小三角架,但大多数时候不可能使用,所以摄像机会抖动.因此我们看到画面通常偏暗人物常常会失真,下方的 字幕时常会出现倾 ...
- CSS 发明者 Håkon Wium Lie 访谈--csdn zhangxin09
原文地址:https://dev.opera.com/articles/css-twenty-years-hakon/ ---------------------------------------- ...
- 开始我的GL离屏渲染绑定[转]
地址: http://wiki.woodpecker.org.cn/moin/lilin/swig-glBmpContext 呵呵,有了第一次的经验,我们就要开始我们的GL离屏渲染的绑定了. 关 于O ...
- const mutable
在C++中,由const修饰的成员函数的函数体内部,是不能够对成员变量进行修改的.这个特性被用来保证某些成员函数在实现过程中,避免由于程序员大意而对数据进行了错误的修改:同时也说明此成员函数是非修改性 ...
- python 列表结构更新的奇妙问题
使用python + plt 画图遇到了一个奇怪的问题 应该出来的是这样: 结果做出来以后是这样: 为什么画到一起了...... 这个锅python列表背 a=[1,2]b=a 这样 改变b ,a ...
- [Hibernate开发之路](3)基础配置
一 JDBC链接 通常你希望SessionFactory来为你创建和缓存(pool)JDBC连接. 假设你採用这样的方式, 仅仅须要例如以下例所看到的那样,打开一个Session: Session s ...