使用jQuery和图像映射在悬停上更改图像

时间:2012-08-12 19:05:32

标签: javascript jquery image hover jquery-hover

我有一张图片,我正在使用图片地图。根据地图将鼠标悬停在部分图像上时,我希望图像发生变化,我不知道如何使用jQuery进行此操作。这是我尝试过的代码:

HTML:

 <div class="img-center">
  <img src="img-src_off.jpg" usemap="#Map" class="feature-image" border="0" />
    <map name="Map" id="Map">
      <area shape="rect" coords="77,461,391,492" href="#" target="_blank"
            class="link-1" />
      <area shape="rect" coords="557,461,855,490" href="#" target="_blank" 
            class="link2" />
    </map>
 </div>

JS:

注意:这是我尝试过的JS,但是抛出了错误(下面列出的错误),我不知道现在要尝试什么。如果我能找到一个没有问题的代码,我就不必使用这段代码。

var $j = jQuery.noConflict();
  $j(document).ready(function() {
     $j.preLoadImages("img_src_01.jpg",
                     "img_src_02.jpg"
     ); 

     $j(".link1").hover(function(){
        this.src = this.src.replace("_off","_01");
        },
        function(){
        this.src = this.src.replace("_01","_off");
        }
     );

           $j(".link2").hover(function(){
        this.src = this.src.replace("_off","_02");
        },
        function(){
        this.src = this.src.replace("_02","_off");
        }
     ); 
   });

  (function(j$) {
    var cache = [];
    $j.preLoadImages = function() {
      var args_len = arguments.length;
      for (var i = args_len; i--;) {
        var cacheImage = document.createElement('img');
        cacheImage.src = arguments[i];
        cache.push(cacheImage);
      }
    }
  });

我看到的错误如下:

TypeError: this.src is undefined
[Break On This Error]   

this.src = this.src.replace("_off","_01");

(this error repeats itself on every hover)

这个错误:

TypeError: $j.preLoadImages is not a function
[Break On This Error]   

"img_src_02.jpg"

请回答时提供示例,因为我不是很流利的Javascript。

1 个答案:

答案 0 :(得分:1)

  

要编写jQuery插件,首先向jQuery.fn对象添加一个新的函数属性,其中属性的名称是插件的名称:

尝试以下方法:

(function($j) {
   $j.fn.preLoadImages = function() {
        //...
   }
})(jQuery);