iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue中定义的data为什么是函数
  • 593
分享到

vue中定义的data为什么是函数

2024-04-02 19:04:59 593人浏览 独家记忆
摘要

目录一、new Vue场景二、组件场景总结高频面试题:vue中的data为啥是函数? 答案是:是不是一定是函数,得看场景。并且,也无需担心什么时候该将data写为函数还是对象,因为v

高频面试题vue中的data为啥是函数?

答案是:是不是一定是函数,得看场景。并且,也无需担心什么时候该将data写为函数还是对象,因为vue内部已经做了处理,并在控制台输出错误信息。

一、new Vue场景

new Vue({
  el: "#app",
  // 方式一:对象
  data: {
    obj: {
      name: "qb",
    }
  },
  // 方式二:工厂函数
  // data () {
  //   return {
  //     obj: {
  //       name: "qb",
  //     }
  //   }
  // },
  template: `<div>{{obj.name}}</div>`
});

这种场景主要为项目入口或者多个html页面各实例化一个Vue时,这里的data即可用对象的形式,也可用工厂函数返回对象的形式。因为,这里的data只会出现一次,不存在重复引用而引起的数据污染问题。

二、组件场景

Vue.component("countComponent", {
  data() {
    return {
      count: 1
    };
  },
  template: `<div>
    <button @click='changeCount'>递增</button>
    <span>{{count}}</span>
  </div>`,
  methods: {
    changeCount() {
      this.count++;
    }
  }
});

new Vue({
  el: "#app",
  template: `<div>
    <countComponent></countComponent>
    <countComponent></countComponent>
  </div>`
});

首先定义全局组件countComponent,然后将该组件重复使用两次,当定义全局组件的时候,会执行Vuecomponent方法:

// ASSET_TYPES定义在文件shared/constants.js文件中
export const ASSET_TYPES = [
  'component',
  'directive',
  'filter'
]

// 以下ASSET_TYPES遍历绑定方法的定义在initGlobalapi(Vue)全局方法挂载阶段完成
import { ASSET_TYPES } from 'shared/constants'
import { isPlainObject, validateComponentName } from '../util/index'
export function initAssetReGISters (Vue: GlobalAPI) {
  
  ASSET_TYPES.forEach(type => {
    Vue[type] = function (
      id: string,
      definition: Function | Object
    ): Function | Object | void {
      if (!definition) {
        return this.options[type + 's'][id]
      } else {
        
        if (process.env.node_ENV !== 'production' && type === 'component') {
          validateComponentName(id)
        }
        if (type === 'component' && isPlainObject(definition)) {
          definition.name = definition.name || id
          definition = this.options._base.extend(definition)
        }
        if (type === 'directive' && typeof definition === 'function') {
          definition = { bind: definition, update: definition }
        }
        this.options[type + 's'][id] = definition
        return definition
      }
    }
  })
}

这里的场景是component,那么会执行到definition = this.options._base.extend(definition)进行组件构造函数的实现,这里的this.options._base就是构造函数Vueextend方法为:

//  Vue.extend 方法的定义在initGlobalAPI(Vue)全局方法挂载阶段完成
export function initExtend (Vue: GlobalAPI) {
  Vue.extend = function (extendOptions: Object): Function {
    extendOptions = extendOptions || {}
    const Super = this
    const SuperId = Super.cid
    const cachedCtors = extendOptions._Ctor || (extendOptions._Ctor = {})
    if (cachedCtors[SuperId]) {
      return cachedCtors[SuperId]
    }

    const name = extendOptions.name || Super.options.name
    if (process.env.NODE_ENV !== 'production' && name) {
      validateComponentName(name)
    }

    const Sub = function VueComponent (options) {
      this._init(options)
    }
    Sub.prototype = Object.create(Super.prototype)
    Sub.prototype.constructor = Sub
    Sub.cid = cid++
    Sub.options = mergeOptions(
      Super.options,
      extendOptions
    )
    // ...
  }
}

定义完组件构造函数Sub后,在为其合并options时,会执行到mergeOptions


export function mergeOptions (
  parent: Object,
  child: Object,
  vm?: Component
): Object {
  // ...
  const options = {}
  let key
  for (key in parent) {
    mergeField(key)
  }
  for (key in child) {
    if (!hasOwn(parent, key)) {
      mergeField(key)
    }
  }
  function mergeField (key) {
    const strat = strats[key] || defaultStrat
    options[key] = strat(parent[key], child[key], vm, key)
  }
  return options
}

在当前例子中,会通过const options = {}定义一个空对象,然后分别将parentchild上的属性合并到options上,此时data的合并策略为:

strats.data = function (
  parentVal,
  childVal,
  vm
) {
  if (!vm) {
    if (childVal && typeof childVal !== 'function') {
      process.env.NODE_ENV !== 'production' && warn(
        'The "data" option should be a function ' +
        'that returns a per-instance value in component ' +
        'definitions.',
        vm
      );

      return parentVal
    }
    return mergeDataOrFn(parentVal, childVal)
  }

  return mergeDataOrFn(parentVal, childVal, vm)
};

这里childVal类型为object,即typeof childVal !== 'function'成立,进而在开发环境会在控制台输出警告并且直接返回parentVal,说明这里压根就没有把childVal中的任何data信息合并到options中去。

总结

