jQuery easyui layout布局自适应浏览器大小

http://www.loststop.com/wap/index-wap2.php?p=3725

首先解释一下标题的含义,当我们用jQuery easyui layout 进行布局的时候,可能会遇到这样一个问题,那就是当手工调整浏览器大小,或者最大化、还原窗口的时候,layout的某个区域不能填充因为浏览器扩大而产生的空白区域,这时候看起来就比较别扭了。当然了,如果你的layout是直接放在body标签上的,且没有嵌套的layout的话,是不会出现layout不能自适应大小的情况的。

当布局比较复杂,势必就会要layout嵌套起来使用,这时候出现的页面不能自适应大小的情况就让我不能忍受,这个问题困扰了我几天时间,好在有万能的网络,问题总会得到解决,下面就将自己这两天查资料以及自己实践的经验介绍给大家,希望对以后遇到同样问题的朋友有所帮助。但是此处并不做深入分析,因为我也不熟悉jQuery和easyui。

先写一个有嵌套的layout,父级基于body,包含north,center,west,east,south五个区域,子级layout基于父级的center区域,如果你打开页面的时候,浏览器不是最大化,然后手工调整浏览器大小,就会发现问题所在,点击此处查看演示

其实,layout继承自panel,而panel有个fit属性,只要设置为true,layout就能自适应父元素的大小而变化,所以只要加上fit=”true”基本就可以解决问题,点击此处查看演示,相对于不能自适应的情况,变动的代码只有下面一行:
[html]

[/html]
这种解决方案应该是最简单的了,不过在非IE浏览器下面,大家可能会发现,反复调整浏览器大小,特别是缩小浏览器的时候,子级的layout就会出现滚动条,一时半会儿也没查出是什么原因导致的。所以网上还有一种较为复杂的解决方案,那就是利用jQuery的resize事件对浏览器窗口监听,当浏览器被调整时重新设置某些页面元素大小,要自适应大小的话,只要设置成跟父元素同宽就可以了,下面是JS代码:
[javascript]
var settime = null;
function redraw(){
$(‘#wrap’).layout(‘resize’);
$(‘#subWrap’).layout(‘panel’, ‘north’).panel(‘resize’,{width:$(‘#subWrap’).width()});
$(‘#subWrap’).layout(‘panel’, ‘center’).panel(‘resize’,{width:$(‘#subWrap’).width()});
$(‘#subWrap’).layout(‘resize’);
}
$(function(){
$(window).resize(function(){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
});
var p1 = $(‘body’).layout(‘panel’,'west’).panel({
onCollapse:function(){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
},
onExpand:function(){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
},
onResize:function(width,height){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
}
});
var p2 = $(‘body’).layout(‘panel’,'east’).panel({
onCollapse:function(){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
},
onExpand:function(){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
},
onResize:function(width,height){
if(settime != null)
clearTimeout(settime);
settime=setTimeout(“redraw()”,100);
}
});
});
[/javascript]

当然了,用jQuery的resize监听对于这样的页面还是不够,因为当我,展开活收缩父级layout的west和east区域,或是是拉动west和est与center之间的split调整大小的时候,子级的layout依旧会出现不能自动填充的情况,所以对于这些事件,统统需要捕捉处理子级layout的布局问题,这也是我上面的js代码为何出了监听window的resize事件外还监听了其它几个事件的原因,相当麻烦?如果有更好的解决方案,欢迎大家提出来。最后调整好的页面演示在这里

2011年11月13号更新:

使用子级layout使用fit=’true’的属性后,基本可以使页面保持自适应,就是在非IE浏览器下面,拉伸浏览器后,再还原包含子级layout的region便会含有滚动条。为了解决这个滚动条问题使用了jquery的resize事件,其实在不必这么大费周折,只要让包含自己layout的region上使用overflow:hidden就可以了,这也算个折中而简单的解决方案吧。
演示页面看这里

在Vue.js中创建一个类似于EasyUI Layout自适应布局页面,你可以使用Element Plus这样的基于Vue的组件库,它提供了响应式的设计和灵活的栅格系统。以下是基本步骤: 1. **安装依赖**: 首先,你需要安装`element-plus`和`vue-router`,如果还没有安装的话: ``` npm install element-plus vue-router ``` 2. **引入并配置**: 在你的`main.js`或`setup()`文件中导入并配置Element Plus: ```javascript import { createApp } from 'vue'; import ElementPlus from 'element-plus'; import App from './App.vue'; // 引入国际化 import lang from 'element-plus/lib/locale/lang/en-US'; // 设置语言 ElementPlus.use(ElementPlus.I18n, { locale: lang, messages: { en-US }, }); const app = createApp(App); app.use(ElementPlus); // 其他路由配置... app.mount('#app'); ``` 3. **创建Layout组件**: 创建一个名为`Layout.vue`的组件,模拟EasyUI的两栏布局: ```html <template> <div class="layout"> <el-col :span="{ xs: 24, sm: 8, md: 6, lg: 4, xl: 3 }" class="left-col"> <!-- 左侧内容 --> <router-view name="left"></router-view> </el-col> <el-col :span="{ xs: 0, sm: 16, md: 18, lg: 20, xl: 19 }" class="right-col"> <!-- 右侧内容 --> <router-view name="right"></router-view> </el-col> </div> </template> <script> export default { name: "Layout", }; </script> ``` 4. **在App.vue中使用Layout**: 将`Layout`组件作为根组件,并使用`<router-view>`标签分隔左右两侧的内容: ```html <template> <Layout> <router-view></router-view> <!-- 这里会动态渲染匹配的子组件 --> </Layout> </template> ``` 5. **路由配置**: 使用Vue Router设置路由规则,确保它们映射到正确的`Layout`组件下的子视图。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值