程序界面效果如下

Tab组件由多个TabItem组成,超出部分隐藏,可以通过左右按钮滑动显示出来

1、封装

// 初始化内容
$(function () {
J.JTab($(".jgui-tab")).init();
});
//Tab封装
(function($) {
J.JTab = function($p_selector) {
//初始化
init = function(p_options, p_datas, p_param) {
return $p_selector.each(function() {
$this=$(this);
$this.find(".jgui-tab-pre").unbind('click').click(function(event) {
var cur_left = $this.find(".jgui-tabcontent").scrollLeft(); //当前滚过的距离
$this.find(".jgui-tabcontent")
.stop()
.animate({ scrollLeft: -200 + cur_left }, 200);
});
$this.find(".jgui-tab-next").unbind('click').click(function(event) {
var cur_left = $this.find(".jgui-tabcontent").scrollLeft(); //当前滚过的距离
$this.find(".jgui-tabcontent")
.stop()
.animate({ scrollLeft: 200 + cur_left }, 200);
});
$this.find(".jgui-tabitem").unbind('click').click(function(event) {
$(this)
.siblings(".jgui-tabitem")
.removeClass("selected");
$(this).addClass("selected", 300);
});
$this.find(".jgui-tabitem .jgui-tab-close").unbind('click').click(function(event) {
$(this)
.closest(".jgui-tabitem")
.remove();
});
});
};
return {
init: init
};
};
})(J.$);

2、添加和显示方法,暂时实现功能,以后封装

//NavItem点击事件
var events = $("#menuaccordion").data("events");
events.onNavItemClick = function(p_obj, p_type) {
if (!$("#leftpanel").is(".unfold") && p_type == "navitem") {
//折叠状态展开
$("#leftpanel").width(300);
$("#centerpanel").css("left", "300px");
$("#mainlogo").html("JGUI DEMO");
J.Accordion($(p_obj).closest(".jgui-accordion")).unfold();
$("#leftpanel").toggleClass("unfold");
$("#folderbtn").toggleClass("icon-menu-unfold", "icon-menu-fold");
return false;
} else if (p_type == "navitemchildleaf") {
//点击了子项叶节点
$tabcontent=$("#pagetab .jgui-tabcontent");
var text = $(p_obj)
.find("a")
.html();
var $findTab = undefined;
$tabcontent
.find("span")
.each(function() {
var $this = $(this);
if ($this.html() == text) {
$findTab = $this;
return;
}
});
if ($findTab == undefined) {
var appentHtml =
'<a class="jgui-tabitem "><i class="anticon icon-codepen jgui-tab-item-icon"></i><span>' +
text +
'</span><i class=" anticon icon-close jgui-tab-close "></i></a>';
$("#pagetab .jgui-tabcontent").append(appentHtml);
J.JTab($("#pagetab")).init();
$findTab=$("#pagetab .jgui-tabcontent .jgui-tabitem:last-child");
}
var left=$tabcontent.scrollLeft();
var objleft=$findTab.offset().left-$tabcontent.offset().left-50;//50是左右按钮的宽度
      var objright=$findTab.offset().left-$tabcontent.offset().left-50+left+$findTab.width();//50是左右按钮的宽度
      var objwidth=$findTab.width();
console.log(left+','+objleft+','+$tabcontent.width());
if(objleft<0)//左边非可见区域
{
$tabcontent
.stop()
.animate({ scrollLeft: left+objleft-objwidth }, 200);
}else if(objright>$tabcontent.width())//右边非可见区域
{
$tabcontent
.stop()
.animate({ scrollLeft: left+(objright-$tabcontent.width())+objwidth }, 200);
}
$findTab.trigger("click");
}
return true;
};

代码一直完善中,详细代码请看
www.jgui.com

