- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我曾经让一个 fancybox 根据用户访问的国家/地区向他们显示一条消息,如下所示:
<script>
jQuery.ajax({
url: '//freegeoip.net/json/',
type: 'POST',
dataType: 'jsonp',
success: function(location) {
// If the visitor is browsing from United Kingdom.
if (location.country_code === 'GB') {
// Tell him about U.S. store.
jQuery.fancybox.open(jQuery('#messageGB'));
}
}
});
</script>
<div id="messageGB">
<p>You are visiting our U.S. store. </p>
</div>
我在使用 fancybox 放置 cookie 时遇到了一些问题,所以现在我正在使用一个 jquery 弹出窗口,它本身可以正常工作,但是如果我尝试进行基于国家/地区的调用,它就不起作用了……有什么想法吗我做错了吗?
// If the visitor is browsing from United Kingdom.
if (location.country_code === 'GB') {
// Tell him about U.S. store.
$('#popup_messageGB').popup({
setcookie: true,
cookie_timeout: 0
}
}
});
</script>
<div id="popup_messageGB">
<p>You are visiting our U.S. store. </p>
</div>
最佳答案
跨域ajax请求需要以特定的方式完成,web服务需要支持。而且您使用的地理位置服务确实支持“jsonp”跨域请求……所以您很幸运。
注意添加到查询字符串的回调参数。您的代码缺少回调,这可能是它无法正常工作的原因。
jQuery 文档解释了如何进行 jsonp 调用 jQuery.getJSON()
你的 jQuery 代码看起来像这样:
$.getJSON('http://freegeoip.net/json/?callback=?', function(data) {
// your popup here
});
然而,对于像这样简单的东西并不真正需要 jQuery。您只需要检索访问者的位置一次。这可以通过在普通脚本标记中包含 Web 服务 URL 来完成。加载后,它将使用返回的数据调用您的函数。
更新:回应评论
@RobRob - 只需复制下面的代码,添加您的弹出代码,就大功告成了。
<!doctype html>
<html>
<body>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$.getJSON('http://freegeoip.net/json/?callback=?', function(location) {
// insert your popup code here
alert( location.country_name );
});
});
</script>
</body>
</html>
下面的示例演示了执行 jsonp 调用的两种方法。
运行代码片段以显示您所在的国家/地区
<html>
<body>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<button onclick="getLocation()">jQuery.getJSON</button>
<h2 id="country_name"></h2>
JSON:
<xmp id="stdout" style="border:1px gray solid; background-color:aliceblue;"></xmp>
<script type="text/javascript">
// Method 1: plain Javascript jsonp callback
function onGeoLocation( data ) {
document.getElementById('stdout').innerHTML = JSON.stringify(data,null,' ');
document.getElementById('country_name').innerHTML = 'Country: ' + data.country_name;
// add your popup here
};
// Method 2: Using jQuery
function getLocation() {
$.getJSON('http://freegeoip.net/json/?callback=?', function(data) {
alert( 'jQuery.getJSON\n' + JSON.stringify(data, null, ' '));
// your popup here
});
}
</script>
<!-- This script tag required for method 1 -->
<script type="text/javascript" src="http://freegeoip.net/json/?callback=onGeoLocation"></script>
</body>
</html>
关于javascript - Location.country_code - Fancybox,现在弹出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30551800/
我似乎无法让它发挥作用。我已经尝试过在线样本,但没有一个正是我需要的。基本上我希望能够显示从给定日期过去的天数。我下面的示例是 HTML 和 PHP 的组合,出于某些原因我不得不这样做。 Date
Closed. This question needs to be more focused。它当前不接受答案。 想改善这个问题吗?更新问题,使其仅关注editing this post的一个问题。
在此处搜索“线程关联”的答案,我发现人们对此很感兴趣,但没有什么理由可以节省可能获得稳定的 QueryPerformanceTimer 结果。 假设一个现代操作系统和一个现代 2-4 插槽工作站/服务
我有一个称为main-app的聚合物元素:
我有一个表,我想在每个插入时间记录每个订单的时间戳。但是,我得到的时间戳值为零。 这是我的架构: CREATE TABLE IF NOT EXISTS orders( orde
我正在使用 MongoDB Atlas 来托管数据库并使用这个无服务器函数查询数据: import { NextApiRequest, NextApiResponse } from "next"; /
苹果卸下了转义键,并用OLED触摸条替换了它。这对emacs用户具有影响,特别是对于具有数十年肌肉内存力才能克服此变化的UNIX/emacs用户而言。幸运的是,触摸栏逃生键似乎总是在您需要的时候出现,
抱歉,我对 DbGrids 还很陌生。 我是否应该使用查询的字段编辑器并以某种方式添加一个捕获 TIMEDIFF 的新字段,然后将其添加为我的 DbGrid 中的列? 或者我可以/应该跳过字段编辑器并
正如一本相当古老的书XUnit Patterns所写,NUnit 2.0不会为每个测试创建新的测试夹具,因此,如果测试正在操纵夹具的某种状态,则该夹具会被共享并且可能导致各种不良副作用。 还是一样吗?
我知道自2016年4月以来,Youtube API的默认配额限制为1M。 如果要增加它,我们需要向Google 发送请求。 我想知道我们可以要求的配额限制的最大值是多少? 最佳答案 根据Google开
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
{ "size": 0, "query": { "range": { "LogTime": { "gte": "now-1d",
当我尝试从终端编译这个简单的代码时: #include int main(void) { printf("%f\n",sqrt(10)); return 0; } 使用 gcc mai
我正在尝试筛选抓取一个 html 页面,以便我可以从中提取所需的有值(value)的数据并将其放入文本文件中。到目前为止,一切进展顺利,直到我在 html 页面中遇到了这个: In inventor
这是我的 结果 MySQL 表的示例: 我想将特定用户的所有日期向前移动相同的时间间隔,以便该用户的最高日期是当前时间戳。我知道如何获取以天为单位的间隔: /* result is 823 */ SE
我有一个函数需要从主视图中的几个不同位置调用。我们称它为 updateFunction。 我这样声明: - (void)updateFunction { //updates some vari
我正在尝试找出如何以某种方式嵌套回调。 var alpha = function(callback){ var x = 5; if(x > 2){ callback()
为什么我收到RangeError:超出最大调用堆栈错误?我正在尝试解析文本以找到数学并解决它。它一直有效,直到我开始实现括号'。我试图找出错误,但就是无法弄清楚。 我的代码: var alg = {
我记得几年前,没有使用 SSL 的原因之一是它占用了大量资源,因此影响了应用程序的性能。 如今,以当前的技术,这仍然是一个需要牢记的点吗? 这个问题的出现是因为一位同事担心使用 SSL 会影响他的应用
我正在将我的数据库从 sqlserver 迁移到 mysql当我在 sqlserver 中使用 getDate() 函数时,mysql 中的替换是 Now()但是 Now() 没有返回 getDate
我是一名优秀的程序员,十分优秀!