作用域控制可以使用哪些变量以及在何处使用。它控制它们对应用程序的不同部分的“可见性”。了解 Vue 提供的作用域级别之间的差异会帮助我们编写更清晰的代码。

下面是 vue 中4个级别的作用域:

  • 全局作用域
  • 子树作用域
  • 组件作用域
  • 实例作用域

全局作用域

Vue 应用程序中的全局作用域与任何编程语言中的全局作用域类似,这些变量在应用程序中的任何地方都是可用的。

可以把全局作用域看作应用程序作用域,因为它将作用域限制为整个应用程序。使用全局作用域

使用全局作用域的主要方式是向Vue原型添加一个值:

Vue.prototype.$globalValue = 'Global Scope!';

通过将其添加到 Vue 对象的原型中,可以在应用程序的每个组件上自动使用它。可以像这样直接从组件访问它:

export default {  mounted() {    console.log(this.$globalValue);  // 'Global Scope!'  },};

使用$作为这些变量的前缀是一种标准做法,因此我们知道它们是全局值,而不是每个组件唯一的。

Vue、vue-router和vuex(以及许多其他库)都使用这种技术来定义全局值。例如,来自vue-router的$route对象是这样一个全局作用域的变量。

子树作用域

大多数时候,全局范围有点像大锤,我们需要一些更精确的东西。子树作用域中的变量作用域是应用程序的特定部分,而不是整个应用程序。

此级别的作用域可能是最少使用的,但是在确实需要使用时非常方便。 通常,一组组件需要共享很多相同的数据,并且通过props传递数据非常繁琐。

此作用域最适合用于共享上下文信息,这些上下文信息可以根据组件在应用程序中的位置进行更改,可以是这样的:

  • 本地状态和数据-如果只有一小部分应用程序需要使用 Vuex,则无需使用 Vuex。 如果使用props传递会变得繁琐且麻烦,此时,子树作用域可能是我们最好的选择。
  • 配置-有时我们需要组件以某种特定方式运行,但仅在应用程序的一部分中运行。 例如,注册表单中的所有Input组件都需要验证,但是我们不想在整个应用程序中都要求验证。使用子树作用域

子树作用域是通过使用provide和inject创建的。 我们提供希望可用于整个子树的值,然后将它们注入需要它们的组件中。

组件作用域

更具体一点,组件作用域使变量可用于单个组件。但是这不应该与更具体的实例作用域相混淆。

如果一个变量具有组件作用域,那么它就是一个组件的所有实例都可以使用的单个变量。我们可以拥有几个相同的组件,并且它们都能够访问相同的变量。

你可能熟悉 JS 中的模块作用域。在单个模块或文件中定义的任何内容都属于相同的模块作用域。由于组件是在单个文件中定义的,所以组件中的所有内容都在相同的模块作用域内。

使用组件作用域

要使用组件作用域,我们需要在与组件相同的文件中定义一个变量:

{{ componentScope }}

在此组件中渲染的变量componentScope是相同的变量,不管使用此组件多少次,componentScope 始终只有一个,没有多个副本。

如果此组件的一个实例修改了componentScope的值,则该组件的每个其他实例都会更改。 不应使用这种方式在组件之间进行通信,但这是共享数据的一种好方法。

实例作用域

实例作用域是我们可以获得的Vue作用域变量最常见形式,具有实例作用域的任何变量仅可用于组件的特定用法。 我们通常将其称为内部状态,有时也称为局部状态。

使用实例作用域

无论何时使用data()函数或使用computed props,都是在使用实例作用域。

甚至直接向组件实例添加属性也可以达到以下效果:

someMethod() {  this.newProperty = 'Instance scope';}

但是,如果以这种方式添加属性,则必须记住,它们不是响应式的。

想了解更多前端资讯及前端知识欢迎关注公众号“一郭鲜”,学习前端不迷路

中provide的用法_Vue中那些你不知道的作用域相关推荐

  1. vue 中provide的用法_Vue中使用provide和inject

    相信大家在工作中一定遇到过多层嵌套组件,而vue 的组件数据通信方式又有很多种. 比如vuex.$parent与$children.prop.$emit与$on.$attrs与$lisenters.e ...

  2. vue 中provide的用法_vue中provide和inject使用

    1.provide/inject有什么用? 常用的父子组件通信方式都是父组件绑定要传递给子组件的数据,子组件通过props属性接收,一旦组件层级变多时,采用这种方式一级一级传递值非常麻烦,而且代码可读 ...

  3. vue 中provide的用法_vue 中的 provide 和 inject 用法

    provider/inject:简单来说就是在父组件 provide 中提供变量,子组件 inject 中来注入,然后可以在子组件内部使用 provide 的变量 需要注意的是这里不论子组件有多深,只 ...

  4. vue 中provide的用法_vue中provide和inject的用法

    2.2.0 新增 描述: provide 和 inject 主要为高阶插件/组件库提供用例.并不推荐直接用于应用程序代码中; 并且这对选项需要一起使用; 以允许一个祖先组件向其所有子孙后代注入一个依赖 ...

  5. vue 中provide的用法_vue中的provide和inject

    阅读element-ui源码,发现在设计子组时件用到了inject属性,随即查了一下官方文档,得知vue在2.2.0版本里新增了provide / inject: provide 和 inject 主 ...

  6. vue 中provide的用法_Vue多级组件provide/inject使用详解

    这次给大家带来Vue多级组件provide/inject使用详解,Vue多级组件provide/inject使用的注意事项有哪些,下面就是实战案例,一起来看一下. provide / inject 是 ...

  7. vue 中provide的用法_vue高阶用法之provide与inject

    1.这个两个必须同时使用,当父组件定义的方法,子组件也想使用怎么办了,这时候就可以派上用场了 provide:Object | () => Object inject:Array | { [ke ...

  8. vue中this.init用法_Vue中的this.$options.data()和this.$data用法说明

    问题 项目里遇到一个问题,用this.$options.data()重置组件data时,data()里用this获取的props或method都为undefined,代码简化如下: export de ...

  9. python中change的用法_vue中select的使用、默认选择、onchange/change事件等操作实例

    Select选择框极其值获取,默认选择 编程语言: {{language.desc}} var app = new Vue({ el: "#app", data: { langua ...

最新文章

  1. 《强化学习周刊》第26期:UCL UC Berkeley发表深度强化学习中的泛化研究综述、JHU推出基于强化学习的人工决策模型...
  2. LLBLGen 关于类型转换
  3. java web截屏_java_WebDriver中实现对特定的Web区域截图方法,用过 WebDriver 的同学都知道,We - phpStudy...
  4. 华为云大数据轻模式体验:忘掉底层烦恼,专注数据开发
  5. 算法笔记_面试题_21.数据结构相关_模板及示例十几道
  6. HP 打印机驱动安装报错Return code: 1603解决办法
  7. 人工智能+建筑,会产生什么?
  8. python检查验证_Python:在时间、日期之间进行检查。验证日期
  9. android抽屉式listview,Android 抽屉效果的导航菜单实现
  10. Android常用设置
  11. 产品读书《游戏改变世界:游戏化如何让现实变得更美好》
  12. 基于微信小程序的充电桩预约管理系统的设计与实现(论文+源码)_kaic
  13. 石膏板建筑材料英国UKCA认证—EN 520
  14. 章鱼输入法 v4.5.7.3
  15. android 语音提醒,文字转语音播放
  16. DirectPlay SDK中文翻译
  17. 063 邪恶八进制域名收集
  18. 简述计算机地图制图的主要阶段,计算机地图制图原理、特点及发展趋势
  19. 生于七十年代的尴尬[转]
  20. Python 角色对战小游戏

热门文章

  1. java 方法 示例_Java语言环境getISOCountries()方法与示例
  2. kotlin 查找id_Kotlin程序查找平行四边形的区域
  3. JAVA语言异常,Java语言中的异常
  4. 自定义taglib引入失败_小程序拼团总失败?看看微信官方和开发者们怎么说
  5. java中的de是什么_【转】java中main函数解析
  6. 软件测试项目计划书总结,软件测试项目计划书.doc
  7. Java ClassLoader findClass()方法与示例
  8. 登陆 tomcat manager
  9. C语言小项目(画机器猫)
  10. 用委托来实现IEqualityComparer接口