vue.js - vuejs 有效负载仅发出数组中的第一个元素
问题描述
我使用带有 vuejs 的 dropzone 插件,并且来自 dropzone 的响应是一个数组。有效负载具有参数数组、响应和文件对象。每次我调用@vdropzone-success="$emit('processFunction',$event)
它都会正确地将请求发送到正确的函数,但只返回有效负载数组的第一个元素。为什么?我附上了 vue 调试器的屏幕截图以帮助说明问题。如何访问 processFunction 中的有效负载以获取数组元素 0 和 1?
添加更多上下文。这是库中向我的子组件发出的函数
this.dropzone.on("success", function(file, response) {
vm.$emit("vdropzone-success", file, response);
});
在我的 vue 代码中之后,我将此结果发送到我的索引组件:
<vue-dropzone
id="dropzone"
ref="myVueDropzone"
@vdropzone-drop="$emit('loading')"
@vdropzone-success="$emit('loaded',...$event)"
:use-custom-slot="true"
:options="dropzoneOptions"
>
我在这里绑定到我的 index.vue 上的元素:
<Upload @loading="loading" @loaded="loaded" />
然后调用加载的函数
loaded(e) {
console.log(e);
this.notLoading = true;
this.isLoading = false;
},
https://github.com/vuejs/vue/issues/5527 这看起来像一个类似的问题。每当我调用 $event 它只返回 0 这是文件。我希望它返回 1,这是来自服务(对象)的响应。
解决方案
好的..我觉得应该有更好的方法来做到这一点,但是...看起来我无法通过库->子->父的vue标签直接传递数组变量。相反,我需要在子节点的 js 中将数组拉出,然后在 js 中将其重新发送给父节点。以下解决方案有效。
图书馆:
this.dropzone.on("success", function(file, response) {
vm.$emit("vdropzone-success", file, response); });
孩子(helper.vue):
<!-- file upload -->
<vue-dropzone
id="dropzone"
ref="myVueDropzone"
@vdropzone-drop="$emit('loading')"
@vdropzone-success="processdata"
:use-custom-slot="true"
:options="dropzoneOptions"
>
以及其中的js部分
methods: {
processdata(...ev){
this.$emit("loaded",ev);
},
最后是父级(index.vue)
<Upload @loading="loading" @loaded="loaded" />
以及为此的js
loaded(...e) {
this.storedValue = e;
不是最优雅的解决方案,但它正在工作!
推荐阅读
- drupal-7 - Drupal 7 自定义内容类型显示规则
- tensorflow - Tensorflow JS 模型 - 超参数调优
- java - 在 JAVA 中迭代 HashMap 时出现编译错误
- django - Dajngo-错误字段“id”需要一个数字但得到字符串
- ios - UNCalendarNotificationTrigger 不适用于本地通知
- dialogflow-es - Dialogflow CX 中是否有默认变量将用户输入作为值?
- javascript - 如果单击按钮,则使用选项卡转到列表中的第一个链接
- asp.net-core-mvc - .net core api + jwt 认证 + .net core mvc 客户端
- c++ - 结构化绑定声明的令人困惑的错误
- javascript - 从 AJAX 响应中调用 jQuery