vue中已经帮我们控制台输出警告,并且不会让组件中的data合并到options中去,那么,很友好的处理了开发者的强行将data写成对象的可能性。

到此这篇关于vue中定义的data为什么是函数的文章就介绍到这了,更多相关vue中data为什么是函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue中定义的data为什么是函数

本文链接: https://www.lsjlt.com/news/167011.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue中定义的data为什么是函数
    目录一、new Vue场景二、组件场景总结高频面试题:vue中的data为啥是函数? 答案是:是不是一定是函数,得看场景。并且,也无需担心什么时候该将data写为函数还是对象,因为v...
    99+
    2024-04-02
  • vue中的data为什么是函数
    小编给大家分享一下vue中的data为什么是函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!vue 中的data 为什么是函数...
    99+
    2024-04-02
  • vue中data为什么必须是函数
    这是因为JavaScript的特性所导致,跟vue本身设计无关,js本身的面向对象编程也是基于原型链和构造函数,而在原型链上添加一般都是一个函数方法并不是添加一个对象,因此在component中,data必须以函数的形式存在,不可以是对象。...
    99+
    2024-04-02
  • vue组件中data为什么是函数
    这篇文章主要介绍“vue组件中data为什么是函数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue组件中data为什么是函数”文章能帮助大家解决问题。原因:防止多个组件实例对象之间共用一个dat...
    99+
    2023-07-04
  • vue组件中data为什么是一个函数
    这篇文章给大家分享的是有关vue组件中data为什么是一个函数的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。组件中 data 为什么是一个函数?为什么组件中的 data 必须是一...
    99+
    2024-04-02
  • vue组件中data为啥是函数
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。一、实例和组件定义data的区别vue实例的时候定义data属性既可以是一个对象,也可以是一个函数const app = new Vue({ el:"#...
    99+
    2023-05-14
    vue3 Vue
  • 你知道vue data为什么是一个函数
    官网解释:当一个组件被定义,data 必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例。如果 data 仍然是一个纯粹的对象,则所有的实例将共享引用同一个数据对象...
    99+
    2024-04-02
  • python中函数的定义方法是什么
    在Python中,函数的定义方法如下:```pythondef function_name(parameters):# 函数体# 可...
    99+
    2023-09-13
    python
  • javascript中定义函数的代码是什么
    这篇文章主要介绍“javascript中定义函数的代码是什么”,在日常操作中,相信很多人在javascript中定义函数的代码是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2024-04-02
  • javascript的自定义函数是什么
    这篇文章主要讲解了“javascript的自定义函数是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript的自定义函数是什么”吧! ...
    99+
    2024-04-02
  • vue组件中data属性定义有什么要求
    在vue组件中定义data属性的要求:在vue组件中,需要将data作为一个函数名、数据对象作为函数返回值来使用,在创建新实例后,可以通过调用data函数,返回初始数据的一个全新副本数据对象。具体分析如下:vue中data属性的作用是用于以...
    99+
    2024-04-02
  • php中定义函数的关键字是什么
    用于定义 php 函数的关键字是 "function"。它遵循的语法结构为:function function_name(parameter_list) { // 函数体 },其中 fu...
    99+
    2024-04-26
  • php中常用的定义数组的函数是什么
    在 php 中,定义数组的两种常用函数是:array() 函数:生成一个索引数组,键为数字。[] 短语法:生成一个索引数组,键从 0 开始按顺序排列。 php中定义数组的常用函数 在P...
    99+
    2024-04-27
  • Vue的data为啥只能是函数原理详解
    目录前言1.Vue3中的data2.vue中的data3.证明data是函数以及原理实现4.如果data必须是一个对象呢?前言 在学习vue的时候vue2只有在组件中严格要求data...
    99+
    2022-11-13
    Vue data 函数原理 Vue data
  • C++ 静态函数的定义是什么?
    静态函数是类中不属于任何对象的独立函数,用于封装类级操作和全局访问。它们的特点包括:1. 不依赖于对象;2. 全局可见性;3. 不可继承和重写。静态函数可用于优化性能和简化对类级功能的访...
    99+
    2024-04-16
    c++ 静态函数
  • python语言中定义函数的规则是什么
    在Python语言中,定义函数的规则如下:1. 使用关键字`def`来定义函数,后面跟着函数名和参数列表,参数列表用括号括起来。2....
    99+
    2023-08-30
    python
  • vue中为什么在组件内部data是一个函数而不是一个对象
    目录实例和组件中 data 的区别?组件中 data 定义对象和函数区别?如果采用函数的写法?总结扩展vue 组件data用箭头函数行不行?组件中 data 定义...
    99+
    2023-05-17
    vue中data为什么是函数而不是对象 vue中data是函数而不是对象
  • c语言中函数的定义方法是什么
    在C语言中,函数的定义通常包含以下几个部分:1. 返回类型:函数可以有不同的返回类型,如int、float、void等,用来表示函数...
    99+
    2023-09-29
    c语言
  • Linq中用户定义函数的原理是什么
    Linq中用户定义函数的原理是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Linq用户定义函数我们可以在LINQ to SQL中使用Linq用户定义函数。只要把Lin...
    99+
    2023-06-17
  • Vue怎么自定义hook函数
    这篇文章主要介绍“Vue怎么自定义hook函数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue怎么自定义hook函数”文章能帮助大家解决问题。定义什么是hook本质是一个函数,把 setup 函...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作