私はjavascriptを学んでいますが、以下のコードの問題を理解できません。配列が実際にどのように機能するかを誤解していると思います。
問題は、アラートされた配列が実際にはソートされていないことです。これに関する洞察に感謝します。
HTML:
<html>
<head>
<title>
Test 1
</title>
<script src="http://code.jquery.com/jquery-latest.js" type=
"text/javascript">
</script>
</head>
<body>
<div class="items">
<ul>
<li>
<a href="#" id="1">Link 1</a>
</li>
<li>
<a href="#" id="2">Link 2</a>
</li>
<li>
<a href="#" id="3">Link 3</a>
</li>
<li>
<a href="#" id="4">Link 4</a>
</li>
</ul>
</div>
</body>
</html>
Javascript:
var clickedLinks = [];
var passedItems = [];
// Collect clicked link IDs into an array and pass the array as an argument to shoplist()
$('.items a').click(function () {
if (clickedLinks.indexOf(this.id) != -1) {
var linkIndex = clickedLinks.indexOf(this.id);
clickedLinks.splice(linkIndex, 1);
} else {
clickedLinks.push(this.id);
}
shoplist(clickedLinks);
});
function shoplist(ids) {
passedItems.push(ids.slice());
alert(passedItems.sort());
}
再現する手順:
- リンク 2 をクリックします。
- リンク 1 をクリックします。
期待される結果: 1、2、2
実際の結果: 2、2、1
私が試したこと:
function shoplist(ids) {
passedItems.push(ids.slice());
var newpi = passedItems.slice();
alert(newpi.sort());
}