vue实例的选项总结


Posted in Javascript onJune 09, 2020

一、数据

API:https://cn.vuejs.org/v2/api/#%E9%80%89%E9%A1%B9-%E6%95%B0%E6%8D%AE

1. data

类型:Object | Function

限制:组件的定义只接受 function

详细:Vue 实例的数据对象。Vue 将会递归将 data 的属性转换为 getter/setter,从而让 data 的属性能够响应数据变化。对象必须是纯粹的对象 (含有零个或多个的 key/value 对)。当一个组件被定义,data 必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例。如果 data 仍然是一个纯粹的对象,则所有的实例将共享引用同一个数据对象!通过提供 data 函数,每次创建一个新实例后,我们能够调用 data 函数,从而返回初始数据的一个全新副本数据对象。

var data = { a: 1 }

// 直接创建一个实例
var vm = new Vue({
 data: data
})
vm.a // => 1
vm.$data === data // => true

// Vue.extend() 中 data 必须是函数
var Component = Vue.extend({
 data: function () {
  return { a: 1 }
 }
})

2. computed

类型:{ [key: string]: Function | { get: Function, set: Function } }

详细:计算属性将被混入到 Vue 实例中。所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例。计算属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算。注意,如果某个依赖 (比如非响应式属性) 在该实例范畴之外,则计算属性是不会被更新的。

var vm = new Vue({
 data: { a: 1 },
 computed: {
  // 仅读取
  aDouble: function () {
   return this.a * 2
  },
  // 读取和设置
  aPlus: {
   get: function () {
    return this.a + 1
   },
   set: function (v) {
    this.a = v - 1
   }
  }
 }
})
vm.aPlus  // => 2
vm.aPlus = 3
vm.a    // => 2
vm.aDouble // => 4

3. methods

类型:{ [key: string]: Function }

详细:methods 将被混入到 Vue 实例中。可以直接通过 VM 实例访问这些方法,或者在指令表达式中使用。方法中的 this 自动绑定为 Vue 实例。

var vm = new Vue({
 data: { a: 1 },
 methods: {
  plus: function () {
   this.a++
  }
 }
})
vm.plus()
vm.a // 2

4. watch

类型:{ [key: string]: string | Function | Object | Array }

详细:一个对象,键是需要观察的表达式,值是对应回调函数。值也可以是方法名,或者包含选项的对象。Vue 实例将会在实例化时调用 $watch(),遍历 watch 对象的每一个属性。

5. props

类型:Array<string> | Object

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

你可以基于对象的语法使用以下选项:

1  type: 可以是下列原生构造函数中的一种:String、Number、Boolean、Array、Object、Date、Function、Symbol、任何自定义构造函数、或上述内容组成的数组。会检查一个 prop 是否是给定的类型,否则抛出警告。Prop 类型的更多信息在此。

2  default: any 为该 prop 指定一个默认值。如果该 prop 没有被传入,则换做用这个值。对象或数组的默认值必须从一个工厂函数返回。

3  required: Boolean 定义该 prop 是否是必填项。在非生产环境中,如果这个值为 truthy 且该 prop 没有被传入的,则一个控制台警告将会被抛出。

4  validator: Function 自定义验证函数会将该 prop 的值作为唯一的参数代入。在非生产环境下,如果该函数返回一个 falsy 的值 (也就是验证失败),一个控制台警告将会被抛出。你可以在这里查阅更多 prop 验证的相关信息。

二、DOM

API:https://cn.vuejs.org/v2/api/#%E9%80%89%E9%A1%B9-DOM

1.el

类型:string | Element

限制:只在用 new 创建实例时生效。

详细:

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

(2)在实例挂载之后,元素可以用 vm.$el 访问。

(3)如果在实例化时存在这个选项,实例将立即进入编译过程,否则,需要显式调用 vm.$mount() 手动开启编译。

提供的元素只能作为挂载点。不同于 Vue 1.x,所有的挂载元素会被 Vue 生成的 DOM 替换。因此不推荐挂载 root 实例到 <html> 或者 <body> 上。

如果 render 函数和 template property 都不存在,挂载 DOM 元素的 HTML 会被提取出来用作模板,此时,必须使用 Runtime + Compiler 构建的 Vue 库。

2.template

类型:string

详细:一个字符串模板作为 Vue 实例的标识使用。模板将会替换挂载的元素。挂载元素的内容都将被忽略,除非模板的内容有分发插槽。

如果值以 # 开始,则它将被用作选择符,并使用匹配元素的 innerHTML 作为模板。常用的技巧是用 <script type="x-template"> 包含模板。

出于安全考虑,你应该只使用你信任的 Vue 模板。避免使用其他人生成的内容作为你的模板。

如果 Vue 选项中包含渲染函数,该模板将被忽略。

3.render

类型:(createElement: () => VNode) => VNode

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

