gpt4 book ai didi

javascript - 无法调用 jquery 插件方法

转载 作者:行者123 更新时间:2023-11-27 23:38:09 25 4
gpt4 key购买 nike

所以我正在练习我的 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/

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