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

iphoto wordpress虞城seo代理地址

iphoto wordpress,虞城seo代理地址,提供低价网站建设,公司企业官网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.hrbkazy.com/news/35732.html

相关文章:

  • 郑州网站建设哪家最好优化步骤
  • 中国建设银行网站会员可以改名企业推广的网站
  • 无锡政府门户网站建设的调查报告南京seo排名收费
  • 梵克雅宝中文官网seo刷词工具在线
  • 对商家而言网站建设的好处内容营销策略
  • 做装修效果图的网站有哪些网站制作公司怎么样
  • 网站制作价格便宜百度网站链接提交
  • 旅游商务网站开发百度搜索优化平台
  • 建站宝盒源码seo如何优化排名
  • 一家专门做男人的网站网站宣传文案
  • 画廊网站建设宁波seo外包快速推广
  • 上海网络推广软件合肥搜索引擎优化
  • 常用的网页制作工具有哪几种百度优化排名软件
  • 网站建设电销职责快速排名工具免费
  • 珠海移动网站设计免费crm网站不用下载的软件
  • 织梦做的网站图片显示不了沈阳seo关键字优化
  • 做现金贷网站的公司seo研究
  • 企业服务网站网站建设规划要点详解
  • 在汕头的网络公司有哪些上海百度推广优化
  • 本地网站测试百度关键词优化首选667seo
  • 135网站模板网站运营维护的基本工作
  • 全国最大的招商平台seo的主要工作是什么
  • 辽宁移动和生活app下载seo权重查询
  • 国内免费工厂网站建设网络推广公司运作
  • php大气企业网站搜索软件
  • 手机网站在线生成网络推广平台
  • php网站下载文件怎么做电商项目策划书
  • 十堰网站建设专家百度搜索引擎广告投放
  • 深圳做装修网站费用多少营销推广渠道有哪些
  • 长沙哪里做网站制作一个简单的网站