- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试构建一个简单的轮播,我知道有很多,但我更喜欢尝试找出答案。
这是我的轮播代码
<div class="amnavigation">
<div class="previous"><</div>
<ul>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
<li>icon</li>
</ul>
<div class="next">></div>
</div>
和CSS
.amnavigation {
height: 140px;
overflow: hidden;
display: flex;
height: 140px;
overflow: hidden;
display: flex;
max-width: 1000px;
margin: auto; }
.amnavigation ul li {
width: 140px;
height: 140px;
background: #999;
display: inline-block;
margin: 5px; }
我什至不知道从哪里开始以及使用什么功能。
我是否会将内部 ul 放置在父容器中,然后将该容器向左或向右移动 140px(或其他值)?
这是一个 fiddle
https://jsfiddle.net/L1v2uyxd/
非常感谢任何建议和耐心,因为我正在努力学习。
最佳答案
开始之前,需要考虑以下几点:
告诉浏览器将这些项目设置为无序列表的样式只是为了覆盖这些显示规则是没有意义的。使用<div>
愿景和<span>
s。甚至自定义元素(没有默认样式!)
决定您的轮播是一个合适的 slider 还是只是淡入/淡出项目。因为推子相当简单和直接(您只需设置动画 opacity
),我将假设它是一个 slider 。
在较大的屏幕上,您想要决定轮播是加框还是全宽。我个人认为全宽更自然,但有些人更喜欢盒装。我在这里把它填满了。
决定您需要有限还是无限 slider 。我假设它是一个looper。如果您不想这样做,只需删除 js
在幻灯片上附加/添加项目。
决定轨道是否具有可变高度。这很重要,因为您可能希望将其包装在额外高度的占位符中,以便可以分隔动画。当做像 slider 这样复杂的事情时,您希望动画方面尽可能保持整洁和干净。后来它们变得足够复杂。
现在,鉴于上述情况,请从 CSS
开始执行此操作。 。我已经按步骤进行了布局(基本设置、 slider 布局、动画)。 js
是在动画步骤中制作的。重点不是为您创建 slider ,而是引导您完成整个过程,以便您有一个示例。
/*
* go to CSS first, I'll send you back here when when it's time
*/
$(window).on('load', function(){
var slides = $('slider slide');
slides.each(function(){
// add 'before' and 'after' classes to all and `active` to first
$(this).addClass(
$(this).index() ? (
$(this).index() > (slides.length / 2) ?'before':'after'
) : 'active'
);
});
// place all `.before` slides before `.active` in DOM
$(slides.get().reverse()).each(function(){
if ($(this).is('.before')) {
$(this).prependTo($(this).parent());
}
});
})
function goNext() {
active = $('slider .active');
active.next().addClass('active').removeClass('after');
active.addClass('before').removeClass('active');
$('slider slide').first().removeClass('before').appendTo($('slider')).addClass('after')
}
function goPrev() {
active = $('slider .active');
active.prev().addClass('active').removeClass('before');
active.addClass('after').removeClass('active');
$('slider slide').last().removeClass('after').prependTo($('slider')).addClass('before')
}
body {
margin: 0;
text-align: center;
overflow-x: hidden;
}
[flex] {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
* {
box-sizing: border-box;
}
.content {
width: 80vw;
border: 1px solid #aaa;
text-align: initial;
margin: 0 auto;
min-height: 100vh;
}
.header {
min-height: 4rem;
text-align: center;
}
.rest-of-page {
padding: 1rem;
}
/* the above is just setup - ignore it
* here comes the juice.
* I used custom html elements so nothing would be default
* this way I needed to put in all required css attributes
* not relying on default styles by browser
*/
slider-container {
border: solid red;
border-width: 1px 0;
display: block;
width: 100vw;
/* left margin equal with half the difference
* between .content width and and viewport width:
*/
left: calc((100% - 100vw) / 2);
position: relative;
overflow: hidden;
min-height: 300px;
text-align: center;
}
slide[flex] {
position: absolute;
top: 1rem;
width: 80vw;
margin: 0 10vw;
height: calc(100% - 4rem);
background-color: #777;
color: white;
/* making sure slides don't render before everything loads */
display: none;
transition: transform .42s cubic-bezier(.4,0,.2,1);
}
slider-container .navigation {
position: absolute;
bottom: 0;
display: flex;
width: 100%;
justify-content: center;
}
slider-container .navigation > * {
width: 2rem;
height: 2rem;
border: 1px solid #242424;
margin: .5rem .25rem;
cursor: pointer;
}
/* all the layout is set so far - all items in place
* now we want to handle slider positions and animations
* disable the code below to see what we got so far
* this is where javascript steps in
*/
slider .active,
slider .before,
slider .after {
display: flex;
}
.before {
transform: translateX(-100vw);
}
.after {
transform: translateX(100vw);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="content">
<div class="header" flex>Header here</div>
<slider-container>
<slider>
<slide flex>icon 1</slide>
<slide flex>icon 2</slide>
<slide flex>icon 3</slide>
<slide flex>icon 4</slide>
<slide flex>icon 5</slide>
<slide flex>icon 6</slide>
<slide flex>icon 7</slide>
<slide flex>icon 8</slide>
<slide flex>icon 9</slide>
<slide flex>icon 10</slide>
<slide flex>icon 11</slide>
<slide flex>icon 12</slide>
<slide flex>icon 13</slide>
<slide flex>icon 14</slide>
<slide flex>icon 15</slide>
</slider>
<div class="navigation">
<div class="previous" flex onclick="javascript:goPrev()"><</div>
<div class="next" flex onclick="javascript:goNext()">></div>
</div>
</slider-container>
<div class="rest-of-page">Content here</div>
</div>
在此之后,您还需要一些东西:
我不是说:喜欢我。你应该建立你自己的。但我列出了如何做到这一点,希望它能有所帮助。我想这就是你问的原因。
关于jquery - 尝试编写一个简单的轮播,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42262810/
我在我的应用程序中使用开源 iCarousel 来实现轮播控件。我使用的轮播类型是 iCarouselTypeRotary 并且图像在这种类型中线性排列。但是,我需要图像像所附图像中的旋转木马一样带来
有人看过像这样的 jQuery 3D 轮播教程吗? http://web.enavu.com/demos/3dcarouselwip/ 没有给出来源,但想知道是否有人有关于如何连续圈出 DIV 并调整
我正在开发一种使用相机自动拍摄照片的软件。我希望用户能够设置照片间隔。我希望它看起来和工作起来像某种轮播。 它应该是这样的: 当我滑动(或用鼠标拖动)时,它应该沿给定方向移动: 所选项目应始终位于中间
抱歉问了个愚蠢的问题。我正在寻找带有按钮的旋转木马。我在 Bootply 上找到了这个模板,它完全符合我的要求。我在开发方面还很陌生。 也许有人可以向我解释如何摆脱侧面滚动效果。我知道我必须向 Jav
我正在寻找一个可以处理表单元素的 jQuery 轮播风格插件。 这是我需要做的。 我有三个表单元素:两个常规文本框和一个文本区域。还有两个按钮,上一个和下一个。 单击下一步按钮时,文本框/文本区域会切
我想构建一个包含两个图像轮播的网页,并且我希望能够将图像从一个轮播拖动到另一个。 我已经有了与 jCarouselLite 一起使用的图像轮播:它使用两个 UL 元素来指定轮播的图像。这工作得很好。
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我有这段代码可以从数据库中获取轮播图片或视频 $stmt = $con->prepare("SELECT * FROM `Main`"); $stmt->execut
我需要做这个 slider ,我找到了一些代码并尝试了,但没有一个完全是 LIKE THIS .bloco03 img {
我的任务是制作 3 张图片的轮播/幻灯片,只能在移动设备上使用。在桌面上,这些图像将显示在 3 列中。有没有一种方法可以自动转换,而无需我创建两个不同的模块并根据屏幕尺寸隐藏/显示一个? 最佳答案 你
我需要在卡片轮播上创建这种效果。我使用 Owl Carousel ,我给了元素框阴影。但我坚持制作不同位置元素的效果,例如 3d 或任何名称。 这是我想做的 http://www.awesomescr
我已经盯着这段相同的代码看了大约 4 个小时,并尝试观看一些不同的教程。问题是 slider 加载,有 3 张幻灯片的空间,但它只显示第一张幻灯片。 所有图像加载良好(在浏览器中验证),但轮播不会更改
我的 carouse/slider 有问题,我已经做到了,上一张和下一张图片每边各占 25%,中央图片占 50% 宽度。问题是我能够更改左右图像的背景,但我似乎无法将相同的颜色应用于中间图像。我已经尝
我想一次放 5 张图片作为页面的背景,即一张图片会显示一小段时间(比如每张一秒钟),然后重复它们。 我想知道有没有办法用 CSS 或 JS 来做到这一点? 预先感谢您的帮助! 最佳答案 这也许就是您正
我正在寻找一个支持触摸、可拖动、响应式 jQuery 滚动条/幻灯片/轮播/ slider ,用于显示水平可滚动项目列表(例如, eshop、最近将照片添加到数据库等)。 它看起来类似于苹果应用程序商
我想要夹层画廊的 Bootstrap 轮播。基本上;我正在拉入所有图像,并且我想要单行三张图像轮播。这是我非常讨厌的一段工作代码;我真的很想让它适用于无限数量的图像。 {% if page.d
大家好,我有这段代码,我一直在为我的网站编写代码。我正在尝试实现一个轮播功能,其中一张图片在另一张图片之后滑动。我遇到的问题是图片不会滑动。这是我的代码在欢迎 Controller 的索引页面中的样子
我正在构建一个简单的轮播,一旦用户水平滚动,事件点就会改变事件状态。但是,当我滚动时,jQuery 左侧位置返回值没有改变: li_left = li.position().left; // this
我正在尝试将文本放在轮播 slider 中的图像下方,但现在文本出现在图像上,而不是下方。 它看起来像这样: 但我希望它看起来像这样: 这是我的代码: final CarouselSlider aut
我在使用 boostrap carousel 时遇到 CSS 问题 我只是想让它更高,我已经尝试了几个 css 但没有任何效果。代码是在这个 jsFiddle 中,http://jsfiddle.ne
我是一名优秀的程序员,十分优秀!