Vue 3中创建一个挂载在this上的loading

今天翻遍全网也没有找到Vue3中一个类似Vue2中挂载在原型链上的$massage这样的文章, 然后我突然想到Ant Design of Vue组件库支持vue3.0, 这样就开始了漫长且痛苦的翻源码之路

github中找到了如下几个文件


从头来说我希望的是一个调用方式为this.$loading()的loading组件
我第一想到的是一个类似message的写法
使用vue2的方式没有成功运行起来, 我想到了去找组件库, 也就是antd of vue 2.0.0 beta版本
首先找到入口函数, 看挂载方式
在这里插入图片描述
这一块是我们想要的

然后去上面找引用关系,也就是message和Modal.info的引用
奈何水平有限, 真看不懂message的代码, 于是挑了Modal.info的实现方式来实现


直接跳转到这里
这个文件不长,慢慢从上面往下看, 定义了close,update,destroyrender方法
render中的代码怎么这么熟悉, 这不就是cli创建出来的main.js中的代码或者文档中起步的实例代码吗
在这里插入图片描述
好的, 我们接下来捋一下思路
在2.x中的实现方式为:

  1. 使用vue.extend实例化对象
  2. 将实例化的对象插入到body中

在3.x中无非就是将extend换为creatApp

直接上代码

// loading.vue
<template>
	<teleport v-if="show" to="body">
		<div class="loading">
			loding...
		</div>
	</teleport>

</template>

<script>
    export default {
        name: "d-loading",
		    props:["parentdom"],
        data() {
            return {
                show: false
            }
        },
        methods: {
            init() {
                this.show = true;
                return this
            },
            hidden() {
                this.show = false;
                // 删除父元素
                this.parentdom.parentElement.removeChild(this.parentdom);
            }
        }
    }
</script>

<style scoped lang="scss">
	.loading {
		width: 100%;
		height: 100%;
		position: fixed;
		top: 0;
		right: 0;
		background: #fff;
		text-align: center;
		z-index: 9999;
	}
</style>
//loading.js loading组件的注册文件
import loading from "./d-loading"
import {createApp} from "vue"
function loading() {
  // 创建一个div包裹loading元素
  let div = document.createElement("div")
  // 将创建好的div插入到body中
  document.querySelector("body").appendChild(div);
  // 在创建好的div中重新实例化一个vue实例
  let loadingEl = createApp(loading, {parentdom: div})
  // 保存loading对象
  let loadingVm = loadingEl.mount(div)
  // 显示loading
  loadingVm.init();
  return () => {
  	  // 销毁实例
      loadingEl.unmount(div)
      // 销毁loading
      loadingVm.hidden();
  };
}

export default {
  install: (app) => {
    // 挂载到this.$loading中
    app.config.globalProperties.$loading = loading
  }
}
// main.js
import loading from "./components/loading";

createApp(App)
	.use(store)
	.use(router)
	.use(loading)
	.mount('#app')
//调用方式
showLoading(){
  console.log(this.$loading)
  let l = this.$loading()

  setTimeout(()=>{
      l()
  },5000)
}
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js 3,使用`this.$loading`来调用loading组件的方式已经不再适用。Vue.js 3的组件的调用方式有所改变。您可以使用`ref`来创建一个loading组件的引用,并通过`show()`和`hide()`方法来显示和隐藏loading组件。 下面是一个示例代码: 1. 首先,在组件引入`ref`和`defineComponent`函数: ```javascript import { ref, defineComponent } from 'vue'; ``` 2. 在组件内部使用`ref`来创建一个loading组件的引用: ```javascript export default defineComponent({ setup() { const loading = ref(null); // ... return { loading, // ... }; }, }); ``` 3. 在模板使用`v-if`来根据`loading`的值来显示或隐藏loading组件: ```html <template> <div> <YourComponent /> <loading-component v-if="loading" /> </div> </template> ``` 4. 在需要显示loading的地方,使用`loading.value = true`来显示loading组件,使用`loading.value = false`来隐藏loading组件。 ```javascript loading.value = true; // 显示loading组件 // 在异步操作完成后隐藏loading组件 setTimeout(() => { loading.value = false; // 隐藏loading组件 }, 2000); ``` 通过以上的步骤,您可以在Vue.js 3实现类似于`this.$loading`的功能。请注意,确保您已经正确引入了loading组件,并将其添加到了组件的模板。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue 3创建一个挂载在this上的loading](https://blog.csdn.net/Lidppp/article/details/108913801)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vue3.x全局$toast、$message、$loading等js插件](https://blog.csdn.net/qq_25674791/article/details/120896392)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值