首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在vue3中侦听父组件中的事件

如何在vue3中侦听父组件中的事件
EN

Stack Overflow用户
提问于 2020-12-24 05:56:24
回答 1查看 4.8K关注 0票数 2

我想将事件从子注释传递给父级。我在vue2中也做了同样的事情,但我不知道如何在vue3中做到这一点。

这是子组件设置方法。

代码语言:javascript
运行
复制
      setup(props, { emit }) {
            const router = useRouter();
            const form = ref(
                {
                    email: "ajay@gmail.com",
                    password: "123456789",
                    isLoading: false,
                },
            );
            const user = ref("");
            const error = ref("");

            function login() {
                User.login(this.form).then(() => {
                    emit('login', true);
                   // this.$root.$emit("login", true);  -- vue2

                   localStorage.setItem("auth", "true");
                   router.push('/dashboard');
                })
                .catch(error => {});
            }

            return { form, login, user, error};
       }

从这里发出登录方法,我希望在父注释中侦听。

这是父组件,emit.on方法不在这里工作。

代码语言:javascript
运行
复制
  setup(props, { emit }) {
        const router = useRouter();
        const state = reactive({
            isLoggedIn: false,
        });

        onMounted(async () => {
            emit.on("login", () => {   // `vue2` this.$root.$on("login"`
                this.isLoggedIn = true;
            });
          
        });
EN

回答 1

Stack Overflow用户

发布于 2020-12-24 07:49:34

在父组件中,应该为发出的事件添加一个处理程序:

代码语言:javascript
运行
复制
<child @login="onLogin"></child>
代码语言:javascript
运行
复制
 setup(props, { emit }) {
        const router = useRouter();
        const state = reactive({
            isLoggedIn: false,
        });
 
   function onLogin(){
      state.isLoggedIn=true,
    }

   return{state,onLogin}

} 

或者在单独的文件中创建一个名为useAuth的可组合函数:

代码语言:javascript
运行
复制
import {reactive} from 'vue'

   const state = reactive({
            isLoggedIn: false,
        });
const useAuth=()=>{
  
   function onLogin(){
         state.isLogged=true;
    }
return {state,onLogin}
}

export default useAuth();

然后导入两个组件中的函数:

儿童:

代码语言:javascript
运行
复制
import useAuth from './useAuth'
....
      setup(props, { emit }) {
            const router = useRouter();
             const {useAuth} =useAuth();
         ....
      function login() {
                User.login(this.form).then(() => {
                    onLogin() //will call the nested function that set loggedIn to true
                

                   localStorage.setItem("auth", "true");
                   router.push('/dashboard');
                })
                .catch(error => {});
            }

在父母中:

代码语言:javascript
运行
复制
import useAuth from './useAuth'
....
  setup(props, { emit }) {
        const router = useRouter();
       const {state} =useAuth();
       //it replaces your local state 
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65434526

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档