Vue之vue.js声明式渲染

Html:

<div id="app">

{{ message }}

</div>

Vue:

var app = new Vue({

el: ‘#app‘,

data: {

message: ‘Hello Vue!‘

}

})

本例子由HTML模板(View)+Vue实例(ViewModel)组成。

创建Vue的实例,需传入一个选项对象,如:

数据(data):Vue 将会递归将 data 的属性转换为 getter/setter,从而让 data 的属性能够响应数据变化。

属性(props): 可以是数组或对象,用于接收来自父组件的数据。props 可以是简单的数组,或者使用对象作为替代,对象允许配置高级选项,如类型检测、自定义校验和设置默认值。

挂载元素(el):提供一个在页面上已存在的 DOM 元素作为 Vue 实例的挂载目标。可以是 CSS 选择器,也可以是一个 HTMLElement 实例。

计算(computed):声明计算,处理复杂逻辑

方法(methods):声明方法,VM 实例可以访问这些方法,或者在指令表达式中使用。计算属性默认有getter,但也可以自定义一个setter。

computed和method比较:methods 来替代 computed,效果上两个都是一样的,但是 computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值。而使用 methods ,在重新渲染的时候,函数总会重新调用执行。computed 性能会更好,但是如果你不希望缓存,你可以methods。

为什么需要缓存?

假设我们有一个性能开销比较大的的计算属性 A ,它需要遍历一个极大的数组和做大量的计算。然后我们可能有其他的计算属性依赖于 A 。如果没有缓存,我们将不可避免的多次执行 A 的 getter!如果你不希望有缓存,请用 method 替代。

watch:观察和响应数据变化。一个对象,键是需要观察的表达式,值是对应回调函数。值也可以是方法名,或者包含选项的对象。

computed和watch比较:计算属性在大多数情况下更合适,但有时也需要一个自定义的 watch。watch 选项允许我们执行异步操作(访问一个 API),限制我们执行该操作的频率,并在我们得到最终结果前,设置中间状态。这是计算属性无法做到的。

扩展(extended):扩展到另一个组件。

minxin:混合实例对象可以像正常的实例对象一样包含选项。

parent:指定已创建的实例之父实例,在两者之间建立父子关系。

component:声明组件,包含 Vue 实例可用组件的哈希表。

生命周期

实例

var app = new Vue({

el: ‘#app‘,

data: {

message : "xuxiao is boy"

},

beforeCreate: function () {

console.group(‘beforeCreate 创建前状态===============》‘);

console.log("%c%s", "color:red" , "el     : " + this.$el); //undefined

console.log("%c%s", "color:red","data   : " + this.$data); //undefined

console.log("%c%s", "color:red","message: " + this.message)

}

})


指令


描述


beforeCeate


在实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用。


created


实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算, watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。


beforeMount


在挂载开始之前被调用:相关的 render 函数首次被调用。

该钩子在服务器端渲染期间不被调用


mounted


el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。如果 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。


beforeUpdate


数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。

你可以在这个钩子中进一步地更改状态,这不会触发附加的重渲染过程


updated


由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。

当这个钩子被调用时,组件 DOM 已经更新,所以你现在可以执行依赖于 DOM 的操作。然而在大多数情况下,你应该避免在此期间更改状态,因为这可能会导致更新无限循环。


activated


keep-alive 组件激活时调用。

该钩子在服务器端渲染期间不被调用。


deactivated


keep-alive 组件停用时调用。

该钩子在服务器端渲染期间不被调用


bedoreDestroy


实例销毁之前调用。在这一步,实例仍然完全可用。

该钩子在服务器端渲染期间不被调用。


destroyed


Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

该钩子在服务器端渲染期间不被调用。

时间: 2024-11-09 02:45:32

Vue之vue.js声明式渲染的相关文章

Vue 声明式渲染

Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统: <div id="app"> {{ message }} </div> var app = new Vue({ el: '#app', data: { message: 'Hello Vue!' } }) Hello Vue! 我们已经成功创建了第一个 Vue 应用!看起来这跟渲染一个字符串模板非常类似,但是 Vue 在背后做了大量工作.现在数据和 DOM 已经被建立了关联

vue_声明式渲染

在hello-vue目录新建一个HTML 在hello.html中,我们编写一段简单的代码: h2中要输出一句话:xx 非常帅.前面的xx是要渲染的数据. 然后我们通过Vue进行渲染: <body> <div id="app"> <h2>{{name}},非常帅!!!</h2> </div> </body> <script src="node_modules/vue/dist/vue.js"

Vue声明式和编程式导航

声明式: <router-link :to='{path:"/detail",query:{obj:value}}'></router-link> 编程式: this.$router.push({path:'/detail',query:{obj:value}}); detail.vue取值 this.$route.query.obj

[vue]声明式导航和编程式导航

声明式导航和编程式导航 共同点: 都能进行导航,都可以触发路由,实现组件切换 区别: 写法不一样,声明式导航是写在组件的template中,通过router-link来触发,编程式导航写在js函数中,通过this.$router.push(xxx)来触发路径 $route&&$router 共同点: 都是属于vue-roouter 区别: $route: 获取路径中的参数,还可以通过watch观测路径的变化 $router: 编程式导 https://www.cnblogs.com/zhu

使用 Vue 2.0 实现服务端渲染的 HackerNews

Vue 2.0 支持服务端渲染 (SSR),并且是流式的,可以做组件级的缓存,这使得极速渲染成为可能.同时, 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration.vue-hackernews-2.0 是 Vue 作者在GitHub上面放的 Vue 2.0 的一个示例项目,结合 Express.vue-router & vuex 来构建,是很好的学习案例. Features Server Side Rendering Vue + vue-router + vue

Vue过渡效果之JS过渡

前面的话 与CSS过渡不同,JS过渡主要通过事件进行触发.本文将详细介绍Vue过渡效果之JS过渡 事件钩子 JS过渡主要通过事件监听事件钩子来触发过渡,共包括如下的事件钩子 <transition v-on:before-enter="beforeEnter" v-on:enter="enter" v-on:after-enter="afterEnter" v-on:enter-cancelled="enterCancelled&

vue项目中app.vue 、main.js和 index.html的关联

1.main.js是我们的入口文件,主要作用是初始化vue实例并使用需要的插件. import Vue from 'vue' import App from './App' /* eslint-disable no-new */ new Vue({ el: '#app', template: '<App/>', components: { App } }) 2.App.vue是我们的主组件,所有页面都是在App.vue下进行切换的.其实你也可以理解为所有的路由也是App.vue的子组件.所以我

Ext JS 5的声明式事件监听

原文:Declarative Listeners in Ext JS 5 在前文<在Ext JS 5使用ViewControllers>中,简单的介绍了Ext JS 5的一项重要改进--声明式事件监听.在本文,将深度探讨如何使用声明式事件监听啦简化应用程序的视图并减少自定义组件的样板代码. 注意:文章假设你使用的是Ext JS 5.0.1或更高版本. 什么是声明式事件监听? 所谓的"声明式事件监听",就是指定义在类主体中的监听或在实例的配置对象中使用了listeners配置

关于困扰我一下午的vue指令 clickoutside.js;以及我对指令的测试结果

https://github.com/ElemeFE/element/blob/d419e260d0fc1463ccbc4f5e45e129ec0e972255/src/utils/clickoutside.js 下面的代码是element ui中的clickoutside.js const on = (function() { if (!Vue.prototype.$isServer && document.addEventListener) { return function(elem