gpt4 book ai didi

javascript - Jquery:获取函数的返回值

转载 作者:行者123 更新时间:2023-11-29 10:09:09 25 4
gpt4 key购买 nike

我想用 jquery 创建一个基本的通用函数,将 html 列表的所有元素放入一个数组中。一切似乎都很好,但我在获取返回值时遇到了一些问题。我知道这是一个基本问题,所以我希望你能帮助我解决它。

  <script>
function listeToArrayById(idListe){
$(function(){
var listChildren = $("#" + idListe).children(); //puts all li children in var listChildren
var arrayListChildren = [];
$.each(listChildren, function(key, value){
arrayListChildren.push($(this).text());
})
return arrayListChildren; // here it's ok arrayListChildren = ["a", "b", "c"]
})
}
var ulChildren = listeToArrayById("list1");
window.console.log(ulChildren); // here is my problem because ulChildren is undefined ... I should get an array ["a", "b", "c"]
</script>
</head>
<body>
<ul id="list1">
<li>a</li>
<li>b</li>
<li>c</li>
</ul>
</body>

最佳答案

您以错误的方式使用了文档就绪处理程序

function listeToArrayById(idListe){ 
var listChildren = $("#" + idListe).children();
var arrayListChildren = [];
$.each(listChildren, function(key, value){
arrayListChildren.push($(this).text());
})
return arrayListChildren; // here it's ok arrayListChildren = ["a", "b", "c"]
}

$(function(){
var ulChildren = listeToArrayById("list1");
console.log(ulChildren);
});

你可以像下面这样简化你的代码,

function listeToArrayById(idListe){ 
return $("#" + idListe).children().map(function(){
return this.textContent
}).get();
}

关于javascript - Jquery:获取函数的返回值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36821432/

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