Hplus框架动态添加选项卡功能(扩展)
【摘要】 @[toc] 一、前言hplus框架确实是后端开发人员的福音,但是有很多功能没有实现,我根据网上大神的做法,实现了动态添加选项卡来打开新页面的功能。 二、代码如下: 1、随便写个按钮<div class="row"> <button class="btn btn-w-m btn-primary glyphicon glyphicon-plus" ...
@[toc]
一、前言
hplus框架确实是后端开发人员的福音,但是有很多功能没有实现,我根据网上大神的做法,实现了动态添加选项卡来打开新页面的功能。
二、代码如下:
1、随便写个按钮
<div class="row">
<button class="btn btn-w-m btn-primary glyphicon glyphicon-plus"
onclick="testTab()" id="btn_add">测试选项卡</button>
</div>
2、调用openTabPage()
function testTab() {
openTabPage("systemmanage/userInfoManage.jsp","个人信息管理");
}
function openTabPage(url, title) {
var wpd = $(window.parent.document);
var mainContent = wpd.find('.J_mainContent');
var thisIframe = mainContent.find("iframe[data-id='"+ url +"']");
var pageTabs = wpd.find('.J_menuTabs .page-tabs-content ')
pageTabs.find(".J_menuTab.active").removeClass("active");
mainContent.find("iframe").css("display", "none");
if(thisIframe.length > 0){ // 选项卡已打开
thisIframe.css("display", "inline");
pageTabs.find(".J_menuTab[data-id='"+ url +"']").addClass("active");
}else{
var menuItem = wpd.find("a.J_menuItem[href='"+ url +"']");
var dataIndex = title == undefined ? menuItem.attr("data-index") : '9999';
var _title = title == undefined ? menuItem.find('.nav-label').text() : title;
var iframe = '<iframe class="J_iframe" name="iframe'+ dataIndex +'" width="100%" height="100%" src="' + url + '" frameborder="0" data-id="' + url
+ '" seamless="" style="display: inline;"></iframe>';
pageTabs.append(
' <a href="javascript:;" class="J_menuTab active" data-id="'+url+'">' + _title + ' <i class="fa fa-times-circle"></i></a>');
mainContent.append(iframe);
//显示loading提示
var loading = top.layer.load();
mainContent.find('iframe:visible').load(function () {
//iframe加载完成后隐藏loading提示
top.layer.close(loading);
});
}
}
三、实现效果:
1、点击测试选项卡按钮
2、可以看到确实动态添加了一个选项卡并打开了新页面
四、感谢openTabPage函数源码的作者:
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)