gpt4 book ai didi

javascript - JqxCombo 值不是从 ajax 结果设置的 - Vue.js

转载 作者:行者123 更新时间:2023-11-30 06:20:07 32 4
gpt4 key购买 nike

我一直在尝试将 JqxWidgets 与 Vue.js 一起使用,这里的基本思想是我们可以在表单中有多个 ComboBox 并且只需调用 ComboBox 模板并提供 ajax 调用,它应该获取并设置为那个特定的组合框.

所以直到现在我有这个

<template>
<JqxComboBox ref="core_combobox" :width="`100%`" :height="25"
@change="onChange($event)" :source="source" :selectedIndex="0" :displayMember="'label'" :valueMember="'value'">
</JqxComboBox>
</template>

<script>
import JqxComboBox from "./jqx-vue/vue_jqxcombobox.vue";

export default {
components: {
JqxComboBox
},
props : {
comboDataSource : String
},
methods: {
// Add here all used callbacks and/or events
onChange: function (event) {
if (event.args) {
let item = event.args.item;
if (item) {
alert(item.value)
}
}
},

getComboSource : function (){
axios
.get('/admin/forms/'+this.comboDataSource+'/listDataSource')
.then(function(response){
console.log(response.data);
return response.data;

});


},
data: function () {
return {
regexPattern : /(?<=\()(.*)(?=)\)/g,
datafields: [
{ name: 'value' },
{ name: 'label' }
],
source: this.getComboSource()
}
}
}
</script>

axios 的结果出于某种原因被转换为像这样的 vue 实例,

0: {__ob__: Observer}
1: {__ob__: Observer}
length: 2
__ob__: Observer {value: Array(2), dep: Dep, vmCount: 0}
__proto__: Array

0里面的值为

label: "SS Sales Corportation"
value: 1
__ob__: Observer {value: {…}, dep: Dep, vmCount: 0}
get label: ƒ reactiveGetter()
set label: ƒ reactiveSetter(newVal)
get value: ƒ reactiveGetter()
set value: ƒ reactiveSetter(newVal)
__proto__: Object

如果有人对此很熟悉,请问我两个问题。1.为什么返回的不仅仅是js对象?2. 数据来了,如何设置到JqxCombo

最佳答案

第一个问题:

这是 Vue 添加的一个特殊属性,它是 Reactivity 系统的一部分,允许 Vue 跟踪数据变化并对它们使用react,您可以在 official doc 中阅读更多相关信息。

第二个问题:

当数据使用 axios 调用时,您可以将其分配给 source 属性,例如:

getComboSource: function() {
axios
.get('/admin/forms/' + this.comboDataSource + '/listDataSource')
.then(function(response) {
console.log(response.data);
this.source= response.data;//<-------

});


}

并且在您的数据对象中,您应该按如下方式初始化 source:

data: function() {
return {
regexPattern: /(?<=\()(.*)(?=)\)/g,
datafields: [{
name: 'value'
},
{
name: 'label'
}
],
source:{}//<----
}
}

关于javascript - JqxCombo 值不是从 ajax 结果设置的 - Vue.js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53710490/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com