吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 691|回复: 16
收起左侧

[求助] Vue3如何获取实例

[复制链接]
cube 发表于 2024-7-12 08:14
本帖最后由 cube 于 2024-7-12 08:30 编辑

当基于Vue的程序发布上线后
通常Vue2可以通过__vue__属性获取实例
而Vue3有什么办法可以通过DOM获取实例么?
诸位大神有什么好的debug建议么?

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
cjcmxc + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

舔指的小飞 发表于 2024-7-12 08:18
这个百度一下答案就出来了,,,
Smartiboy 发表于 2024-7-12 08:19
本帖最后由 Smartiboy 于 2024-7-12 08:24 编辑

vue3中可以通过getCurrentInstance函数来获取当前实例对象,也可以用 ref 获取 DOM 元素或组件实例。
讲一下getCurrentInstance大概的使用方法,如下代码演示:
[JavaScript] 纯文本查看 复制代码
import { getCurrentInstance } from 'vue';
const instance = getCurrentInstance();
// 当前实例
console.log(instance);


至于如何debug,讲道理我一般都是console调试,偶尔会用debugger关键字在想要debug的地方,一般我会在业务逻辑比较复杂的函数里用来查一下代码是否按照预期工作。
 楼主| cube 发表于 2024-7-12 08:26
本帖最后由 cube 于 2024-7-12 08:28 编辑
Smartiboy 发表于 2024-7-12 08:19
vue3中可以通过getCurrentInstance函数来获取当前实例对象,也可以用 ref 获取 DOM 元素或组件实例。
讲一 ...

是我描述的有问题.
不是开发过程中获取实例的方法,是发布之后,有什么手段可以获取当前Element所绑定的实例。
 楼主| cube 发表于 2024-7-12 08:27
舔指的小飞 发表于 2024-7-12 08:18
这个百度一下答案就出来了,,,

好的,方法很好,非常感谢。
Smartiboy 发表于 2024-7-12 08:37
cube 发表于 2024-7-12 08:26
是我描述的有问题.
不是开发过程中获取实例的方法,是发布之后,有什么手段可以获取当前Element所绑定的 ...

这个我就不知道了,等找到方法了也教我一下哈!~
sophieqd 发表于 2024-7-12 08:58
load
window.vue=this

console下,用vue.x

试试看
头像被屏蔽
961705025 发表于 2024-7-12 09:26
提示: 该帖被管理员或版主屏蔽
好听吗 发表于 2024-7-12 10:55
能知道该项目所使用的组件库吗?
yushuai033X 发表于 2024-7-12 11:33
可以使用app.config.globalProperties全局属性来存储应用实例,并在需要获取实例的地方通过DOM元素来获取应用实例。具体步骤如下:
1、在应用初始化时,将应用实例存储在app.config.globalProperties中。
[JavaScript] 纯文本查看 复制代码
const app = createApp(App);
// 存储应用实例在全局属性中
app.config.globalProperties.appInstance = app;


2、在需要获取实例的地方,通过DOM操作来获取元素,然后通过appInstance属性来获取应用实例。
[JavaScript] 纯文本查看 复制代码
const rootElement = document.getElementById('app');
const appInstance = rootElement.appInstance;
console.log(appInstance); // 输出应用实例

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-24 14:07

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表