创建Vue实例时,使用 new Vue ({//配置项}) 或者 组件定义中 export default {//配置项},所有的Vue组件都是Vue实例,并且接受相同的选项对象(一些根实例特有的选项除外)

如:

new Vue({
//选项配置
  el: '#app',
components: { App },
template: '<App/>'
})

配置项一共可以分为六大类:数据、DOM、生命周期钩子、资源、组合、其他

一、数据

(1)data:Vue根实例或者当前组件上的数据对象,类型可能是纯粹的object形式,但当为组件上的数据时,必须是function类型

当是Vue根实例上时:

new Vue ({
data: {
num: 3
}
})

当是组件上的数据时:

export default {
data: function () {
return {
num: 3
}
}
}

(2)computed:计算属性,根据data中的数据需要动态计算的属性。在new根实例和组件中使用的方法和含义都一样,不一一举例(以下所有配置不提名都代表一样)

new Vue({
data: {
a: 1
} ,
computed: {
dbA: function(){
return this.a * 2;
}
}
})

如上例中,计算属性dbA是由data数据中的属性得到,使用时和数据属性a是一样的,没有差距

(3)watch:侦听器,监视data中属性的变化,来做出反应

new Vue({
data: {
a: 1,
dbA:2
},
watch: {
a: function(val,oldVal){//监听a的变化,val为变化后的值,oldVal为变化之前的值
this.dbA = val *2
}
}
})

和计算属性进行对比可以发现,当有一些数据需要随着其他数据变化而变化时,计算属性和侦听器有时均可以实现,要优选计算属性,避免侦听器的滥用!但是当需要在数据变化时执行异步操作或者开销较大的操作时,要是用侦听器

(4)methods:方法的集合,用到的所有方法,定义在其中

new Vue({
data: {
a: 1
} ,
methods: {
clickBtn: function(){
this.a++;
}
}
})

(5)props:接受从父组件传过来的数据

在父组件中,使用子组件时:<child v-bind:data1="data1"></child>,通过v-bind把子组件中所需要的数据传递给子组件,在子组件中通过props来接受

子组件中props的格式一般为为:props:['data1','data2',....]或者是 props:{data1:data1Type,data2:data2Type,...}

export default {
data () {
return {
show: true
}
},
props: {
lists: Array
}
}

(6)porpsData:只能用在new创建的根实例中,主要作用是方便测试

二:DOM

(1)el:只有在new创建的根实例中才有,提供一个在页面上已存在的DOM元素作为Vue实例的挂载目标,可以是一个CSS选择器也可以是一个HTMLElement实例,一般选用CSS选择器中的id来标识

(2)template:一个字符串模板作为Vue实例的标识使用

new Vue({
el: '#app',
components: { App },
template: '<App/>'
})

(3)render:字符串模板的代替方案,允许你发挥 JavaScript 最大的编程能力。该渲染函数接收一个 createElement 方法作为第一个参数用来创建 VNode。

Vue 选项中的 render 函数若存在,则 Vue 构造函数不会从 template 选项或通过 el 选项指定的挂载元素中提取出的 HTML 模板编译渲染函数。

(4)renderError:当render函数遭遇错误时,提供的另外一种渲染输出

三:生命周期钩子

生命周期钩子即生命周期回调函数,常用的分为以下三种:

(1)初始化阶段(执行一次):

  • beforeCreate(){},
  • created(){},
  • beforeMount(){},
  • mounted(){},//初始化完成后触发,一般在该回调函数中发送ajax请求或者启动定时器等异步任务

(2)更新阶段(执行0~n次):

  • beforeUpdated(){},
  • updated(){}

(3)死亡阶段(执行1次):

  • beforeDestroy(){},//做收尾工作,如:清除定时器
  • destroyed(){}

四:资源

(1)components:注册vue实例中可用的组件,是object类型

<template>
<div class="container">
<!--使用组件-->
<vue-header/>
<Menu/>
</div> </template> <script>
//引入组件
import VueHeader from './components/Header'
import Menu from './components/Menu'
export default{
components: { //注册组件
VueHeader,
Menu
}
}
</script>

(2)directives:注册(自定义)局部指令,自定义的指令只有在当前vue实例中有效

语法:directives:{"diretiveName":function(){}}

(3)filters:定义本地过滤器

filters: {
capitalize: function (value) {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
}
//除了上面在一个组件的选项中定义本地的过滤器,也可在在创建 Vue 实例之前全局定义过滤器
Vue.filter('capitalize', function (value) {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}) new Vue({
// ...
})

过滤器可以用在两个地方:双花括号插值和 v-bind 表达式

<!-- 在双花括号中 -->
{{ message | capitalize }} <!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>

Vue实例 中的常用配置项的更多相关文章

  1. Vue 实例中的生命周期钩子

    Vue 框架的入口就是 Vue 实例,其实就是框架中的 view model ,它包含页面中的业务处理逻辑.数据模型等,它的生命周期中有多个事件钩子,让我们在控制整个Vue实例的过程时更容易形成好的逻 ...

  2. 详解Vue 实例中的生命周期钩子

    Vue 框架的入口就是 Vue 实例,其实就是框架中的 view model ,它包含页面中的业务处理逻辑.数据模型等,它的生命周期中有多个事件钩子,让我们在控制整个Vue实例的过程时更容易形成好的逻 ...

  3. 2-3 Vue实例中的数据,事件和方法

    上节课模板是写在Vue的实例里面的,现在我们可以把它恢复出来.写在挂载点的内部,看起来会舒服一点.Vue的数据项,可以配置任意的数据名字. <!DOCTYPE html> <html ...

  4. Vue学习之vue实例中的数据、事件和方法

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. vue实例中created、mounted以及其他类型说明

    生命周期图示(图片来自coderwhy老师): 每个 Vue 实例在被创建之前都要经过一系列的初始化过程.例如,实例需要配置数据观测(data observer).编译模版.挂载实例到 DOM ,然后 ...

  6. Vue实例中封装api接口的思路 在页面中用async,await调用方法请求

    一般我们写小型的项目是用不到封装axios实例 但是当我们写大型项目时  接口有时候多到有上百个接口,那我们在请求一次调用一次接口,接口上好多都是重复的,这个时候我们就可以封装axios实例,既节省了 ...

  7. yarn 在Vue框架中的常用命令

    初始化项目 yarn add init 安装vue yarn add vue 安装webpack,webpack-dev-server(是一个小型的Node.js Express服务器) yarn a ...

  8. Vue.js中的常用的指令缩写

    Vue.js为两个最为常用的指令提供了特别的缩写: v-bind缩写 <!--完整语法--> <a v-bind:href="url">测试</a&g ...

  9. Vue开发中的常用技巧(持续更新)

    1. 监听子组件的生命周期例如有父组件Parent和子组件Child,如果父组件监听到子组件挂载mounted就做一些逻辑处理,常规写法可能如下: // Parent.vue <Child @m ...

随机推荐

  1. 10-19文献阅读之DCB

    ---恢复内容开始--- <一种精确估计区域北斗接收机硬件延迟的方法>-2016-,很有价值 估计北斗接收机硬件延迟,不需要传统复杂的电离层模型.已知一个参考站接收机硬件延迟的条件下,利用 ...

  2. CORS (Cross Origin Resources Share) 跨域

    CORS 跨域 1 什么是跨域问题 基于安全考虑,浏览器会限制使用脚本发起任何跨域请求. 所谓的跨域请求,就是与当前页面的 http/ip/port 不一样的请求. 但在实际运用中,跨域获取数据的需求 ...

  3. 我的开源项目——Jerry

    在日常工作中,经常会碰到一些问题,比如数字金额要写成千分位形式(1234 -> 123,4.00).要写成汉字大写形式(123 -> 壹佰贰拾叁圆),又比如要进行 cookie 读写操作, ...

  4. Java基础加强之并发(四)synchronized关键字

    并发系列参考文章http://www.cnblogs.com/skywang12345/p/3323085.html#3907193 synchronized原理 在java中,每一个对象有且仅有一个 ...

  5. Java反射学习一

    Java 反射机制 基本概念 在Java运行时环境中,对于任意一个类,能否知道这个类有哪些属性和方法?对于任意一个对象,能否调用它的任意一个方法? 答案是肯定的. 这种动态获取类的信息以及动态调用对象 ...

  6. CentOS部署Kubernetes1.13集群-1(使用kubeadm安装K8S)

    参考:https://www.kubernetes.org.cn/4956.html 1.准备 说明:准备工作需要在集群所有的主机上执行 1.1系统配置 在安装之前,需要先做如下准备.三台CentOS ...

  7. layer关闭当前窗口并刷新父窗口

    window.parent.location.reload(); var index = parent.layer.getFrameIndex(window.name); parent.layer.c ...

  8. highcharts柱状图实现legend和数据列一一对应效果

    var cate = ['Green', 'Pink']; Highcharts.chart('container', { chart: { type: 'column' }, legend: { e ...

  9. KVM虚拟机IO处理过程(一) ----Guest VM I/O 处理过程

    虚拟化技术主要包含三部分内容:CPU虚拟化,内存虚拟化,设备虚拟化.本系列文章主要描述磁盘设备的虚拟化过程,包含了一个读操作的I/O请求如何从Guest Vm到其最终被处理的整个过程.本系列文章中引用 ...

  10. Java开发工程师基础Math,Random,Scanner类的使用

    Math类的使用(重点) (1)数学操作类:该类没有构造函数,方法均为静态的 (2)掌握内容 A:成员变量 **E:比任何其他值都更接近e(即自然对数的底数)的double值. **PI:比任何其他值 ...