gpt4 book ai didi

JavaScript 堆栈,LIFO 堆栈 : value not as expected

转载 作者:行者123 更新时间:2023-12-02 16:12:12 29 4
gpt4 key购买 nike

我有以下代码。

var stackMapIn = [];
var stackMapOut = [];
var stackBack = [];

stackMapOut.push("m1");

$scope.clickLinks = function(initialOut,initialIn,extra,backIn,backOut,name){
$('div#'+initialOut+'Map,'+extra).fadeOut('slow',function(){
$('.'+initialOut+'Details,.bkbtn'+backOut).css("display","none");
$('.'+initialIn+'Details,.bkbtn'+backIn).css("display","block");
$('.noQuery').css("display","none");
$("#buildingHeader").html(name);
$('div#'+initialIn+'Map').fadeIn('slow');
})

stackMapOut.push(initialIn);
stackMapIn.push(initialOut);
stackBack.push(backIn);
}

$scope.clickBack = function(bkbtnCheck){
alert(stackBack[0]);
mapOut = stackMapOut.pop();
mapIn = stackMapIn.pop();
stackBack.pop();
backIn = stackBack[0];
alert(backIn);

$('div#'+mapOut+'Map').fadeOut('slow',function(){
$('.'+ mapOut + 'Details,.bkbtn').css("display", "none");
$('.' + mapIn + 'Details,.bkbtn'+backIn).css("display", "block");
$(".noQuery").css("display","none");
$("#buildingHeader").html("Name");
$('div#' + mapIn + 'Map').fadeIn('slow');
})
}

现在我将快速浏览一下这段代码运行时发生的情况。

clickLinks 第一次运行:

initialIn = 'm2'

initialOut = 'm1'

backIn = 'Home'

clickBack尚未运行。

第二次clickLinks运行:

initialIn = 'm7'

initialOut = 'm2'

backIn = 'CentralPortfolio'

好的,现在事情应该是这样的(我期望):

stackMapOut = ['m1','m2','m7']

stackMapIn = ['m1','m2']

stackback = ['Home','CentralPortfolio']

现在我们运行clickBack...为什么警报输出“Home”??

我在这里想做的是,当clickLinks运行时,我有一系列的东西出现和消失。有时,用户可以运行clickBack以返回到先前的状态(状态)。因此,我使用 JavaScript 堆栈 来跟踪它所处的状态以及它需要返回的位置。

问题是,我可以连续运行clickLinks一次、clickBack一次,没有问题。我什至可以再次运行clickLinks,并且仍然单击后退按钮两次(返回开始),没有问题。但我仍然不明白为什么此时 stackBack[0] (这应该是堆栈的顶部?)= "Home" 而不是 "CentralPortfolio"。

因为我现在遇到的真正问题是,如果我第三次运行 clickLinks:仍然 stackBack[0] = 'Home' (当我期望它此时为“CentralCampus”),因此,显示的是“Home”后退按钮(而正确的其他内容则根据 mapOutmapIn 显示) 而不是显示 CentralPortfolio 的后退按钮;因为我在使用“CentralCampus”之前“弹出”了它。

<小时/>

如果需要任何其他信息或需要更多说明,请告诉我。我尽力提供任何需要的信息并使其尽可能清晰。

最佳答案

Now we run clickBack... Why does the alert output "Home"??`

因为stackBack[0]Home。您希望它做什么?你甚至在你的问题中也提到了这一点:

stackback = ['Home','CentralPortfolio']

索引0是数组中的第一个元素,即Home。最后一个元素是 stackBack[stackBack.length - 1]

using JavaScript stack

不,您使用的是 javascript 数组,但是像堆栈一样使用它。除非你像数组一样索引它 - 这是你困惑的根源。您可以将其用作 poppush 的堆栈,但不要尝试使用 []

对其进行索引

当您push数组时,您将一个元素添加到数组的末尾。换句话说,它最终成为索引 yourArray.length - 1 处的最后一个元素。当您pop时,您再次从数组中取出最后一个元素。因此,弹出 stackback 会返回 CentralPortfolio,当然,第一个元素保持不变。

关于JavaScript 堆栈,LIFO 堆栈 : value not as expected,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30059449/

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