- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想将属性 soundFileName
声明为 var soundFileName = 'audio/60.wav';
这样 soundFileName
就不会全局定义,但是当我这样做时,我得到 ReferenceError: soundFileName is not defined
。
我将 soundFileName
的值作为参数传递给 loop(soundFileName)
,我认为值 'audio/60.wav'
应该可以顺利通过。
我怀疑这与范围或嵌套有关,但我不确定如何解决该问题。当我使用不带 var 的 soundFileName = 'audio/60.wav';
时,代码确实有效。
我错过了什么?谢谢!
编辑:代码现在可以工作并更新了!
<!DOCTYPE html
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<script src="js/howler.core.js"></script>
<link rel="stylesheet" href="css/styles.css">
</head>
<body>
<script src="timeprobabilities.js"></script>
<script>
///////////////////////////////////////////////////////////////
// MASTER START ///////////////////////////////////////////////
///////////////////////////////////////////////////////////////
// initiates fist call to all clocks to each will start and can then be called again
(function masterStart() {
setTimeout(function() {
//// LOOP SOUNDS \\\\
A();
}, 0);
}());
///////////////////////////////////////////////////////////////
// LOOPS SHARED OPTIONS ///////////////////////////////////////
///////////////////////////////////////////////////////////////
var options = {
numberOfSounds: 0,
maxNumberOfSounds: 4
};
function logNumberOfSounds() { // passing options into this before is what broke code
options.numberOfSounds++;
//console.log('Number of sounds is: ' + options.numberOfSounds + '########');
}
///////////////////////////////////////////////////////////////
// LOOP A ////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////
function A() {
var optionsA = {
playDurationMin: 0,
playDurationMax: 60000,
// start time minimum and maximum
startMinA: 0,
startMaxA: 8000,
maxVolumeA: 1,
//
startMinB: 0,
startMaxB: 30000,
maxVolumeB: 1,
//
startMinC: 0,
startMaxC: 30000,
maxVolumeC: 1,
//
startMinD: 0,
startMaxD: 30000,
maxVolumeD: 1,
//
startMinE: 0,
startMaxE: 30000,
maxVolumeE: 1,
//
startMinF: 0,
startMaxF: 30000,
maxVolumeF: 1,
//
startMinG: 0,
startMaxG: 30000,
maxVolumeG: 1,
//
startMinH: 0,
startMaxH: 30000,
maxVolumeH: 1,
//
startMinI: 0,
startMaxI: 30000,
maxVolumeI: 1,
//
startMinJ: 0,
startMaxJ: 30000,
maxVolumeJ: 1,
//
startMinK: 0,
startMaxK: 30000,
maxVolumeK: 1
};
masterClock();
function masterClock() {
setTimeout(function() {
soundA(options, optionsA);
}, 10); // these need to be called with delay so they don't use the other functions' paramaters
}
function soundA() {
var soundFileName = 'audio/60.wav';
fadeIn = 8000;
fadeOut = 8000;
console.log('soundFileName in A: ' + soundFileName);
calculateStartDelay(optionsA.startMinA, optionsA.startMaxA);
function calculateStartDelay(startMin, startMax) {
startDelay = Math.floor(Math.random() * startMax) + startMin;
}
function calculatePlayDuration(playDurationMin, playDurationMax) {
playDuration = Math.floor((Math.random() * playDurationMax) + playDurationMin);
}
function executePlayTools() {
calculatePlayDuration(optionsA.playDurationMin, optionsA.playDurationMax);
loop(options, playDuration, soundFileName, fadeIn, fadeOut);
console.log('A: ////////////////////////////////// ');
masterClock();
}
setTimeout(function() {
if (probabilityValue < probabilityPointA) {
maxVolume = optionsA.maxVolumeA;
executePlayTools();
} else if (probabilityValue < probabilityPointB) {
maxVolume = optionsA.maxVolumeB;
executePlayTools();
} else if (probabilityValue < probabilityPointC) {
maxVolume = optionsA.maxVolumeC;
executePlayTools();
} else if (probabilityValue < probabilityPointD) {
maxVolume = optionsA.maxVolumeD;
executePlayTools();
} else if (probabilityValue < probabilityPointE) {
maxVolume = optionsA.maxVolumeE;
executePlayTools();
} else if (probabilityValue < probabilityPointF) {
maxVolume = optionsA.maxVolumeF;
executePlayTools();
} else if (probabilityValue < probabilityPointG) {
maxVolume = optionsA.maxVolumeG;
executePlayTools();
} else if (probabilityValue < probabilityPointH) {
maxVolume = optionsA.maxVolumeH;
executePlayTools();
} else if (probabilityValue < probabilityPointI) {
maxVolume = optionsA.maxVolumeI;
executePlayTools();
} else if (probabilityValue < probabilityPointJ) {
maxVolume = optionsA.maxVolumeJ;
executePlayTools();
} else {
maxVolume = optionsA.maxVolumeK;
console.log('Probability Else');
}
console.log('startDelay: ' + startDelay)
}, startDelay);
}
}
///////////////////////////////////////////////////////////////
// SHARED LOOP ///////////////////////////////////////////////
///////////////////////////////////////////////////////////////
function loop(options, playDuration, soundFileName, fadeIn, fadeOut) {
console.log('soundFileName in loop: ' + soundFileName);
if (options.numberOfSounds < options.maxNumberOfSounds) { //Don't create more than the max number of sounds.
var sound = getSound(soundFileName);
var id2 = sound.play();
logNumberOfSounds();
sound.volume(0); // don't think I need this since it's declared above and in getSound(), but it stops blips?
sound.fade(0, maxVolume, fadeIn, id2); // FADE IN
setTimeout(function() {
sound.fade(maxVolume, 0, fadeOut, id2); // FADE OUT
options.numberOfSounds--;
// Attempt to clean up the sound object
setTimeout(function() {
sound.stop();
sound.unload();
}, fadeOut + 1000);
}, playDuration);
}
}
// PLAYER FOR MAIN SOUND FUNCTION /////////////////////////////
function getSound(soundFileName) {
return new Howl({
src: [soundFileName],
autoplay: true,
loop: true,
volume: 0,
fade: 0 // removes the blip
});
}
</script>
<script src="js/howler.core.js"></script>
<script src="js/siriwave.js"></script>
<script src="js/player.js"></script>
</body>
</html>
最佳答案
每个函数都有自己的作用域,函数内声明的变量仅存在于该函数的作用域内。
在这种情况下,soundFileName
被声明为 soundA
中的 var
,因此它仅存在于 soundA
的范围内>.
您将 soundFileName
作为参数传递给 loop
,然后从那里将其传递给 getSound
,但是您的 function definitions for loop
和 getSound
不包含任何命名参数。
您需要更改 function definition为 loop
和 getSound
包含预期的参数:
function loop(options, playDuration, soundFileName, fadeIn, fadeOut) {
...
// soundFileName is now availabie in this scope
...
}
function getSound(soundFileName) {
...
// soundFileName is now availabie in this scope
...
}
请注意,在 JavaScript
中的每个函数中(不包括 arrow functions )都有 a special arguments
object包含调用函数的参数,因此由于您将 soundFileName
作为 loop
的第三个参数传递,传递的值也将在 loop
中可用> 作为 arguments[2]
,并且由于它作为第一个参数传递给 getSound
,它也将在 getSound
中作为 可用参数[0]
。
关于javascript - 为什么函数在全局声明变量而不是 var 时起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54849385/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to nest OR statements in JavaScript? 有没有办法做到这一点:
在 JavaScript 中有没有办法让一个变量总是等于一个变量?喜欢var1 = var2但是当var2更新,也是var1 . 例子 var var1 = document.getElementBy
我正在努力理解这代表什么 var1 = var2 == var3 我的猜测是这等同于: if (var2 == var3): var1 = var2 最佳答案 赋值 var1 = var2
这个问题已经有答案了: What does the PHP error message "Notice: Use of undefined constant" mean? (2 个回答) 已关闭 8
我在临时表中有几条记录,我想从每条记录中获取一个值并将其添加到一个变量中,例如 color | caption -------------------------------- re
如何将字符串转为变量(字符串变量--> $variable)? 或者用逗号分隔的变量列表然后转换为实际变量。 我有 2 个文件: 列名文件 行文件 我需要根据字符串匹配行文件中的整行,并根据列名文件命
我有一个我无法解决的基本 php 问题,我也想了解为什么! $upperValueCB = 10; $passNodeMatrixSource = 'CB'; $topValue= '$uppe
这可能吗? php $variable = $variable1 || $variable2? 如果 $variable1 为空则使用 $variable2 是否存在类似的东西? 最佳答案 PHP 5
在 Perl 5.20 中,for 循环似乎能够修改模块作用域的变量,但不能修改父作用域中的词法变量。 #!/usr/bin/env perl use strict; use warnings; ou
为什么这不起作用: var variable; variable = variable.concat(variable2); $('#lunk').append(variable) 我无法弄清楚这一点
根据我的理解,在32位机器上,指针的sizeof是32位(4字节),而在64位机器上,它是8字节。无论它们指向什么数据类型,它们都有固定的大小。我的计算机在 64 位上运行,但是当我打印包含 * 的大
例如: int a = 10; a += 1.5; 这运行得很完美,但是 a = a+1.5; 此作业表示类型不匹配:无法从 double 转换为 int。所以我的问题是:+= 运算符 和= 运算符
您好,我写了这个 MySQL 存储过程,但我一直收到这个语法错误 #1064 - You have an error in your SQL syntax; check the manual that
我试图在我的场景中显示特定的奖牌,这取决于你的高分是基于关卡的目标。 // Get Medal Colour if levelHighscore goalScore { sc
我必须维护相当古老的 Visual C++ 源代码的大型代码库。我发现代码如下: bIsOk = !!m_ptr->isOpen(some Parameters) bIsOk的数据类型是bool,is
我有一个从 MySQL 数据库中提取的动态产品列表。在 list 上有一个立即联系 按钮,我正在使用一个 jquery Modal 脚本,它会弹出一个表单。 我的问题是尝试将产品信息变量传递给该弹出窗
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
jQuery Core Style Guidelines建议两种不同的方法来检查变量是否已定义。 全局变量:typeof variable === "undefined" 局部变量:variable
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: “Variable” Variables in Javascript? 我想肯定有一种方法可以在 JavaScrip
在语句中使用多重赋值有什么优点或缺点吗?在简单的例子中 var1 = var2 = true; 赋值是从右到左的(我相信 C# 中的所有赋值都是如此,而且可能是 Java,尽管我没有检查后者)。但是,
我是一名优秀的程序员,十分优秀!