首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使dijit Accordionpane的高度动态化

如何使dijit Accordionpane的高度动态化
EN

Stack Overflow用户
提问于 2009-09-01 19:11:22
回答 4查看 6.3K关注 0票数 3

我不知道如何告诉accordioncontainer将其折叠面板的高度设置为auto,这样窗格的高度就会根据其内容而动态变化。

在下面的代码中,我向accordioncontainer添加了两个窗格。一个面板的高度为10px,另一个面板的高度为90px,但在这两种情况下,折叠面板的高度都计算为10px。看起来它总是取第一个的高度。

代码语言:javascript
复制
var accordionContainer = new dijit.layout.AccordionContainer({'id':'accContainer'}).placeAt("test");
var accordPane = new dijit.layout.ContentPane({"title": "test", "content":"<div style='height:10px'>sdfsdfsdf</div&gt;"});
var accordPane2 = new dijit.layout.ContentPane({"title": "test1", "content":"<div style='height:90px'>sdfsdfsdf</div>"});

accordionContainer.addChild(accordPane);
accordionContainer.addChild(accordPane2, 1);
accordPane.startup();
accordPane2.startup();
accordionContainer.startup();
accordionContainer.selectChild(accordPane2);

我使用的是dojo 1.3.2

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2009-09-08 21:10:03

我重写了dijit.layout.AccordionContainer的_getTargetHeight函数,高度总是返回'auto‘。滑动窗格的动画将不会正常工作,但它不是那么明显。

代码语言:javascript
复制
_getTargetHeight: function(/* Node */ node){
// summary:
//For the given node, returns the height that should be
//set to achieve our vertical space (subtract any padding
//we may have).
//This is used by the animations.

//var cs = dojo.getComputedStyle(node);
//return Math.max(this._verticalSpace - dojo._getPadBorderExtents(node, cs).h, 0);
return 'auto';
}
票数 2
EN

Stack Overflow用户

发布于 2009-09-04 12:22:02

这目前是不可能的。我写了一个博客/示例代码来解释为什么以及如何生成一组标题窗格,以扩展到它们的自然高度(而不是AccordionContainer容器的高度):

http://www.sitepen.com/blog/2008/10/21/quick-fixes-and-dojo-support/

它需要制作一个单独的TitleGroup小部件(自定义,博客中的代码),并将标题窗格放在里面。每个组件的行为都很像AccordionPane (具有title="“attributes、href="”加载功能等),并委托标题点击来管理同级组件的打开/关闭状态。

票数 3
EN

Stack Overflow用户

发布于 2009-09-04 03:11:53

尝试将Accordion Container本身的尺寸设置为足以容纳内容和必要的标题窗格的大小,例如

代码语言:javascript
复制
#accContainer{
  height: 120px;
  width: 200px;
}

容器上的startup()调用应该会为您启动子窗格。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1364140

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档