如果组件是一个函数组件,渲染函数还会接收一个额外的 context 参数,为没有实例的函数组件提供上下文信息。

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

4.renderError

2.2.0 新增

类型:(createElement: () => VNode, error: Error) => VNode

详细:只在开发者环境下工作。

当 render 函数遭遇错误时,提供另外一种渲染输出。其错误将会作为第二个参数传递到 renderError。这个功能配合 hot-reload 非常实用。

示例:

new Vue({
 render (h) {
  throw new Error('oops')
 },
 renderError (h, err) {
  return h('pre', { style: { color: 'red' }}, err.stack)
 }
}).$mount('#app')

以上就是vue实例的选项总结的详细内容,更多关于VUE 实例选项的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
可输入的下拉框
Jun 19 Javascript
Prototype使用指南之hash.js
Jan 10 Javascript
jq实现酷炫的鼠标经过图片翻滚效果
Mar 12 Javascript
浅谈$(document)和$(window)的区别
Jul 15 Javascript
Node.js本地文件操作之文件拷贝与目录遍历的方法
Feb 16 Javascript
使用PHP+JavaScript将HTML页面转换为图片的实例分享
Apr 18 Javascript
微信小程序 form组件详解
Oct 25 Javascript
jQuery实现获取隐藏div高度的方法示例
Feb 09 Javascript
VsCode插件整理(小结)
Sep 14 Javascript
node简单实现一个更改头像功能的示例
Dec 29 Javascript
优雅的elementUI table单元格可编辑实现方法详解
Dec 23 Javascript
Vue-cli3项目引入Typescript的实现方法
Oct 18 Javascript
微信小程序中的列表切换功能实例代码详解
Jun 09 #Javascript
vue项目或网页上实现文字转换成语音播放功能
Jun 09 #Javascript
浅谈vue的第一个commit分析
Jun 08 #Javascript
从零开始在vue-cli4配置自适应vw布局的实现
Jun 08 #Javascript
详解Vue Cli浏览器兼容性实践
Jun 08 #Javascript
解决微信授权成功后点击按返回键出现空白页和报错的问题
Jun 08 #Javascript
微信h5静默和非静默授权获取用户openId的方法和步骤
Jun 08 #Javascript
You might like
用mysql内存表来代替php session的类
2009/02/01 PHP
PHP开发不能违背的安全规则 过滤用户输入
2011/05/01 PHP
php获取系统变量方法小结
2015/05/29 PHP
php简单创建zip压缩文件的方法
2016/04/30 PHP
php+mysql+ajax 局部刷新点赞/取消点赞功能(每个账号只点赞一次)
2020/07/24 PHP
PHP延迟静态绑定使用方法实例解析
2020/09/05 PHP
Javascript 检测、添加、移除样式(className)函数代码
2009/09/08 Javascript
javascript sudoku 数独智力游戏生成代码
2010/03/27 Javascript
JS中处理与当前时间间隔的函数代码
2012/05/23 Javascript
JS中令人发指的valueOf方法介绍
2013/02/22 Javascript
详谈nodejs异步编程
2014/12/04 NodeJs
Node.js+Express配置入门教程详解
2016/05/19 Javascript
JavaScript之WebSocket技术详解
2016/11/18 Javascript
Bootstrap3 多选和单选框(checkbox)
2016/12/29 Javascript
利用vue.js插入dom节点的方法
2017/03/15 Javascript
详谈js模块化规范
2017/07/07 Javascript
JS Testing Properties 判断属性是否在对象里的方法
2017/10/01 Javascript
打造通用的匀速运动框架(实例讲解)
2017/10/17 Javascript
Angular中sweetalert弹框的基本使用教程
2018/07/22 Javascript
JS实现倒序输出的几种常用方法示例
2019/04/13 Javascript
Vue 无限滚动加载指令实现方法
2019/05/28 Javascript
vue基础知识--axios合并请求和slot
2020/06/04 Javascript
web.py在模板中输出美元符号的方法
2014/08/26 Python
如何使用七牛Python SDK写一个同步脚本及使用教程
2015/08/23 Python
Python3.7中安装openCV库的方法
2018/07/11 Python
numpy实现神经网络反向传播算法的步骤
2019/12/24 Python
python pymysql链接数据库查询结果转为Dataframe实例
2020/06/05 Python
python有几个版本
2020/06/17 Python
关于css中margin的值和垂直外边距重叠问题
2020/10/27 HTML / CSS
巴西最大的在线约会网站:ParPerfeito
2018/07/11 全球购物
幼儿园教师培训方案
2014/02/04 职场文书
《草原》教学反思
2014/02/15 职场文书
和领导吃饭祝酒词
2015/08/11 职场文书
简历中的自我评价应该这样写!
2019/07/12 职场文书
《中国古代诗歌散文欣赏》高中语文教材
2019/08/20 职场文书
MySQL入门命令之函数-单行函数-流程控制函数
2021/04/05 MySQL