[英]How can I turn this into a loop?
I'm trying to make this even cleaner, I've shortened dozens of lines to this, but need to loop through my column/dropdown values and run them through the function. 我正在尝试使它更简洁,我已经缩短了数十行,但是需要遍历我的column / dropdown值并通过该函数运行它们。 I'm blanking.
我要空白
function populateDropdowns (dropdownObject) {
$.ajax({
url: "website eq '"+dropdownObject.column+"'",
type: "GET",
headers: {
"accept": "application/json;odata=verbose",
},
success: function (data) {
var authOne = (data.d.results[0].Choices.results);
$(dropdownObject.dropdown).empty();
$.each(authOne, function(i, p) {
$(dropdownObject.dropdown).append($('<option></option>').val(p).html(p));
});
},
error: function (error) {
alert(JSON.stringify(error));
}
});
}
var dropdownObject = {};
dropdownObject = {column:"value1", dropdown:'#id1'}; populateDropdowns(dropdownObject);
dropdownObject = {column:"value2", dropdown:'#id2'}; populateDropdowns(dropdownObject);
dropdownObject = {column:"value3", dropdown:'#id3'}; populateDropdowns(dropdownObject);
dropdownObject = {column:"value4", dropdown:'#id4'}; populateDropdowns(dropdownObject);
dropdownObject = {column:"value5", dropdown:'#id5'}; populateDropdowns(dropdownObject);
If your values are fixed till 5, then a for loop should work fine. 如果您的值固定到5,那么for循环应该可以正常工作。
for(var i = 1; i < 6; i++){
populateDropdowns( {column : "value" + i, dropdown:'#id' + i});
}
EDIT 1: If values are not sequential, then you can pass Objects array to a forEach
loop. 编辑1:如果值不是连续的,则可以将Objects数组传递给
forEach
循环。
var dropdowns = [
{column: "value1", dropdown: "#id1"},
{column: "value2", dropdown: "#id2"},
{column: "value3", dropdown: "#id3"},
{column: "value4", dropdown: "#id4"},
{column: "value5", dropdown: "#id5"}
;
dropdowns.forEach(dropdown => populateDropdowns(dropdown));
If you want to loop through some data, the data should probably be in an array: 如果要遍历某些数据,则数据可能应该在数组中:
const dropdownObjects = [
{ column: 'value1', dropdown: '#id1' },
{ column: 'value2', dropdown: '#id2' },
{ column: 'value3', dropdown: '#id3' },
// ...
];
for (var i = 0; i < dropdownObjects.length; i++) {
populateDropdowns(dropdownObjects[i]);
}
Or, more succinctly: 或者,更简洁地说:
dropdownObjects.forEach(populateDropdowns);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.