0812 学习笔记
今天我学到什么写些什么,所以上下文没有关系
方法VS函数
函数和方法都是一段代码,通过名字来进行调用。
所有传递给函数的数据都是显式传递的。函数和对象无关。
方法跟一个对象相关联,方法中的数据是隐式传递的
function app(){
console.log('########')
}
const app1=new Vue({
methods:{
add(){
console.log('#########')
}
}
})
//app是函数
//app1中的add是方法,app1对象是类vue的实例化,add是app1的方法
vue的方法和函数汇总(这段是转载的)
var vm = new Vue({
el: '#app',// 控制区域
data: {},// 定义数据
methods: {},// 定义方法
filters: {},// 定义私有过滤器
directives: {},// 定义私有指令
components: { }, // 定义实例内部私有组件的
beforeCreate() { },// 实例刚在内存中被创建出来,此时,还没有初始化好 data 和 methods 属性
created() { }, //实例已经在内存中创建OK,此时 data 和 methods 已经创建OK,此时还没有开始 编译模板
beforeMount() { },// 此时已经完成了模板的编译,但是还没有挂载到页面中
mounted() { },// 此时,已经将编译好的模板,挂载到了页面指定的容器中显示
beforeUpdate() { },// 状态更新之前执行此函数, 此时 data 中的状态值是最新的,但是界面上显示的 数据还是旧的,因为此时还没有开始重新渲染DOM节点
updated() { },// 实例更新完毕之后调用此函数,此时 data 中的状态值 和 界面上显示的数据,都已经完成了更新,界面已经被重新渲染好了!
beforeDestroy() { },// 实例销毁之前调用。在这一步,实例仍然完全可用。
destroyed() { }, //Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。
})
声明式VS命令式
<body>
<div class="app">
<h2>{{message}}</h2>
</div>
</body>
<script>
const app=new Vue({
el:'.app',
data:{
message:'你好啊'
}
})
</script>
运行之后界面会显示”你好啊“,如果想要让界面显示”你好世界“,直接改变修改message处的值就可以,这就是声明式,就只需要声明我要什么,而不用操心我是如何做到的。
jQuery是典型的命令式,要想完成同样的任务,我们需要使用$符选择h2元素,并修改innerHTML的值,这一步一步都需要手动敲代码去完成。
再来一个通俗的例子:
我让jQuery去买瓶酱油,给了他100块钱,这时我们需要告诉他去小卖铺的路怎么走、怎么跟老板说买啥酱油,买多少钱的酱油,找多少零钱,还得告诉他怎么回来(命令式)。
我让Vue去买酱油去了,这时我只需要给他钱,并且告诉他目的地在哪儿,买什么酱油即可,不需要手把手教他(函数式)。
这也是现在为什么jQuery越来越少人用,而三大框架越来越火的原因,谁不想少操点心呢,是头发太多了吗。