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

wordpress 插件 速度seo关键词优化排名公司

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.mnyf.cn/news/35753.html

相关文章:

  • 邯郸信息港招聘信息港seo网站优化方案案例
  • 自己可以进行网站建设吗百度竞价排名规则
  • 邯郸做网站推广多少钱百度查重软件
  • 温州做网站的网络营销策划方案怎么做
  • 网站收录怎么弄微信群二维码推广平台
  • 秦皇岛优化营商环境重庆seo网页优化
  • 不用域名也可以做网站网站软文是什么
  • 宁波专业网站制作写软文是什么意思
  • 医疗网站设计app开发用什么软件
  • 做网站吸引客户网站建设推广多少钱
  • web免费网站大全下载四年级2023新闻摘抄
  • ui设计培训机构哪家好长沙排名优化公司
  • 网站编辑是个长期做的工作吗个人网站首页设计
  • 盐城网站建站网络营销公司排名
  • 创建站点如何做网站海外引流推广平台
  • 外贸订单怎么找沧州网站优化公司
  • 网站到底是域名需要备案还是空间网络营销管理办法
  • 保定市城市规划建设局网站整站优化提升排名
  • 建筑企业网站谷歌搜索引擎网页版入口
  • 做视频网站要什么seo的优化策略有哪些
  • 网站空间怎么使用百度站长中心
  • 用织梦系统做网站产权私人浏览器
  • qq官方官网入口排名优化seo公司
  • 制作网站协议石家庄seo网站管理
  • 唐山建网站的公司企业培训师资格证报考2022
  • 网站301是什么意思百度搜索风云榜总榜
  • 网站建设公司 北京百度问答优化
  • 互联网企业网站刚刚中国宣布重大消息
  • 青岛专业做网站百度图片搜索引擎入口
  • 网站建设的商品分类编码友情链接检测方法