- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
感谢您提供的任何帮助。有谁知道如何使用 Vue.js 中的 $emit 方法将数据上链发送到全局方法?在 Vue.js 的一个非常基本的例子中,我没有遇到任何问题。然而,一旦使用 Vue CLI 设置我的项目,使用更高级的文件夹结构,我的方法似乎没有正确注册。
在我的 Register.vue
组件中,我注册了一个新用户,这样做之后我想将新用户发送到上游以更新我的全局范围:
this.$emit("login-user", newUser);
我的组件注册如下:
<Register msg="Otherwise, go ahead and register here:" :login-user="loginNewUser"/>
其中 :login-user
引用全局方法:loginNewUser()
。
loginNewUser()
方法在 main.js
中设置如下:
new Vue({
router,
store,
render: h => h(App),
methods: {
loginNewUser(user) {
console.log(user);
}
}
}).$mount("#app");
是我的方法用错地方了吗?使用 Vue CLI create
项目层次结构时,如何将数据从我的组件向上发送到我的全局范围?此方法以前有效,但我的应用程序设置略有不同,我可能会忽略一些非常重要的事情。
如果您愿意,可以在以下位置查看此项目的完整存储库:https://github.com/twknab/viaRV_vue_cli_project
在 src/components/Register.vue
中,on line 76是我尝试对 main.js
和 loginNewUser()
方法进行 $emit
调用的地方 on line 17 ,我收到错误消息:
[Vue warn]: Property or method "loginNewUser" is not defined on the instance but referenced during render. Make sure that this property is reactive, either in the data option, or for class-based components, by initializing the property.
非常感谢您花时间阅读。
最佳答案
显示警告是因为 loginNewUser
在 Home
中被引用组件:
<Register msg="Otherwise, go ahead and register here:" @login-user="loginNewUser"/>
然而 loginNewUser
未在 Home
中定义组件,但在你的 main.js
文件,在组件层次结构中向上三层:main.js > App.vue > Home.vue
new Vue({
router,
store,
render: h => h(App),
methods: {
loginNewUser(user) {
// existing code here
}
}
}).$mount("#app");
要解决这个问题,您必须从 main.js
传递事件处理程序给你的Home
包含 3 个步骤的组件。
首先,将事件处理程序传递给App.vue
通过修改你的 render
在 main.js
中发挥作用来自:
render: h => h(App)
为此:
render: function(createElement) {
return createElement(App, {
on: {
loginNewUser: this.loginNewUser
}
})
}
h
is a more generalized version ofcreateElement
so basically, they're the same.
createElement
accepts several arguments and we will use thesecond
argument whichis a data object to passevent
handlers to the rendered component.
其次,在你的App
组件,定义 loginNewUser
并将引用传递给 router-view
.
export default {
name: "App",
methods: {
loginNewUser() {
this.$emit('loginNewUser');
}
}
}
<router-view @login-new-user="loginNewUser"></router-view>
第三,定义loginNewUser
在你的Home.vue
组件。
export default {
name: "home",
components: {
Login,
Register
},
methods: {
loginNewUser() {
this.$emit('loginNewUser');
}
}
};
最后,在您当前的代码中,不要忘记更改 :login-user
至 @login-user
.
如果您使用 Vuex
或者计划,而不是从上到下传递事件处理程序,您可以使用 actions
您可以在组件中的任何位置调用它。
关于javascript - 使用 Vue CLI 项目设置时如何将 $emit 与 Vue.js 一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54111023/
我只是偶然发现了一个似乎广为人知的compsci关键字“emit”。但是我找不到用通用计算机科学术语对其的任何明确定义,也找不到任何特定编程语言中的“emit()”函数或关键字的特定定义。 我在这里找
在 Qt 中,它们都是有效的,并且表现相同: emit someSignal(value); 对比 emit(someSignal(value)); 有什么区别吗? 最佳答案 Is there any
是否可以同步执行并在调用方法本身时返回结果。所以,我想在 $emit 完成后执行下一条语句。其如下: Parent component has method, doC
我是 socket.io 的新手,遇到了一些看起来很奇怪的事情。我实际上不知道 socket.emit 和 io.emit 之间的区别,但我在任何地方都找不到解释。 io.on('connection
有谁知道如何显式实现接口(interface)的属性 使用反射。发射? 最佳答案 有关 TypeBuilder.DefineMethodOverride 的信息,请参阅 MSDN 文档,其中包括使用
我有多个可观察对象进行网络调用,并且仅当所有可观察对象发出错误时,我才需要从组合器可观察对象发出错误。如果至少有一个可观察完成,则应传递结果。 我当前的流功能如下: Observable.fromIt
我想在这里实现的是当 IF 语句为 true 时 fightID 更改为其他值,因此它不会匹配它之前分配的值,因此我无法在战斗结束后立即通过控制台运行 win-fight 发出的消息。但是我现在得到的
当我们需要自定义组件在 VueTable2 中发出事件时,我们必须使用: this.$parent.$emit('myCustomEvent') // instead of this.$emit('m
This is my production webpack config .标题中的两个引号分别指的是 webpack2 和 webpack。两者都因类似的错误而挂起。 这是我触发构建的命令 设置 N
我正在尝试构建一个发布者,它会在其他 5 个发布者中的任何一个发布者发出 true 时发出 true。我已经设法构建了一个工作版本,但感觉非常恶心,使用 CombineLatest4 + Combin
我正在尝试创建用于教育目的的简单 .net 编译器。在解析、扫描和构建 AST 之后,我正在使用 Reflection.Emit.ILGenerator 生成 .net 程序集。 这是我的程序集生成示
以下 node.js 脚本不工作 var EventEmitter = require('events').EventEmitter; var util = require('util'); var
我使用的是Laravel 10,Livewire 2.x,我试图使用Livewire组件中的一个简单函数中的emit或emitTo事件来更新愿望列表计数。。WishlistCount控制器:。当我运行
我收到以下警告: [Vue warn]: Extraneous non-emits event listeners (addData) were passed to component but cou
我不明白 io.emit 和 io.sockets.emit 之间有什么区别。 有时它们的行为相同,但有时它们的行为不同。 最佳答案 socket.emit 仅将消息发送到发送者客户端 io.emit
我刚刚成功地使用 socket.io 连接到一个服务器脚本,所以我很高兴。我对我的脚本生成的奇怪行为不太满意:我在单击按钮时向服务器脚本发送一个发射,然后服务器测试脚本向控制台日志发回一条消息 6x。
这听起来可能有点模糊,但我仍在学习并试图理解它是如何工作的。 我开始使用“侧菜单”启动 ionic 项目,它已经设置了带有“应用程序”抽象状态/ View / Controller 的 urlrout
我遵循了一些 Nodejs 教程并完成了一个简单的 REST Web 服务。此 Web 服务监听/api/accounts 中的电子邮件和密码,然后继续在 Cassandra 集群中进行查找。我使用
我正在尝试建立一种模式,在这种模式下,我的产生某些对象的可观察对象被转换为领域事件,例如围绕可观察对象产生的 Started、Success、Error,如果这有意义的话 public Observa
这个问题已经有答案了: How can I let the javascript catch a signal from node and prompt a window right after th
我是一名优秀的程序员,十分优秀!