javascript - 无法调用 jquery 插件方法

标签 javascript jquery

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

相关文章:

javascript - Bootstrap Popover 和 JQuery 在 'show' 之后不为 'hide'

javascript - 有人能帮我理解为什么这个 Javascript 除了 IE 之外在其他地方都可以工作吗?

javascript - 仍然可以在 Firefox 中使用 offcanvas 菜单水平滚动

javascript - 我的 Ajax 调用未定义

javascript - 表单数据和请求负载有什么区别?

javascript - Highcharts - 在面积图中如何对多个系列使用渐变颜色?

javascript - `new Date(Date.UTC)` 的奇怪行为

javascript - XSS:这如何安全?

javascript - PHP 文件从未从 jQuery 调用

javascript - 页面重新加载时,Vue getter 返回未定义