Onmouseover恢复原始文本

时间:2013-01-16 20:25:16

标签: jquery html css onmouseover

所以我已经将onmouseover应用于Angelina Jolie图像,以便更改上面元素的文本,其中包含"一些示例文本"。我怎样才能使它恢复原始文本,其中包含"您的每日剂量的违禁品"。预先感谢您的帮助。 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);
});

3 个答案:

答案 0 :(得分:1)

你的小提琴工作得很好,你所拥有的就是旧的悬停,这会破坏新的影响。见:http://jsfiddle.net/VSCXy/10/(注意我删除了Angelina,因为她是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);
});

答案 1 :(得分: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);
    }
  );
});

答案 2 :(得分: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的内容以及所有需要的工作。