- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我喜欢根据元素的位置向元素添加不同的类。
换句话说:我有一个包含六个元素的列表,这个列表的第三个元素的类是 active。事件元素之后的所有元素都应具有 slide-right
类。如果他们在它之前,他们应该有 slide-left
类。
这怎么可能?任何帮助将不胜感激。
$(document).ready(function() {
// configurator tabs
$('ul.tabs li').click(function() {
var tab_id = $(this).attr('data-tab');
var index = $(".tabs li").index(this);
if (index == 0)
{
$('#previous').addClass('disabled');
}
else if (index + 1 == $(".tabs li").length)
{
$('#next').addClass('disabled');
}
else
{
$('#next').removeClass('disabled');
$('#previous').removeClass('disabled');
}
$('ul.tabs li').removeClass('current');
$('.tab-content').removeClass('current');
$(this).addClass('current');
$("#" + tab_id).addClass('current');
})
// arrow navigation
$('#previous').click(function() {
if($('ul.tabs li.current').prev().length != 0 ){
$('ul.tabs li.current').removeClass('current').prev().addClass('current').click();
}
})
$('#next').click(function() {
if($('ul.tabs li.current').next().length != 0 ){
$('ul.tabs li.current').removeClass('current').next().addClass('current').click();
}
})
// keyboard navigation
$("body").keydown(function(e) {
if(e.keyCode == 37) { // left
if($('ul.tabs li.current').prev().length != 0 ){
$('ul.tabs li.current').removeClass('current').prev().addClass('current').click();
}
}
else if(e.keyCode == 39) { // right
if($('ul.tabs li.current').next().length != 0 ){
$('ul.tabs li.current').removeClass('current').next().addClass('current').click();
}
}
});
});
body {
margin-top: 100px;
font-family: 'Trebuchet MS', serif;
line-height: 1.6
}
.container {
width: 800px;
margin: 0 auto;
}
ul.tabs {
margin: 0px;
padding: 0px;
list-style: none;
}
ul.tabs li {
background: none;
color: #222;
display: inline-block;
padding: 10px 15px;
cursor: pointer;
}
ul.tabs li.current {
background: #ededed;
color: #222;
}
ul.arrownavigation {
list-style: none;
}
ul.arrownavigation li {
display: inline-block;
background: #111;
color: #fff;
padding: 10px;
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
ul.arrownavigation li:active {
background: #444;
}
ul.arrownavigation li.disabled {
opacity: 0.2;
pointer-events: none;
}
.tab-content {
display: none;
background: #ededed;
padding: 15px;
}
.tab-content.current {
display: inherit;
}
.tab-content.slide-left.current{
display: block;
opacity: 0;
transform: translateX(100px);
animation: slide-left 0.4s ease forwards;
}
@-webkit-keyframes slide-left {
to { transform: translateX(0); opacity: 1;}
}
@-moz-keyframes slide-left {
to { transform: translateX(0); opacity: 1;}
}
@-o-keyframes slide-left {
to { transform: translateX(0); opacity: 1;}
}
@keyframes slide-left {
to { transform: translateX(0); opacity: 1;}
}
.tab-content.slide-right.current{
display: block;
opacity: 0;
transform: translateX(-100px);
animation: slide-right 0.4s ease forwards;
}
@-webkit-keyframes slide-right {
to { transform: translateX(0); opacity: 1;}
}
@-moz-keyframes slide-right {
to { transform: translateX(0); opacity: 1;}
}
@-o-keyframes slide-right {
to { transform: translateX(0); opacity: 1;}
}
@keyframes slide-right {
to { transform: translateX(0); opacity: 1;}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="container">
<ul class="arrownavigation">
<li id="previous">Previous</li>
<li id="next">Next</li>
</ul>
<ul class="tabs">
<li class="tab-link current" data-tab="tab-1">Tab 1</li>
<li class="tab-link" data-tab="tab-2">Tab 2</li>
<li class="tab-link" data-tab="tab-3">Tab 3</li>
<li class="tab-link" data-tab="tab-4">Tab 4</li>
<li class="tab-link" data-tab="tab-5">Tab 5</li>
<li class="tab-link" data-tab="tab-6">Tab 6</li>
</ul>
<div id="tab-1" class="tab-content slide-left current">
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
</div>
<div id="tab-2" class="tab-content slide-left">
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
</div>
<div id="tab-3" class="tab-content slide-left">
Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
</div>
<div id="tab-4" class="tab-content slide-left">
Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
</div>
<div id="tab-5" class="tab-content slide-left">
Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
</div>
<div id="tab-6" class="tab-content slide-left">
Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
</div>
</div>
<!-- container -->
最佳答案
有点像
$('ul.tabs li.current').prevAll().removeClass('slide-right').addClass('slide-left')
关于javascript - 根据职位添加类(class),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39963018/
这个方法的作用是什么? URL aURL = new URL(myRemoteImages[position]); myRemoteImages 是一个字符串列表,有 4 个不同的变量。位置是 in
我对 Facebook API 的工作原理有初步的了解;我可以使用图形 API 来发布消息,但仅此而已。但是,我们也想发布工作。 Facebook 似乎有一个专门用于发布工作和接收申请的自定义 UI,
我正在尝试使用纯 JavaScript 编写一个简单的脚本,它会产生位置粘性效果。下面的代码对我来说效果很好。 var siteHeader = document.getElementById('si
我想在不同的机器上使用相同的作业。但是我不想每次都更改作业的配置。我可以将机器名称标签作为参数传递并在另一台机器上运行作业吗? (不同时)。 我想在将作业运行到我在配置中编写的脚本(批处理脚本)时传递
我有三个表。变化、讨论和对话。每个讨论都有一个对话集合。每个对话都是关于一个变化。然后对话在讨论中排名 1-10。你最终会得到这样的结果: Conversations{ [ id: 1,
我正在尝试使用 CodeIgniter 中内置的站点执行 cron 作业 - 我可以访问 CPanel cron 功能,任何人都可以建议使用 CPanel 设置 cron 作业的最佳方法吗? 我正在使
Sorry, the resource that you are trying to access is restricted. Please contact your LinkedIn Partne
我最近开始申请 .Net 职位。我目前在一家大型电信公司担任销售职务。我很晚才发现我喜欢编程,因此买了房子并做出了 promise ,这意味着上大学不是一个选择。 我想知道的是,作为一名自学者,找一份
下周我将面试一份使用 Spring 框架的 J2EE 工作。我在最近的几个职位中使用过 Spring,但我可能想复习一下。 应该注意什么,应该看哪些网站,刷一下? 最佳答案 我不会询问框架本身,但在哪
我是一名优秀的程序员,十分优秀!