所以我已经将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);
});
答案 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的内容以及所有需要的工作。