LayUI之动态选项卡Tab&iframe使用

本文介绍了如何在LayUI中实现动态选项卡Tab和iframe的使用,包括静态布局、动态添加选项卡、设置选项卡名称、处理重复选项卡以及页面跳转。同时,还讲述了登录功能的实现,包括创建User实体类、DAO方法及优化Action。最后,展示了会议OA项目的页面翻新过程,涉及login.jsp、main.js、header.jsp等多个文件的更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、tab选项卡

二、登录功能实现

三、会议OA项目翻新


一、tab选项卡

步骤:

①、查找layui的选项卡页面布局代码--静态

将官网中任意一种选项卡的代码复制下来 ,粘贴到你要用的地方

  <div class="layui-body">
    <!-- 内容主体区域 -->
		<div class="layui-tab" lay-filter="demo"  lay-allowClose="true">
		  <ul class="layui-tab-title">
		    <li class="" lay-id="11">首页</li>
		  </ul>
		  <div class="layui-tab-content">
		    <div class="layui-tab-item layui-show">1</div>
		  </div>
		</div>
  </div>

 初步效果:

 ②、动态添加选项卡

方法:

<script type="text/javascript">
	let $,element;
	 layui.use(['jquery','element'],function(){
	 	$ = layui.jquery,
		element = layui.element;
		$.ajax({
			url:"${pageContext.request.contextPath}/permission.action?methodName=menus",
			dataType:'json',
			success:function(data){
				console.log(data)
				let html = '';
				$.each(data,function(i,n){
					html +='<li class="layui-nav-item layui-nav-itemed">';
					html +=' <a class="" href="javascript:;">'+data[i].text+'</a>';
					//判断当前一级节点是否存在节点
					if(data[i].hasChildren){
						html +=' <dl class="layui-nav-child">';
						let childern = data[i].children;
						$.each(childern,function(index,node){
							html+=' <dd><a href="javascript:;" onClick="openTab()">'+childern[index].text+'</a></dd>';
						})
						html +=' </dl>';
					}
					html +='</li>';
				});
				$("#menu").html(html);
			}
		})
	});
	 function openTab(){
		 element.tabAdd('demo', {
	        title: '新选项'+ (Math.random()*1000|0) //用于演示
	        ,content: '内容'+ (Math.random()*1000|0)
	        ,id: new Date().getTime() //实际使用一般是规定好的id,这里以时间戳模拟下
		 })
	 }
</script>

初步效果:

③、将选项卡名称换成菜单名

 js方法:

<script type="text/javascript">
	let $,element;
	 layui.use(['jquery','element'],function(){
	 	$ = layui.jquery,
		element = layui.element;
		$.ajax({
			url:"${pageContext.request.contextPath}/permission.action?methodName=menus",
			dataType:'json',
			success:function(data){
				console.log(data)
				let html = '';
				$.each(data,function(i,n){
					html +='<li class="layui-nav-item layui-nav-itemed">';
					html +=' <a class="" href="javascript:;">'+data[i].text+'</a>';
					//判断当前一级节点是否存在节点
					if(data[i].hasChildren){
						html +=' <dl class="layui-nav-child">';
						let childern = data[i].children;
						$.each(childern,function(index,node){
							html+=' <dd><a href="javascript:;" onClick="openTab(\''+childern[index].text+'\',\''+childern[index].attributes.self.url+'\',\''+childern[index].id+'\')">'+childern[index].text+'</a></dd>';
						})
						html +=' </dl>';
					}
					html +='</li>';
				});
				$("#menu").html(html);
			}
		})
	});
	 function openTab(){
		 element.tabAdd('demo', {
	        title: '新选项'+ (Math.random()*1000|0) //用于演示
	        ,content: '内容'+ (Math.random()*1000|0)
	        ,id: new Date().getTime() //实际使用一般是规定好的id,这里以时间戳模拟下
		 })
	 }
	/*  
	1、查找layui的选项卡页面布局代码-静态
	2、动态的添加选项卡
	3、将选项卡名称换成菜单名
	*/ 
	function openTab(title,url,id){
		 // 新增一个Tab项
	     element.tabAdd('demo', {
			title : title,//用于演示
			content : url,
			id : id
	     }) 
	} 
</script>

然后我们 PermissionDao这个类也进行改动

package com.zking.dao;

import java.util.ArrayList;
import java.util.List;

import com.zking.entity.Permission;
import com.zking.util.BaseDao;
import com.zking.util.BuildTree;
import com.zking.util.PageBean;
import com.zking.util.R;
import com.zking.util.TreeVo;

public class PermissionDao extends BaseDao<Permission>{
	
	//查询t_oa_permission表中的数据
	public List<Permission> executeQuery(Permission permission, PageBean pageBean) throws Exception {
		String sql="SELECT * from t_oa_permission";
		return super.executeQuery(sql, Permission.class, pageBean);
	}
	
	public List<TreeVo<Permission>> menus(Permission permission, PageBean pageBean) throws Exception {
		List<TreeVo<Permission>> trees=new ArrayList<TreeVo<Permission>>();
		//从数据库中拿到的菜单数据,此时数据都是平级的,不具备父子关系
		List<Permission> list = this.executeQuery(permission,
要实现LayUITab选项卡切换显示对应的页面,可以通过以下步骤: 1. 在HTML中创建Tab选项卡的结构,例如: ``` <div class="layui-tab"> <ul class="layui-tab-title"> <li class="layui-this">Tab1</li> <li>Tab2</li> <li>Tab3</li> </ul> <div class="layui-tab-content"> <div class="layui-tab-item layui-show"> <!-- Tab1对应的页面 --> <iframe src="tab1.html"></iframe> </div> <div class="layui-tab-item"> <!-- Tab2对应的页面 --> <iframe src="tab2.html"></iframe> </div> <div class="layui-tab-item"> <!-- Tab3对应的页面 --> <iframe src="tab3.html"></iframe> </div> </div> </div> ``` 2. 在JavaScript中使用LayUITab模块初始化Tab选项卡,例如: ``` layui.use('element', function(){ var element = layui.element; }); ``` 3. 在JavaScript中监听Tab选项卡的切换事件,并根据选项卡的索引切换显示对应的页面,例如: ``` element.on('tab', function(data){ if(data.index === 0){ // 切换到Tab1对应的页面 $('iframe[src="tab1.html"]').show().siblings().hide(); }else if(data.index === 1){ // 切换到Tab2对应的页面 $('iframe[src="tab2.html"]').show().siblings().hide(); }else if(data.index === 2){ // 切换到Tab3对应的页面 $('iframe[src="tab3.html"]').show().siblings().hide(); } }); ``` 其中,`data.index`表示选项卡的索引,从0开始计数。根据需要,可以在每个条件分支中使用AJAX请求获取对应的页面并显示在iframe中。注意,如果页面内容不是同源的,需要在iframe使用`sandbox`属性或者使用其他跨域请求的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值