我想通过下一个和上一个按钮逐步执行数组。每个按钮调用的功能与它相同。我有以下代码......
function displayPic(i) {
if (i == 0) {
$('#map_holder').empty();
$('#map_holder').append(picArray[i] + '<br><input id="next" type="button" value="Next" onclick="displayPic(' + i + 1 + ');" />');
if (i == picArray.length - 1) {
$('#map_holder').empty();
$('#map_holder').append(picArray[i] + '<br><input id="prev" type="button" value="Prev" onclick="displayPic(' + i - 1 + ');" />');
}
else {
$('#map_holder').empty();
$('#map_holder').append(picArray[i] + '<br><input id="prev" type="button" value="Prev" onclick="displayPic(' + i - 1 + ');" /> <input id="next" type="button" value="Next" onclick="displayPic(' + i + 1 + ');" />');
}
}
}
任何帮助?
答案 0 :(得分:2)
我不建议每次显示新图像时添加按钮,这会使它更复杂。如何使用全局变量i
并使用<img>
和<button id='prev'>
以及<button id='next'>
尽早构建表单?
<div id='map_holder'></div>//this will display the image
<button id="prev">Prev</button>
<button id="next">Next</button>
var i = 0;
displayPic(0); //show the first photo initially
$('#prev').click(function(){
i--;
displayPic(i);
});
$('#next').click(function(){
i++;
displayPic(i);
});
function displayPic(i) {
$('#map_holder').empty();
$('#map_holder').append(picArray[i]);
if(i == 0)
$('#prev').hide();
else
$('#prev').show();
if(i == picArray.length-1)
$('#next').hide();
else
$('#next').show();
}
答案 1 :(得分:0)
查看您的代码,存在一个问题。外部块检查if (i == 0)
,然后内部块检查if (i == picArray.length - 1)
。在正常情况下,内部阻止条件永远不会评估为true
,因为i
由于外部0
条件而保证为if (i == 0)
。
尝试此操作:
function displayPic(i) {
if (i == 0) {
$('#map_holder').empty();
$('#map_holder').append(picArray[i] + '<br><input id="next" type="button" value="Next" onclick="displayPic(' + i + 1 + ');" />');
}
else if (i == picArray.length - 1) {
$('#map_holder').empty();
$('#map_holder').append(picArray[i] + '<br><input id="prev" type="button" value="Prev" onclick="displayPic(' + i - 1 + ');" />');
}
else {
$('#map_holder').empty();
$('#map_holder').append(picArray[i] + '<br><input id="prev" type="button" value="Prev" onclick="displayPic(' + i - 1 + ');" /> <input id="next" type="button" value="Next" onclick="displayPic(' + i + 1 + ');" />');
}
}
如果仍然无效,请提供进一步的详细信息。