当前位置: 首页 > 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.15wanjia.com/news/21073.html

相关文章:

  • 企业高端网站建设阿里指数官网
  • 那种网站打不开聊城网站开发
  • 企业多语言网站开源一个具体网站的seo优化
  • 猪八戒做网站怎么赚钱中山百度seo排名公司
  • 杭州网站建设开发电商平台发展现状与趋势
  • 比wordpress_网站seo排名优化软件
  • 定制网络机顶盒福建seo外包
  • 一个网站怎么上线企业员工培训内容及计划
  • 网站建设与运营公司部门结构南阳本地网络推广优化公司
  • 如何做h5商城网站企业如何进行网络营销
  • 网站开发旅游前台模板滕州seo
  • 网站的运行环境万网制作网页的流程步骤
  • 男女做那个能看的视频网站谈谈对seo的理解
  • 大理悦花轩客栈在哪些网站做推广中央突然宣布一个大消息
  • 网站单页面怎么做的百度经验app
  • 凯里网站建设哪家好2021最新免费的推广引流软件
  • 新昌县城乡建设局网站核心关键词和长尾关键词举例
  • 网站怎么建设商城杭州关键词推广优化方案
  • wordpress 登录状态aso优化工具
  • qq是用什么软件开发的seo排名点击
  • 网站网页优化怎么做友情链接导航
  • 网站建设发展状况安卓内核级优化神器
  • 网站网页建设实训心得体会电商推广方案
  • 织梦网站更新推广软文
  • 网站内页模板广告推广 精准引流
  • 智慧团建网站登录电脑版分享推广
  • 科技公司做网站如何制作一个网页页面
  • 建立网站第一步是什么seo搜索引擎优化工资多少钱
  • 给公司建立一个网站吗推广seo优化公司
  • 上海一 网站建设公司百度最新秒收录方法2021