- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我正在练习我的 jquery/javascript 技能。我基本上创建了一个包含图像插件(PgwSlider)和谷歌地图jquery插件的网站。我在图像插件中包含了 4 个图像,以便用户可以通过单击插件中的箭头来查看不同的图像。界面。我想做的是,当用户查看第一张图片时,谷歌地图会显示一个区域。当用户点击查看另一张图片时,gmaps 插件上的地址也应该发生变化。我对地址进行硬编码,因此它不是随机的。例如。如果 slider 显示包含不同大学的图片,当用户在图片中移动时,gmap 中显示的大学地址也应该与图片相关地发生变化。
这是我的逻辑:由于 pgwSlider 有一个 .getCurrentSlide() 方法,它返回当前幻灯片。我想做的是创建一个 var 并将 .getCurrentslide() 存储在其中。然后创建一个 if 语句,在每个语句中,应该执行 google map api。像这样:
var counter = pgwSlider.getCurrentSlide();
if(counter == 1){*Create the map to show uni address 1*}
else if(counter==2){*Create the map to show uni address 2"}
else if(counter == 3){And so on etc}
这就是我所拥有的:
<!DOCTYPE html>
<html lang="en">
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
<script src="gmaps.js"></script>
<script src="https://maps.googleapis.com/maps/api/js"></script>
<script src="pgwslideshow.min.js"></script>
<link rel="stylesheet" href="pgwslideshow.min.css">
</head>
<style>
#map{
width: 530px;
height:400px;
}
</style>
<body>
<ul class="pgwSlideshow">
<li>
<img src="http://3vxsjq3roj103wlhf71jhh7t.wpengine.netdna-cdn.com/wp-content/uploads/2014/09/computer-nerd.jpeg"
alt="Software Engineer" data-description="Average salary: £37k">
</li>
<li>
<img src="http://www.alphasoftware.com/blog/wp-content/uploads/2015/08/Full-stack-Mobile-App-Developer-Job-in-LA.jpg"
alt="Mobile Developer" data-description="Average salary: £33k">
</li>
<li>
<img src="http://waqas.club/wp-content/uploads/2014/11/web-developer-lahore.png"
alt="Web Developer" data-description="Average salary: £24k">
</li>
<li>
<img src="https://sourcemaking.com/files/sm/images/architect.jpg"
alt="Software Architect" data-description="£62k">
</li>
<li>
<img src="http://i2.cdn.turner.com/money/.element/img/1.0/sections/mag/moneymag/bestjobs/2010/snapshot/049_systems_engineer.ju.jpg"
alt="Systems Enginner" data-description="£40k">
</li>
</ul>
<div id="map">
</div>
<script>
$(document).ready(function(){
var mapCanvas = document.getElementById('map');
var mapOptions = {
center: new google.maps.LatLng(44.5403, -78.5463),
zoom: 8,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
var map = new google.maps.Map(mapCanvas, mapOptions);
$(".pgwSlideshow").pgwSlideshow({
transitionEffect:'fading',
autoSlide:true
});
var counter = pgwSlider.getCurrentSlide();
if(counter == 1){
var mapCanvas = document.getElementById('map');
var mapOptions = {
center: new google.maps.LatLng(51.508540, -0.128082),
zoom: 8,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
var map = new google.maps.Map(mapCanvas, mapOptions);
}else{
alert("This will be displayed for testing purposes.");
}
</script>
</body>
</html>
我的问题是它无法加载。好像要破页了。我的页面中还有其他插件,当我使用此方法时,其余插件不起作用。
编辑== 好吧,我设法通过将 var 和 if 语句放置在结束脚本标记上方,使其不会破坏我的页面并破坏我网站中的其余插件。但现在我的问题是 if 语句似乎没有运行。我尝试过设置像 (if counter ==2){alert("executed")} 这样的 if 条件,但当用户查看幻灯片中的第二张图像时,它似乎没有执行警报语句。
编辑2 == 所以我已经找到了问题的主要原因。根据 pgwSlider 文档,要使用这些方法,我首先需要通过编写以下内容来初始化 pgwslider 变量:
var pgwSlider = $('.pgwSlider').pgwSlider();
但我开始知道,在该代码之后编写的任何内容都不会被执行。我放置了一个简单的 if 语句,将 var 计数器初始化为 0,并在计数器等于 0(事实确实如此)时调用警报框来弹出。当我将 if 语句放在 pgwSlider 变量上方时,它会执行并弹出警报框。当我将它放在 pgwSlider var 下时,它不会被执行。这是为什么?
最佳答案
发生的情况是 counter
固定在 1
并且您的 if
语句不再继续进行。
您可以通过告诉 pgwSlideshow 在新幻灯片加载完成时触发一个事件来解决此问题。这样您就可以始终收听最新值并可以显示正确的 Google map 。
首先,您需要将 pgwSlideshow 分配给变量:
var Slideshow = $(".pgwSlideshow").pgwSlideshow({...
然后,添加一个 afterSlide
方法,并使用它来找出当前幻灯片是什么。将 pgwSlideshow 代码块替换为:
var slideshow = $(".pgwSlideshow").pgwSlideshow({
transitionEffect: 'fading',
autoSlide: true,
afterSlide: function(){
var counter = slideshow.getCurrentSlide();
console.log("counter number is: ", counter);
}
});
afterSlide
每次 pgwSlideshow 执行其操作时都会被调用。看起来这里还列出了很多其他内容:http://pgwjs.com/pgwslideshow/
在浏览器中右键单击 > 单击“检查元素”,输出将显示在控制台中。
最后,添加 if/else 逻辑:
var slideshow = $(".pgwSlideshow").pgwSlideshow({
transitionEffect: 'fading',
autoSlide: true,
afterSlide: function(){
var counter = slideshow.getCurrentSlide();
if (counter === 1){
console.log("this is number one!");
// add google map code for number one here
}
else
{
console.log("something else");
}
}
});
关于javascript - 无法调用 jquery 插件方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33947253/
为了让我的代码几乎完全用 Jquery 编写,我想用 Jquery 重写 AJAX 调用。 这是从网页到 Tomcat servlet 的调用。 我目前情况的类似代码: var http = new
我想使用 JNI 从 Java 调用 C 函数。在 C 函数中,我想创建一个 JVM 并调用一些 Java 对象。当我尝试创建 JVM 时,JNI_CreateJavaVM 返回 -1。 所以,我想知
环顾四周,我发现从 HTML 调用 Javascript 函数的最佳方法是将函数本身放在 HTML 中,而不是外部 Javascript 文件。所以我一直在网上四处寻找,找到了一些简短的教程,我可以根
我有这个组件: import {Component} from 'angular2/core'; import {UserServices} from '../services/UserService
我正在尝试用 C 实现一个简单的 OpenSSL 客户端/服务器模型,并且对 BIO_* 调用的使用感到好奇,与原始 SSL_* 调用相比,它允许一些不错的功能。 我对此比较陌生,所以我可能会完全错误
我正在处理有关异步调用的难题: 一个 JQuery 函数在用户点击时执行,然后调用一个 php 文件来检查用户输入是否与数据库中已有的信息重叠。如果是这样,则应提示用户确认是否要继续或取消,如果他单击
我有以下类(class)。 public Task { public static Task getInstance(String taskName) { return new
嘿,我正在构建一个小游戏,我正在通过制作一个数字 vector 来创建关卡,该数字 vector 通过枚举与 1-4 种颜色相关联。问题是循环(在 Simon::loadChallenge 中)我将颜
我有一个java spring boot api(数据接收器),客户端调用它来保存一些数据。一旦我完成了数据的持久化,我想进行另一个 api 调用(应该处理持久化的数据 - 数据聚合器),它应该自行异
首先,这涉及桌面应用程序而不是 ASP .Net 应用程序。 我已经为我的项目添加了一个 Web 引用,并构建了各种数据对象,例如 PayerInfo、Address 和 CreditCard。但问题
我如何告诉 FAKE 编译 .fs文件使用 fsc ? 解释如何传递参数的奖励积分,如 -a和 -target:dll . 编辑:我应该澄清一下,我正在尝试在没有 MSBuild/xbuild/.sl
我使用下划线模板配置了一个简单的主干模型和 View 。两个单独的 API 使用完全相同的配置。 API 1 按预期工作。 要重现该问题,请注释掉 API 1 的 URL,并取消注释 API 2 的
我不确定什么是更好的做法或更现实的做法。我希望从头开始创建目录系统,但不确定最佳方法是什么。 我想我在需要显示信息时使用对象,例如 info.php?id=100。有这样的代码用于显示 Game.cl
from datetime import timedelta class A: def __abs__(self): return -self class B1(A):
我在操作此生命游戏示例代码中的数组时遇到问题。 情况: “生命游戏”是约翰·康威发明的一种细胞自动化技术。它由一个细胞网格组成,这些细胞可以根据数学规则生存/死亡/繁殖。该网格中的活细胞和死细胞通过
如果我像这样调用 read() 来读取文件: unsigned char buf[512]; memset(buf, 0, sizeof(unsigned char) * 512); int fd;
我用 C 编写了一个简单的服务器,并希望调用它的功能与调用其他 C 守护程序的功能相同(例如使用 ./ftpd start 调用它并使用 ./ftpd stop 关闭该实例)。显然我遇到的问题是我不知
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
我希望能够从 cmd 在我的 Windows 10 计算机上调用 python3。 我已重新安装 Python3.7 以确保选择“添加到路径”选项,但仍无法调用 python3 并使 CMD 启动 P
我是一名优秀的程序员,十分优秀!