1

因此,我将 onmouseover 应用于安吉丽娜朱莉图像,以更改上面显示“一些示例文本”的元素的文本。我怎样才能让它恢复到原来的文本,上面写着“你每天服用的 Contrabang”。预先感谢您的帮助。Jsfiddle 在这里http://jsfiddle.net/cntra/VSCXy/9/

HTML:

<div class="columa">     
<div id="text-display">
<span id="targetElm">Your Daily Dose of Contrabang</span>
</div>

<div class="morphing-tinting">
<a href="#" class="changeTextClass" rel="targetElm|some sample text">
<span class="image-wrap" style="position:relative; left: 0px; top:0; display:inline-block;        
background:url
(http://www.howmuchdotheyweigh.com/wp-content/uploads/2011/02/angelina-jolie.jpg)
 no-repeat center center; width: 250px; height: 250px;">
</span></a>

CSS:

  #text-display
 {top:; position: relative;
 display:inline-block;padding:5px 10px; 
 font-family: sans-serif; font-weight:bold; font-size:50px; 
 color: white; text-align: center; line-height: 1.2em;margin:0px;   
 background-color:#E94F78;}


.morphing-tinting .image-wrap {
position: absolute;

-webkit-transition: 1s;
-moz-transition: 1s;
transition: 1s;

-webkit-border-radius: 30em;
-moz-border-radius: 30em;
border-radius: 30em;
}

.morphing-tinting .image-wrap:hover{
-webkit-border-radius: 30em;
-moz-border-radius: 30em;
border-radius: 30em;
}

JS

$('.changeTextClass').hover(function(){
    var elmData = $(this).attr('rel').split('|');
    $('#'+elmData[0]).text(elmData[1]);
});

    var elmData,origText;
$('.changeTextClass').hover(function(){
    elmData = $(this).attr('rel').split('|');
    origText = $('#'+elmData[0]).text();
    $('#'+elmData[0]).text(elmData[1]);
 }, function(){
    $('#'+elmData[0]).text(origText);
});
4

3 回答 3

1

你的小提琴工作得很好,你所拥有的只是旧的悬停正在破坏新的影响。请参阅:http: //jsfiddle.net/VSCXy/10/(注意我删除了安吉丽娜,因为她是 NSFW)

更新js部分:

var elmData,origText;
$('.changeTextClass').hover(function(){
    elmData = $(this).attr('rel').split('|');
    origText = $('#'+elmData[0]).text();
    $('#'+elmData[0]).text(elmData[1]);
 }, function(){
    $('#'+elmData[0]).text(origText);
});
于 2013-01-16T20:31:06.327 回答
1

您可以缓存原始文本并使用 handlerOut 回调将文本设置回原始文本。

.hover( handlerIn(eventObject), handlerOut(eventObject) )

因此,在准备好 DOM 时,我会这样做:

$(document).ready(function()
{
  var originalText = $('#targetElm').text();

  $('.changeTextClass').hover(
    function() {
      var elmData = $(this).attr('rel').split('|');
      $('#targetElm').text(elmData[1]);
    },
    function() {
      $('#targetElm').text(originalText);
    }
  );
});
于 2013-01-16T20:40:54.980 回答
0

将您的脚本更改为以下内容:

var elmData,origText;
$('.changeTextClass').hover(function(){
    elmData = $(this).attr('rel').split('|');
    origText = $('#targetElm').text();
    $('#'+elmData[0]).text(elmData[1]);
 }, function(){
    $('#'+elmData[0]).text(origText);
});

您删除了第一个悬停功能,然后在第二个中更改了 origText 的内容以及所有想要的工作。

于 2013-01-16T20:36:03.070 回答