JGUI源码:Tab组件实现(9)的更多相关文章

  1. JGUI源码:组件及函数封装方法(7)

    以Accordion为例1.在base.js定义一个对象,这样可以和JQuery对象区分开,用户使用组件时比较清晰一点,也可以在这里引用多个库. var JGUI = J = { version : ...

  2. JGUI源码:从头开始,建一个自己的UI框架(1)

    开篇 1.JGUI是为了逼迫自己研究底层点的前端技术而做的框架,之前对web底层实现一直没有深入研究,有了技术瓶颈,痛定思痛从头研究, 2.虽然现在vue技术比较火,但还在发展阶段,暂时先使用JQue ...

  3. JGUI源码:鼠标中键滚动再次优化(5)

    //电脑端中键滚动事件 var mousewheel = getBrowserInfo() == "Firefox" ? "DOMMouseScroll" : ...

  4. JGUI源码:Accordion鼠标中键滚动和手机端滑动实现(2)

    本文是抽屉组件在PC端滚动鼠标中键.手机端滑动时,滚动数据列表实现方法,没有使用iscroll等第三方插件,支持火狐,谷歌,IE8+等浏览器. 演示在:www.jgui.com Github地址:ht ...

  5. tomcat8 源码分析 | 组件及启动过程

    tomcat 8 源码分析 ,本文主要讲解tomcat拥有哪些组件,容器,又是如何启动的 推荐访问我的个人网站,排版更好看呦: https://chenmingyu.top/tomcat-source ...

  6. Restrramework源码(包含组件)分析

    1.总体流程分析 rest_framework/view.py 请求通过url分发,触发as_view方法,该方法在ViewSetMixin类下 点进去查看as_view源码说明,可以看到它在正常情况 ...

  7. 修改elementUI源码新增组件/修改组件

    前言 经常我们会遇到elementUI组件库期间有5%达不到我们想要的需求,第一我们重新写组件,第二我们改源码 安装element https://github.com/ElemeFE/element ...

  8. Vue源码之组件化/生命周期(个人向)

    大致流程 具体流程 组件化 (createComponent) 构造⼦类构造函数 const baseCtor = context.$options._base // plain options ob ...

  9. React源码之组件的实现与首次渲染

    react: v15.0.0 本文讲 组件如何编译 以及 ReactDOM.render 的渲染过程. babel 的编译 babel 将 React JSX 编译成 JavaScript. 在 ba ...

随机推荐

  1. windows已激活,但提示:windows 7 内部版本7601 此windows副本不是正版

    把三个服务改为自动:

  2. Swift中 删除Array的元素对象

    Swift中Array的删除对象 在Swift中数组Array没有removeObject的方法 1.找到下标 let model_index = selectedArray.index(where: ...

  3. ES6的Map如何遍历

    projectMap.forEach(function (value, key, map) { //value和key就是map的key,value,map是map本身 });

  4. 练习 python之数据库增删改查

    # 文件存储时可以这样表示 ## id,name,age,phone,dept,enroll_date# 1,Alex Li,22,13651054608,IT,2013-04-01# 2,Jack ...

  5. Azure导出所有用户权限---powershell命令

      直接运行脚本         #requires -Version 3.0 -Modules AzureRM.Resourcesparam(    [switch]    $GroupRolesB ...

  6. jenkins自动化部署vue

    一.nodejs配置 首先加入nodejs插件 在配置里面配置这个插件 这样我们就能在自动构建发布的配置里看到nodejs的编译选项了 二.发布配置 首先新建一个自由风格的项目 然后配置构建保留天数和 ...

  7. 【转】分享JavaScript监听全部Ajax请求事件的方法

    若Ajax请求是由jQuery的$.ajax发起的,默认情况下可以使用 jQuery的Global Ajax Event Handlers监听到Ajax事件,然而我遇到的却是用原生JavaScript ...

  8. 第二章 Python基本图形绘制

    2.1 深入理解Python语言 Python语言是通用语言 Python语言是脚本语言 Python语言是开源语言 Python语言是跨平台语言 Python语言是多模型语言 Python的特点与优 ...

  9. 华为笔记HOSTS,便于访问云端存储

    # Copyright (c) - Microsoft Corp. # # This is a sample HOSTS file used by Microsoft TCP/IP for Windo ...

  10. 你注意到 .Net Framework 和 .Net Core 中使用 Session 的区别了吗?

    起因 在测试一个例子时发现的问题,这个示例实现的功能是刷新页面也能保持表格锁定列的状态,先看下页面的完成效果: 测试中发现,几乎相同的代码: 在 FineUIMvc(Net Framework)下没有 ...