layui左右移动tab标签模版
{% load staticfiles %}
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<title>layout 后台大布局 - Layui</title>
<link rel="stylesheet" href="{% static 'layui/css/layui.css' %}">
<script type="text/javascript" src="{% static 'layui/layui.js' %}"></script>
<script type="text/javascript" src="{% static 'layui/jquery-3.4.1.min.js' %}"></script>
<style>
.layui-tab-title li {
border-bottom: 1px solid #e6e6e6;
}
</style>
</head>
<body class="layui-layout-body">
<div class="layui-layout layui-layout-admin">
<div class="layui-header">
<div class="layui-logo">layui 后台布局</div>
<!-- 头部区域(可配合layui已有的水平导航) -->
<ul class="layui-nav layui-layout-left">
<li class="layui-nav-item"><a href="">控制台</a></li>
<li class="layui-nav-item"><a href="">商品管理</a></li>
<li class="layui-nav-item"><a href="">用户</a></li>
<li class="layui-nav-item">
<a href="javascript:;">其它系统</a>
<dl class="layui-nav-child">
<dd><a href="">邮件管理</a></dd>
<dd><a href="">消息管理</a></dd>
<dd><a href="">授权管理</a></dd>
</dl>
</li>
</ul>
<ul class="layui-nav layui-layout-right">
<li class="layui-nav-item">
<a href="javascript:;">
<img src="http://t.cn/RCzsdCq" class="layui-nav-img">
贤心
</a>
<dl class="layui-nav-child">
<dd><a href="">基本资料</a></dd>
<dd><a href="">安全设置</a></dd>
</dl>
</li>
<li class="layui-nav-item"><a href="">退了</a></li>
</ul>
</div>
<div class="layui-side layui-bg-black">
<div class="layui-side-scroll">
<!-- 左侧导航区域(可配合layui已有的垂直导航) -->
<ul class="layui-nav layui-nav-tree" lay-filter="test">
<li class="layui-nav-item">
<a href="javascript:;">所有商品<span class="layui-nav-more"></span></a>
<dl class="layui-nav-child">
<dd><a href="javascript:;" data-id="ceshi" data-url="{% url 'happy:ceshi' %}">列表一</a></dd>
<dd><a href="javascript:;" data-id="ceshi2" data-url="{% url 'happy:ceshi' %}">列表二</a></dd>
<dd><a href="javascript:;">列表三</a></dd>
<dd><a href="">超链接</a></dd>
</dl>
</li>
<li class="layui-nav-item">
<a href="javascript:;">解决方案</a>
<dl class="layui-nav-child">
<dd><a href="javascript:;">列表一</a></dd>
<dd><a href="javascript:;">列表二</a></dd>
<dd><a href="">超链接</a></dd>
</dl>
</li>
<li class="layui-nav-item"><a href="">云市场</a></li>
<li class="layui-nav-item"><a href="">发布商品</a></li>
</ul>
</div>
</div>
<div class="layui-body">
<!-- 内容主体区域 -->
<div class="layadmin-pagetabs" style="position: relative;margin: 0px;padding: 0px;">
<div class="layui-icon layui-icon-prev" id="left_button" style="position: absolute;left: 0;background-color: red;width:40px;height:40px;text-align: center;line-height: 40px;color: #000000;"></div>
<div class="layui-icon layui-icon-next" id="right_button" style="position: absolute;right: 0;background-color: #ffffff;width:40px;height:40px;text-align: center;line-height: 40px;color: #000000;"></div>
<div class="layui-tab" lay-allowClose="true" lay-unauto="" lay-filter="test1"
style="left: 41px;position: relative;width:93%;overflow: hidden;">
<ul class="layui-tab-title" style="border-bottom: none;" >
<li class="layui-this" lay-id="111">文章列表1</li>
<li lay-id="222">发送信息2</li>
<li lay-id="333">权限分配3</li>
<li lay-id="444">审核4</li>
<li lay-id="555">订单管理5</li>
<li lay-id="333">权限分配6</li>
<li lay-id="444">审核7</li>
<li lay-id="555">订单管理8</li>
<li lay-id="333">权限分配9</li>
<li lay-id="444">审核10</li>
<li lay-id="555">订单管理11</li>
<li lay-id="333">权限分配12</li>
<li lay-id="444">审核13</li>
<li lay-id="555">订单管理14</li>
<li lay-id="333">权限分配15</li>
</ul>
<div class="layui-tab-content">
<div class="layui-tab-item layui-show">1</div>
<div class="layui-tab-item">2</div>
<div class="layui-tab-item">3</div>
<div class="layui-tab-item">4</div>
<div class="layui-tab-item">5</div>
<div class="layui-tab-item">6</div>
<div class="layui-tab-item">7</div>
<div class="layui-tab-item">8</div>
<div class="layui-tab-item">9</div>
<div class="layui-tab-item">10</div>
<div class="layui-tab-item">11</div>
<div class="layui-tab-item">12</div>
<div class="layui-tab-item">13</div>
<div class="layui-tab-item">14</div>
<div class="layui-tab-item">15</div>
</div>
</div>
</div>
</div>
<div class="layui-footer">
<!-- 底部固定区域 -->
layui.com - 底部固定区域
</div>
</div>
<script>
//JavaScript代码区域
layui.use(['element', 'jquery'], function () {
var element = layui.element;
var $ = layui.jquery;
var active = {
tabadd: function (url, id, name) {
element.tabAdd('test1', {
title: name
,
content: '<iframe data-frameid="' + id + '" scrolling="no" frameborder="0" src="' + url + '" style="width:100%;"></iframe>' //支持传入html
,
id: id
}
);
element.render('tab');
},
tab_change: function (data_id) {
location.hash = 'test1=' + data_id;
var layid = location.hash.replace(/^#test1=/, '');
element.tabChange('test1', layid);
}
};
//向右移动
var less_width=0;sum_total=0;less_sum_title=0;tab_click_list=[];
var total_list=[]; //记录菜单滚动宽度
$('#right_button').click(function () {
var sum_title=parseFloat($('.layui-tab-title').width());
//temp_data存上一次宽度
var temp_width=0;temp_data=0;one_total_list=0;
var temp_total=$('.layui-tab-title li[lay-id]').length;
for (var i=sum_total;i<temp_total;i++){
tab_click_list.push($('.layui-tab-title li').eq(i).attr("lay-id"));
temp_width = parseFloat($('.layui-tab-title li').eq(i).width())+30;
if (less_width > sum_title+less_sum_title) {
less_width = less_width - temp_data;
less_sum_title = less_width;
break;
} else {
//console.log('ok');
less_width += temp_width;
temp_data = temp_width;
sum_total=i;
}
}
if (sum_total < temp_total-1) {
//用列表记录菜单滚动所有宽度
total_list.push(-less_width);
console.log(total_list,'个数');
var css = {
"left": -less_width,
};
$('.layui-tab-title').css(css);
}
});
//向左移动
var left_sum_width = 0;less_total_list=0;less_one_total=2;
$('#left_button').click(function () {
var sum_title=parseFloat($('.layui-tab-title').width());
//temp_data存上一次宽度
var temp_width=0;temp_data=0;
var temp_total=$('.layui-tab-title li[lay-id]').length;
less_total_list=total_list.length-less_one_total;
ceshi = -total_list[less_total_list];
if (less_total_list >= 0) {
console.log(less_total_list, "less_total_list");
var css = {
"left": total_list[less_total_list]
};
$('.layui-tab-title').css(css);
less_one_total += 1;
} else if (less_total_list < 0) {
var css = {
"left": 0
};
$('.layui-tab-title').css(css);
//清除所有已赋值的变量
less_width=0;sum_total=0;less_sum_title=0;total_list=[];
}
});
//移动函数
function right_func(){
var less_width=0;sum_total=0;less_sum_title=0;
var total_list=[]; //记录菜单滚动宽度
var sum_title=parseFloat($('.layui-tab-title').width());
//temp_data存上一次宽度
var temp_width=0;temp_data=0;one_total_list=0;
var temp_total=$('.layui-tab-title li[lay-id]').length;
for (var i=sum_total;i<temp_total;i++){
console.log($('.layui-tab-title li').eq(i).attr("lay-id"),"lay-id");
temp_width = parseFloat($('.layui-tab-title li').eq(i).width())+30;
if (less_width > sum_title+less_sum_title) {
less_width = less_width - temp_data;
less_sum_title = less_width;
break;
} else {
//console.log('ok');
less_width += temp_width;
temp_data = temp_width;
sum_total=i;
}
}
if (sum_total < temp_total-1) {
//用列表记录菜单滚动所有宽度
total_list.push(-less_width);
console.log(total_list,'个数');
var css = {
"left": -less_width,
};
$('.layui-tab-title').css(css);
}
}
//监听导航点击
element.on('nav(test)', function (elem) {
//console.log(elem);
var data_click = $(this);
var url = elem.parent('dd').children('a').attr('data-url');
var data_id = elem.parent('dd').children('a').attr('data-id');
var text_ch = elem.parent('dd').children('a').text();
//只有获取到data_id才会执行,以防一级菜单点击后创建tab标签
if (data_id) {
//console.log('ok');
//console.log($('.layui-tab-title li[lay-id]'));
var isJudge = false;
var sum_width = 0;
$.each($('.layui-tab-title li[lay-id]'), function () {
//console.log($(this).width(), 'widhth');
sum_width += parseInt($(this).width());
//console.log($(this).attr("lay-id"));
//console.log(data_click.attr("data-id"));
if (($(this).attr("lay-id")) == (data_click.attr("data-id"))) {
isJudge = true;
}
});
//如果tab标签没有就添加并移到相应位子
if (!isJudge) {
active.tabadd(url, data_id, text_ch);
active.tab_change(data_id);
var tab_click_total=$('.layui-tab-title li[lay-id]').length;
for (var b=0;b<tab_click_total;b++){
//判断是否在tab标签内,并移动
var temp_b=$.inArray(data_id, tab_click_list);
if (temp_b==-1){
$('#right_button').click();
}else if(temp_b>0){
tab_click_list=[];
break;
}
}
console.log(tab_click_list);
isJudge = false;
}else {
active.tab_change(data_id);
tab_click_list=[];
var css = {
"left": 0
};
$('.layui-tab-title').css(css);
//清除所有已赋值的变量
less_width = 0;sum_total = 0;less_sum_title = 0; total_list = [];
var tab_click_total=$('.layui-tab-title li[lay-id]').length;
for (var b=0;b<tab_click_total;b++){
//判断是否在tab标签内,并移动
console.log(tab_click_list,"tab_click_list");
var temp_b=$.inArray(data_id, tab_click_list);
if (temp_b==-1){
$('#right_button').click();
}else if(temp_b>0){
tab_click_list=[];
break;
}
}
}
}
});
//监听Tab切换,以改变地址hash值
element.on('tab(test1)', function () {
location.hash = 'test1=' + this.getAttribute('lay-id');
console.log(location.hash);
});
var layid = location.hash.replace(/^#test1=/, '');
element.tabChange('test1', layid);
});
</script>
</body>
</html>
layui左右移动tab标签模版的更多相关文章
- layui的选项卡(tab)的问题
当页面打开单个tab时,操作栏显示: 当页面打开多个tab时,会发现操作栏与下面第一个tab显示的操作栏类型一样,并且操作栏的按钮无作用 第一个标签操作栏显示: 产生这样的原因:使用layui时,每个 ...
- JS特效之Tab标签切换
在我们平时浏览网站的时候,经常看到的特效有图片轮播.导航子菜单的隐藏.tab标签的切换等等.这段时间学习了JS后,开始要写出一些简单的特效.今天我也分享一个简单tab标签切换的例子.先附上代码: HT ...
- 支持自动切换的tab标签代码札记
html代码如下: <!-- tab标签代码begin --> <div class="tab1" id="tab1"> <div ...
- 多iframe使用tab标签方式添加、删除、切换的处理实例
紧接着上一篇随笔iframe的内容增高或缩减时设置其iframe的高度的处理方案 如果采用iframe来切换显示内容的方式来展现办公Web.那么需要解决几个问题 1.tab标签需要和显示的iframe ...
- 类似掌盟的Tab页 Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签 (转)
原博客地址 :http://blog.csdn.net/xiaanming/article/details/10766053 本文转载,记录学习用,如有需要,请到原作者网站查看(上面这个网址) 之前 ...
- jquery插件之tab标签页或滑动门
该插件乃本博客作者所写,目的在于提升作者的js能力,也给一些js菜鸟在使用插件时提供一些便利,老鸟就悠然地飞过吧. 此插件旨在实现目前较为流行的tab标签页或滑动门特效,在此插件中默认使用的是鼠标滑过 ...
- Jquery LigerUI框架学习(二)之Tree于Tab标签实现iframe功能
LigerUI框架Tree于Tab标签动态使用,当点击Tree后动态创建Tab标签,和通常用的iframe框架功能类似 Tree中的关键代码 //Tree初始化 $("#tree1" ...
- Android(java)学习笔记129:Tab标签的使用
1.案例1---TabProject (1)首先是main.xml文件: <?xml version="1.0" encoding="utf-8"?> ...
- 如何一行jquery代码写出tab标签页(链式操作)
啦啦!今天又学了一招,js写几十行的tab标签页jquery写一行就行啦,用到了链式操作!以下是代码: <!DOCTYPE html> <html lang="en&quo ...
随机推荐
- noip33
T1 第一个猎人死的轮数等于在1号猎人之前死的猎人数+1,如果当前这个人没死,那么他死在一号猎人之前的概率为 \(\frac{w_{i}}{w_{1}+w_{i}}\),因为每死一个就会造成1的贡献, ...
- SpringBoot整合ActiveMq实现Queue和Topic两种模式(看不懂你来打我)
目录 一.前言 二.ActiveMq的下载和使用 三.依赖准备 四.yml文件配置 五.配置Bean 六.创建生产者(Queue+Topic) 七.创建消费者(Topic模式下) 八.测试结果(Top ...
- Vamware没有卸载干净,导致无法重装,无法删除VMware旧版本,请与技术小组联系
原因:注册表没有清理干净!!! 问题:把文件夹清理了n遍,却无法重装VMware,报错如标题. 原因:相关注册表没删完. 解决办法: - 1.创建一个.txt文本: - 2.将下面的内容复制到.txt ...
- flutter实现文字超出最大宽度显示省略号
Container( width: 60, child: Text( '...', maxLines: 1, overflow: TextOverflow.ellipsis, ), ) 给Text外层 ...
- Spring详解(十)------spring 环境切换
软件开发过程一般涉及"开发 -> 测试 -> 部署上线"多个阶段,每个阶段的环境的配置参数会有不同,如数据源,文件路径等.为避免每次切换环境时都要进行参数配置等繁琐的操 ...
- HTML基本语法(慕课网学习笔记)
标题 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8& ...
- CompletionService简介、原理以及小案例
博客1:http://www.oschina.net/question/12_11255 博客2: CompletionService简介 CompletionService与ExecutorServ ...
- 关于Typora的使用
关于Typora的使用 今天介绍一个做笔记用的一款markdown编辑器,用了之后,顺利被圈粉: Typora,美观小众,可用性强! 和传统的markdown编辑器不一样,传统的markdown编辑器 ...
- Java程序设计学习笔记(五) — 多线程
时间:2016-4-15 09:56 --多线程(还有多核编程) 1.进程 进程是一个正在执行中的程序. 每一个进程执行都有一个执行顺序,该顺序是一个执行路径, ...
- C# 使用正则表达式替换PPT中的文本(附vb.net代码)
文本介绍如何在C#程序中使用正则表达式替换PPT幻灯片中的指定文本内容.具体操作步骤如下: 1. 在程序中引用Spire.Presentation.dll.两种方法可参考如下: (1)直接在程序中通过 ...