阅读时间预估:3分钟
html
当你看到这篇文章的时候,想必这位大侠不免多少略知Vue这个世界级别的框架的来头,华裔程序贵族尤雨溪大佬的开源做品(膜拜大佬三分钟...),从面世至今gitHub上的点赞数量已经超过Angular,React等著名框架,🔥的发紫,着实有后来者居上的感受,Vue借鉴了前二者的优秀设计模式和思想以一种渐进式的模式呈现给咱们,意图也很是明显,小白上手首选,学习成本低,开源社区活跃,废话很少说,接下来跟(da)着(lao)个人脚步,带你从小白进阶大佬(chui niu)..前端
大佬叮嘱: 万层高楼平地起,做为vue小白vue官方中文网必定要努力的通读几遍,案例必定要多敲几遍哦.vue
咱们所说的前端框架与库的区别?react
库,本质上是一些函数的集合。每次调用函数,实现一个特定的功能,接着把控制权交给使用者git
框架,是一套完整的解决方案,使用框架的时候,须要把你的代码放到框架合适的地方,框架会在合适的时机调用你的代码程序员
You call Library, Framework calls yougithub
核心点:谁起到主导做用(控制反转)npm
好莱坞原则:Don't call us, we'll call you.编程
框架的侵入性很高(从头至尾)segmentfault
后端中经常采用MVC模式.
MVC模式,将应用程序划分为三大部分,实现了职责分离
在前端中常常要经过 JS代码 来进行一些逻辑操做,最终还要把这些逻辑操做的结果如今页面中。也就是须要频繁的操做DOM
MVVM经过数据双向绑定让数据自动地双向同步
Vue这种MVVM模式的框架,不推荐开发人员手动操做DOM
虽然没有彻底遵循 MVVM 模型,Vue 的设计无疑受到了它的启发。所以在文档中常常会使用 vm (ViewModel 的简称) 这个变量名表示 Vue 实例
<!-- 指定vue管理内容区域,须要经过vue展现的内容都要放到找个元素中 一般咱们也把它叫作边界 数据只在边界内部解析-->
<div id="app">{{ msg }}</div>
<!-- 引入 vue.js -->
<script src="vue.js"></script>
<!-- 使用 vue -->
<script>
var vm = new Vue({
// el:提供一个在页面上已存在的 DOM 元素做为 Vue 实例的挂载目标
el: '#app',
// Vue 实例的数据对象,用于给 View 提供数据
data: {
msg: 'Hello Vue'
}
})
</script>
复制代码
var vm = new Vue({
data: {
msg: '你们好,我是Geek-James'
}
})
vm.$data.msg === vm.msg // true
复制代码
<h1>Hello, {{ msg }}.</h1>
<p>{{ 1 + 2 }}</p>
<p>{{ isOk ? 'yes': 'no' }}</p>
<!-- !!!错误示范!!! -->
<h1 title="{{ err }}"></h1>
复制代码
双向数据绑定:将DOM与Vue实例的data数据绑定到一块儿,彼此之间相互影响
原理:Object.defineProperty中的get和set方法
/* defineProperty语法 介绍 */
var obj = {}
Object.defineProperty(obj, 'msg', {
// 设置 obj.msg = "1" 时set方法会被系统调用 参数分别是设置后和设置前的值
set: function (newVal, oldVal) { },
// 读取 obj.msg 时get方法会被系统调用
get: function ( newVal, oldVal ) {}
})
复制代码
<!-- 示例 -->
<input type="text" id="txt" />
<span id="sp"></span>
<script>
var txt = document.getElementById('txt'),
sp = document.getElementById('sp'),
obj = {}
// 给对象obj添加msg属性,并设置setter访问器
Object.defineProperty(obj, 'msg', {
// 设置 obj.msg 当obj.msg反生改变时set方法将会被调用
set: function (newVal) {
// 当obj.msg被赋值时 同时设置给 input/span
txt.value = newVal
sp.innerText = newVal
}
})
// 监听文本框的改变 当文本框输入内容时 改变obj.msg
txt.addEventListener('keyup', function (event) {
obj.msg = event.target.value
})
</script>
复制代码
var vm = new Vue({
data: {
stu: {
name: 'jack',
age: 19
}
}
})
/* Vue.set */
Vue.set(vm.stu, 'gender', 'male')
/* Object.assign 将参数中的全部对象属性和值 合并到第一个参数 并返回合并后的对象*/
vm.stu = Object.assign({}, vm.stu, { gender: 'female', height: 180 })
复制代码
说明:Vue 异步执行 DOM 更新,监视全部数据改变,一次性更新DOM
优点:能够去除重复数据,对于避免没必要要的计算和 避免重复 DOM 操做上,很是重要
若是须要那到更新后dom中的数据 则须要经过 Vue.nextTick(callback):在DOM更新后,执行某个操做(属于DOM操做)
methods: {
fn() {
this.msg = 'change'
this.$nextTick(function () {
console.log('$nextTick中打印:', this.$el.children[0].innerText);
})
console.log('直接打印:', this.$el.children[0].innerText);
}
}
复制代码
Vue是个啥? 看完这篇不知道面前的这位大侠是否真正的领略到,欢迎留言点赞加评论,文章有不对的地方恳请各位大佬提出.
若是个人分享对面前的这位大侠有所启发,恳请以程序员最高礼遇点✨ 星加分享的方式鼓励我.
关注公众号回复:学习 领取前端最新最全学习资料,也能够进群和大佬一块儿学习交流