gpt4 book ai didi

javascript - 尝试根据先前函数的结果显示图像

转载 作者:行者123 更新时间:2023-11-28 00:01:39 24 4
gpt4 key购买 nike

我是 javascript 的新手,所以请非常温和并尽可能多地解释事情;)

我正在尝试创建一个按钮,该按钮将从列表中随机选择一个名称并显示该人的图像(如果您知道这是做什么用的,则为英雄)。

到目前为止,我有一个运行随机选择名称功能的按钮,我只是很难显示图像...

<html>
<body>

<button onclick="myFunction()">Random</button>

<script>
function myFunction()
{
var strings = ['Axe', 'Bane', 'Batrider' ];

var randomIndex = Math.floor(Math.random() * strings.length);

var randomString = strings[randomIndex];
document.write(' ' + randomString);
}
</script>

<script type="text/javascript">
var picData = [
['Axe','http://ponky.org/~ropedy/DC/icons/heroes/Axe.png'],
['Bane','http://ponky.org/~ropedy/DC/icons/heroes/Bane.png'],
['Batrider','http://ponky.org/~ropedy/DC/icons/heroes/Batrider.png']
];
window.onload=myFunction(){
var cookieValue = 'Axe';
for(i=0; i < picData.length; i++){
if(cookieValue == picData[i][0]) {
document.getElementById('imgCont').src = picData[i][1];
i=picData.length;
}
}
}
</script>

<div>
<img id="imgCont" src="" alt="" />
</div>

最佳答案

将您的 window.onload 更改为如下内容:

window.onload = function() {
myFunction();
// then the rest of your stuff to set the .src
}

但看起来您真正想要做的是将用于设置 .src 的内容移动到一个单独的函数中,以便您可以调用它来响应您的按钮点击。

类似于:

var picData = [
['Axe','http://ponky.org/~ropedy/DC/icons/heroes/Axe.png'],
['Bane','http://ponky.org/~ropedy/DC/icons/heroes/Bane.png'],
['Batrider','http://ponky.org/~ropedy/DC/icons/heroes/Batrider.png']
];

function myFunction()
{
var randomIndex = Math.floor(Math.random() * picData.length);

var randomString = picData[randomIndex][0];
document.write(' ' + randomString); // Note: I'd generally avoid document.write

document.getElementById('imgCont').src = picData[randomIndex][1];
}

现在,如果您想在首次加载时给您一个随机图像并在您每次单击按钮时给您一个随机图像,您可以从 onloadonclick 调用它。

为了便于阅读和维护代码,我还将用对象文字数组替换您的一个或多个数组:

var picData = [
{name:'Axe', imageUrl:'http://ponky.org/~ropedy/DC/icons/heroes/Axe.png'},
{name:'Bane', imageUrl:'http://ponky.org/~ropedy/DC/icons/heroes/Bane.png'},
{name:'Batrider', imageUrl:'http://ponky.org/~ropedy/DC/icons/heroes/Batrider.png'}
];

为什么?因为现在而不是:

 picData[randomIndex][1];

我会写:

 picData[randomIndex].imageUrl;

这更具可读性,让您更清楚地了解您实际在做什么。

关于javascript - 尝试根据先前函数的结果显示图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21024088/

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