在DOJO边框容器中创建列

时间:2013-10-23 08:53:26

标签: css dojo

我想在我的页面中使用DOJO边框容器。我有这个样本。

    <script>
      require(["dijit/layout/BorderContainer", "dijit/layout/ContentPane","dojo/domReady!"], 
      function(BorderContainer, ContentPane){
      // create a BorderContainer as the top widget in the hierarchy
       var bc = new BorderContainer({
        style: "height: 300px; width: 500px;"
      });

// create a ContentPane as the center pane in the BorderContainer
var cp2 = new ContentPane({
    region: "center",
    content: "how are you?,this is a test content"
});
bc.addChild(cp2);

// put the top level widget into the document, and then call startup()
bc.placeAt(document.body);
bc.startup();
});
</script>

我想创建一些列,使其看起来像一个表。我怎样才能做到这一点?? 有人可以帮助我

1 个答案:

答案 0 :(得分:1)

根据您的标题,“在 Dojo BorderContainer中创建列”(强调我的),然后我会考虑dgridtable containergrid container在边框容器内部适合,取决于你试图用桌子完成什么。

如果表格用于数据,请考虑使用dgrid。如果表是用于表单布局,请考虑表容器。如果该表用于窗口小部件布局,请考虑网格容器。

这是使用网格容器的示例。 nbZones是列数。

<!DOCTYPE html>
<html>
    <head>
        <link href='//ajax.googleapis.com/ajax/libs/dojo/1.9.1/dijit/themes/claro/claro.css' rel='stylesheet' type='text/css' />
        <link href='//ajax.googleapis.com/ajax/libs/dojo/1.9.1/dojox/widget/Portlet/Portlet.css' rel='stylesheet' type='text/css' />
        <link href='//ajax.googleapis.com/ajax/libs/dojo/1.9.1/dojox/layout/resources/GridContainer.css' rel='stylesheet' type='text/css' />
        <script src='//ajax.googleapis.com/ajax/libs/dojo/1.9.1/dojo/dojo.js'></script>
        <style type='text/css'>
        html,body,#border { margin:0; width:100%; height:100%; }
        </style>
    </head>
    <body class='claro'>
        <div id='border' data-dojo-type='dijit/layout/BorderContainer'>
            <div id='grid'></div>
        </div>
        <script type='text/javascript'>
        require(
            ['dojo/ready', 'dojo/parser', 'dojox/layout/GridContainer', 'dojox/widget/Portlet'],
            function (ready, Parser, GridContainer, Portlet) {
                ready(function () {
                    Parser.parse().then(function () {
                        // create grid and put into border container
                        var grid = new GridContainer({nbZones:3}, 'grid');

                        // create cells and put into grid
                        for (var i = 0; i < 30; i++) {
                            grid.addChild(new Portlet({
                                closable:false,
                                content:'(' + Math.floor(i/3) + ', ' + (i%3) + ')'
                            }));
                        }
                        grid.startup();
                    });
                });
            }
        );
        </script>
    </body>
</html>