从头开始在正文中定义警报变量
Alert variable defined in body from head
我有一个简单的HTML页面,它使用了Facebook Javascript SDK:
<html>
<head>
<script src="http://code.jquery.com/jquery-latest.min.js" type="text/javascript"></script>
<script>
alert(publish);
</script>
</head>
<body>
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.init({
appId : 'xxxxxxxxxxx',
xfbml : true,
version : 'v2.1'
});
FB.getLoginStatus(function(response) {
});
FB.api(
"/me/permissions",
function (response) {
if(response && !response.error) {
publish = '1';
}
else {
publish = '0';
}
}
);
};
(function(d, s, id){
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) {return;}
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/sdk.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</body>
</html>
我想使用在FB.api
函数中定义的名为publish
的变量。我想在小节中使用它,但因为它是稍后定义的,所以它记录了一个未定义的变量错误。有办法绕过这个吗?
这里有两个问题,一个声明问题和一个时间问题。
截至您的alert
行,尚未创建名为publish
的变量。如果您尝试读取未声明符号的值,则会导致ReferenceError
。(如果你试图将写入一个未声明的符号,在宽松模式下你会得到隐式全局变量的恐怖,在严格模式下你就会得到一些合理的东西:ReferenceError
。)
但更重要的是,时间问题:当你试图提醒它时,publish
不仅未声明,而且即使声明了它,它也没有有用的值,因为你还没有设置值。
提醒publish
值的正确位置是在api
回调中,在那里您可以获得值:
FB.api(
"/me/permissions",
function (response) {
var publish; // <== declare it
if(response && !response.error) {
publish = '1';
}
else {
publish = '0';
}
alert(publish); // <== use it
}
);
如果您需要在api
回调之外使用publish
,那么您可以将声明移动到回调之外。但是,在回调发生之前,您不能使用publish
(有意义)。例如:
var publish; // <======= Declaration
window.fbAsyncInit = function() {
FB.init({
appId : 'xxxxxxxxxxx',
xfbml : true,
version : 'v2.1'
});
FB.getLoginStatus(function(response) {
});
FB.api(
"/me/permissions",
function (response) {
if(response && !response.error) {
publish = '1'; // <=== fill it in
}
else {
publish = '0'; // <===
}
}
);
};
function doSomethingWithItLater() { // <=== A function that uses it
if (publish) {
// Do this
} else {
// Do that
}
}
(function(d, s, id){
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) {return;}
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/sdk.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
重要的是,在之后调用api
回调并设置publish
的值之前,不要调用doSomethingWithItLater
。确保这一点的最佳方法是从回调中调用它。
您需要在函数启动之前定义变量。然后函数将更新变量。
<script type="text/javascript">
var publish;
相关文章:
- 得到"全局未定义“;全局变量定义清楚时出错
- 使用变量的名称,然后为该变量定义函数
- Javascript 从 php 变量定义 getElementById()
- 使用变量定义宽度和高度
- 函数内部的JavaScript全局变量定义
- Javascript变量定义-澄清
- 为多个变量定义相同的类型,在Webstorm中识别
- 如何用变量定义一个数组,然后用一个数字填充每个数组
- 画布的奇怪行为 上下文变量定义位置导致选项卡处于非活动状态时画布呈现冻结
- 为什么要显式将变量定义为未定义
- Gulp/Grunt 获取触笔工作表中的所有颜色变量,并将它们作为变量定义写入文件
- 是否可以在 Node.js 中为模块变量定义 SET 函数
- ES6 块范围的变量定义作为条件
- 使用 jQuery 获取由变量定义的文本输入的值
- :gt()选择器,为变量定义的索引
- 如何在ASP.NET中将Javascript变量定义为Session
- 带有用户输入的ajax请求变量定义有问题
- 使用ElasticSearch搜索变量定义字段
- 变量定义,不同的输出
- JavaScript变量定义和范围