当前位置: 首页 > news >正文

什么叫网站根目录互联网培训机构排名前十

什么叫网站根目录,互联网培训机构排名前十,青海省网站建设哪家公司比较靠谱,做一钓鱼网站吗vue3注册全局属性方法 前言一、app.config.globalProperties1 注册实例2 注册方法 二、依赖注入(Provide / Inject)1 注册实例2 注册方法3 一次性多次传入 最后 前言 在使用 Vue 时,多个地方使用同一个方法导致每个地方都需要按需引用&#…

vue3注册全局属性方法

  • 前言
  • 一、app.config.globalProperties
    • 1 注册实例
    • 2 注册方法
  • 二、依赖注入(Provide / Inject)
    • 1 注册实例
    • 2 注册方法
    • 3 一次性多次传入
  • 最后

前言

在使用 Vue 时,多个地方使用同一个方法导致每个地方都需要按需引用,从而增加代码量。然而,这种做法实际上有助于减少冗余、提高一致性,并且是代码重用、抽象或模块化的体现。这种方法提高了代码的维护性、可读性和一致性。

注:
自动导入Vue Composition API 函数(如 ref, reactive, computed 等)可以使用插件 unplugin-auto-import
组件全局注册可以参考官网vue3组件全局注册,或者使用插件unplugin-vue-components

一、app.config.globalProperties

一个用于注册能够被应用内所有组件实例访问到的全局属性的对象。

1 注册实例

main.js 中引入全局要使用的实例,通过 app.config.globalProperties 添加到全局中

//main.js文件
const app = createApp(App)
app.config.globalProperties.$Text = '111'
//使用的组件
<script setup>
import { getCurrentInstance } from 'vue'   const { proxy } = getCurrentInstance()
console.log(proxy.$Text);  //111 </script>

2 注册方法

同理也是可以注册方法的
这里写了个防抖函数,关于防抖函数可以参考这里Vue中使用防抖和节流

//main.js文件
import { debounce } from "./util"
const app = createApp(App)
app.config.globalProperties.$Debounce = debounce
//使用的组件
<template><button @click="clickeMe">点击我</button>
</template>
<script setup>
import { getCurrentInstance } from 'vue'
const { proxy } = getCurrentInstance()
const Debounce = proxy.$Debounce 
const clickeMe = Debounce(async () => {console.log("await我被点击了");//这里写需要的代码
}, 1000);
</script>

参考官网:app.config.globalProperties

二、依赖注入(Provide / Inject)

提供一个值,可以被后代组件注入。
在这里插入图片描述

1 注册实例

<script setup>
//APP.vue 
import {provide} from 'vue'
provide('text', '111')
</script>
//使用的组件
<script setup>
import { inject } from 'vue'const text = inject('text')
console.log(text); //111
</script>

2 注册方法

这里一样的用防抖来举例

<script setup>
//APP.vue 
import {provide} from 'vue'
import { debounce } from "./util"
provide('debounce', debounce)
</script>
//使用的组件
<script setup>
<template><button @click="clickeMe">点击我</button>
</template><script setup>
import { inject } from 'vue'
const debounce = inject('debounce')
const clickeMe = debounce(async () => {console.log("await我被点击了");//这里写需要的代码
}, 1000);
</script> 

效果图
请添加图片描述
可以看到多次点击后1s内执行了一次

3 一次性多次传入

在 Vue 3 中,provide 函数本身不支持一次性传递多个值。但可以通过将多个值包装在一个对象中,来实现类似的效果。这样可以通过单个 provide 调用传递多个参数。
代码示例:

//APP.vue 
import { debounce } from "./util"
const values = {text: '111',debounce: debounce
};
provide('values', values)
//使用的组件
<template><button @click="clickeMe">点击我</button>
</template><script setup>
import { inject } from 'vue'const values = inject('values')
const { debounce, text } = values
const clickeMe = debounce(async () => {console.log("await我被点击了"); //这里写需要的代码
}, 1000);
console.log(text); //111
</script>

参考Vue3官网:组合式 API:依赖注入

最后

参考文档:Vue3 MaskerFan 博客园

http://www.tj-hxxt.cn/news/51266.html

相关文章:

  • 海门住房和城乡建设局网站大数据培训课程
  • 什么网站做网页好交换链接的方法
  • 在线做家装设计的网站百度竞价ocpc投放策略
  • 浩子文wordpressseo优化排名软件
  • 阿里巴巴网站图片怎么做事件营销
  • 郑州网站建设直播在线crm
  • 青岛市北区网站制作公司市场调研的基本流程
  • laravel 网站开发网上店铺的推广方法有哪些
  • 宁波市节约型机关建设考试网站怎么在百度上发表文章
  • 宁波做网站建设推广百度推广账号注册
  • 做板子焊接的网站的公司名字百度账号安全中心
  • 政务内网网站建设方案兰州网站优化
  • 网站建设营销推广工作互联网推广渠道
  • 域客士单页网站网络广告策划案
  • 小影wordpress主题网络seo公司
  • php和java哪个做网站浩本周时事新闻概要10条
  • 网站建设费用报告推广网上国网
  • 北京网站开发哪家强刷神马关键字排名软件
  • 天津网站建设工具傻瓜式自助建站系统
  • 打电话说帮忙做网站刚刚北京传来重大消息
  • 沧州做网站的seo技术有哪些
  • 专门做网站的公司网站设计制作培训
  • wordpress账号密码都正确登陆不seo
  • 在线做交互网站什么是友情链接?
  • 外贸流程培训小红书seo优化
  • 快速的网站开发广告公司是做什么的
  • 网站建设百度云seo优化的方法
  • 有没有做产品团购的网站百度最怕哪个投诉电话
  • 教做奥数的网站广告公司简介
  • wordpress一百万文章关键词优化价格表