gpt4 book ai didi

javascript - 从子组件中过滤数组数据表

转载 作者:搜寻专家 更新时间:2023-10-30 22:42:12 24 4
gpt4 key购买 nike

我正在将我的一个旧的 PHP/jquery 单页应用程序迁移到 VueJS/Webpack,以便更好地使用后者。这是一个简单的表,它从 JSON API 获取数据并使用过滤器控件(在它们自己的组件中)。除了我尝试使用子组件中的控件过滤表格外,一切正常。我已经为我用作表格数据源的数组设置了一个 Prop 。

我的 App.vue模板如下所示:

<template>
<div>
<fan-modals v-bind:fans="fans"></fan-modals>

<div class="container">
<filter-controls v-bind:fans="fans"></filter-controls>
<fans v-bind:fans="fans"></fans>
</div> <!-- end #container -->
</div>
</template>

<script>
import FilterControls from './components/FilterControls.vue';
import Fans from './components/Fans.vue';
import FanModals from './components/FanModals.vue';


export default {
name: 'app',
data: function() {
return {
fansUrl: 'example.com',
fans: []
}
},
components: {
filterControls: FilterControls,
fans: Fans,
fanModals: FanModals
},
methods: {
getFans: function (data) {
var self = this;
$.getJSON(self.fansUrl, function(data){
self.fans = data;
});
}
},
mounted() {
this.getFans();
}
}
</script>

我正在尝试在 <FilterControls> 的函数中重用我在旧应用程序中使用的重构 jquery 脚本成分。这是我的 <FilterControls> 的脚本部分子组件:

<script>
export default {
data: function() {
return {
voltageArray: [],
rpmArray: [],
noiseLevelArray: [],

selectedVoltage: 'Voltage',
selectedRPM: 'Max RPM',
selectedNoiseLevel: 'Max dBA',

selectedImpellerSize: '',
selectedCageSize: '',
selectedPhase: '',
selectedFrequency: '',
secondVoltage: ''
}
},
props: {
fans: {
type: Array
}
},
watch: {
fans(value) {
this.populateControls(value);
}
},
methods: {
populateControls(fans) {

//create emtpy arrays for dropdowns
var voltage = [];
var rpm = [];
var noiseLevel = [];

//for each fan in fans, get voltages, rpm and noiseLevel values and add them to the empty arrays
$.each(fans, function(index, value) {
voltage.push(fans[index].voltage);
rpm.push(fans[index].rpm);
noiseLevel.push(fans[index].noise_level);
});

//deduplicate and sort arrays
this.voltageArray = $.unique(voltage).sort();
this.rpmArray = $.unique(rpm).sort(function(a, b){return a-b});
this.noiseLevelArray = $.unique(noiseLevel).sort();

},
filterFans(fans) {
var filtered = $.grep(fans, function(fan) {
if (this.selectedVoltage === "208-240++") { var secondVoltage = "230"; };

return (selectedImpellerSize === '' || fan.diameter === selectedImpellerSize);// &&
(selectedCageSize === '' || fan.cage_diameter === selectedCageSize) &&
(selectedPhase === '' || fan.phases === selectedPhase) &&
(selectedFrequency === '' || fan.frequency === selectedFrequency) &&
(selectedRPM === 'Max RPM' || fan.rpm <= parseInt(selectedRPM)) &&
(selectedNoiseLevel === 'Max dBA' || fan.noise_level <= selectedNoiseLevel) &&
(selectedVoltage === 'Voltage' || fan.voltage === selectedVoltage || fan.voltage === (jQuery.isEmptyObject(secondVoltage) ? selectedVoltage : secondVoltage));
});

fans = filtered;
}
}
}
</script>

populateControls()方法用可能的值填充我的下拉列表以进行过滤。我正在尝试使用 filterFans()过滤我的方法 fans用于填充我的表的数组。当我将此方法附加到单击按钮时,出现错误:

Uncaught TypeError: Cannot read property 'length' of undefined

它引用了以 var filtered = $.grep(fans, function(fan) 开头的行所以我猜它在遍历我的 fans 时遇到了问题数组。

我知道有更好的方法可以做到这一点,但我对 VueJS 还很陌生。我是否漏掉了一些非常明显的东西?

最佳答案

问题可能出在您对按钮的事件处理程序绑定(bind)的使用上。例如,您可能有这个:

<button @click="filterFans()">Filter fans</button>

问题在于缺少 filterFans 所需的函数参数(即 fans)。 $.grep 尝试读取 fans.length,导致您看到的错误。

您可以通过更新模板中的处理程序来解决此问题:

<button @click="filterFans(fans)">Filter fans</button>

或者更新filterFans直接读取this.fans:

filterFans() {
const filtered = $.grep(this.fans, /* ... */);
}

关于javascript - 从子组件中过滤数组数据表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52265412/

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