jQuery FadeIn 从左到右

Posted

技术标签:

【中文标题】jQuery FadeIn 从左到右【英文标题】:jQuery FadeIn from left to right 【发布时间】:2013-08-25 03:45:47 【问题描述】:

在我的 jQuery 中,我使用 ID 淡入一个 div。我希望淡入淡出从左到右“移动”。

到目前为止我的 sn-p:

$('#content').hide().fadeIn(1500);

谁能帮帮我?

谢谢!

【问题讨论】:

检查这个***.com/a/625192/1961192 【参考方案1】:
 $("#content").hide().show("slide",  direction: "left" , 1500);

【讨论】:

这似乎不起作用。未捕获的类型错误:k.easing[this.easing] 不是 init.run (jquery-3.4.1.min.js:2) 中的函数【参考方案2】:
$('#content').hide().fadeIn(function() 
    $('#content').animate(
        left: "80px"
    , 500); 
,1500).css('left' ,'0');

【讨论】:

【参考方案3】:

这将比听起来更难实现。如果您需要支持 IE8 等旧版浏览器,那就更难了。

我能想到的最实用的解决方案是使用与背景颜色相同的叠加元素,但使用渐变而不是纯色背景。

渐变将具有至少与被隐藏元素的大小相同的纯色,以便它看起来只是显示背景色,但会有一个隐藏部分超出元素的边界,并淡出在那个隐藏的部分透明。

然后是一个简单的例子,对叠加层进行动画处理,使渐变逐渐暴露出来,露出它背后的内容。

您根本不会使用普通的fadeIn() 函数。尽管它看起来像是横向淡入,但从技术角度来看,它就像将卡片从元素顶部滑下以显示它的效果。

在旧版本的 IE 中正确使用可能会很棘手,因为它使用专有的渐变功能。这在理论上应该是可能的,但是 IE8 的 filter 渐变有很多怪癖,如果你想像这样用它们做“聪明”的事情,你可能会发现它们。

我没有时间为你编写一个工作原型,但希望这能让你有足够的入门知识开始编写它。

【讨论】:

【参考方案4】:

这是一种快速简单的方式:

$("#ID").css("position":"relative","opacity": 0, "left":"+=100"); $("#ID").animate(left:0, opacity:1,2000);

您需要在 CSS 中指定 "opacity" :0, "position": "relative"(or Absolute) 或使用 JQuery 对其进行调整。就像我做过的那样。

这段代码移动对象 100px 从它的原始位置。然后在淡入时再次返回。

祝你好运!

【讨论】:

【参考方案5】:

//这就是你想要的

var $marginLefty =    $("#content"); // your selector here

$marginLefty.animate(
     height:'toggle',width:'toggle',
      marginLeft: parseInt($marginLefty.css('marginLeft'),10) == 0 ?
        $marginLefty.outerWidth() :
        0
    );

下面编辑的示例示例

<!DOCTYPE html>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script> 
$(document).ready(function()
  $("button").click(function()

var $marginLefty =    $("#content"); // your selector here

$marginLefty.animate(
     height:'toggle',width:'toggle',
      marginLeft: parseInt($marginLefty.css('marginLeft'),10) == 0 ?
        $marginLefty.outerWidth() :
        0
    );
  );
);
</script> 
</head>

<body>
<button>Start Animation</button>

<div id="content" style="background:#98bf21;height:100px;width:100px;position:absolute;">
</div>
</body>
</html>

【讨论】:

谢谢。一个问题:现在元素消失了。如何将元素来自“外部”的“动画”反转为内容? 简单。再次调用相同的函数。【参考方案6】:

您可以使用 CSS 过渡,结合其中的两个,宽度和不透明度。

-webkit-transition: width 500ms ease-in, opacity 1.5s ease-out;
-moz-transition: width 500ms ease-in, opacity 1.5s ease-out;
-o-transition: width 500ms ease-in, opacity 1.5s ease-out;
transition: width 500ms ease-in, opacity 1.5s ease-out;

要让内容保持在同一个地方,请看这个小提琴:http://jsfiddle.net/LLn311un/1/

【讨论】:

【参考方案7】:

我个人使用 animate.css 库

只需将 css 文件链接到您的页面:

&lt;link href= "https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css" rel="stylesheet"&gt;

您也可以下载文件并在本地提供。

然后只需将类“动画 slideInLeft”添加到您的元素。

$('#content').show().addClass('animated slideInLeft');

您可以在此处查看文档:https://animate.style/

【讨论】:

以上是关于jQuery FadeIn 从左到右的主要内容,如果未能解决你的问题,请参考以下文章

jQuery从左到右连续动画图像? [关闭]

jquery切换从左到右和向后滑动

jquery滑动侧边栏从左到右

无法让 div 在 jQuery 中从左到右设置动画

jQuery效果-----fadeIn()fadeOut()fadeToggle()fadeTo()

jquery fadeIn()方法 语法