# 栅格布局 栅格布局容器根节点,使用grid-row与grid-col进行栅格布局。具体请参考[Grid-container](../reference/arkui-js/js-components-grid-container.md)。 ## 创建grid-container组件 在pages/index目录下的hml文件中创建一个grid-container组件,并添加[Grid-row](../reference/arkui-js/js-components-grid-row.md)子组件。 ```html
``` ```css /* xxx.css */ .container{ flex-direction: column; background-color: #F1F3F5; margin-top: 500px; justify-content: center; align-items: center; } ``` ![zh-cn_image_0000001226897009](figures/zh-cn_image_0000001226897009.png) > **说明:** > grid-container仅支持grid-row为子组件。 ## 调用方法 grid-container点击组件调用getColumns、getColumnWidth、getGutterWidth方法,返回栅格容器列数、column宽度及gutter宽度。长按调用getSizeType方法返回当前容器响应尺寸类型(xs|sm|md|lg)。 ```html
``` ```css /* xxx.css */ .container{ flex-direction: column; background-color: #F1F3F5; margin-top: 400px; justify-content: center; align-items: center; } ``` ```js // index.js import promptAction from '@ohos.promptAction'; export default { data:{ gutterWidth:'', columnWidth:'', columns:'', }, getColumns(){ this.$element('mygrid').getColumnWidth((result)=>{ this.columnWidth = result; }) this.$element('mygrid').getGutterWidth((result)=>{ this.gutterWidth = result; }) this.$element('mygrid').getColumns((result)=>{ this.columns= result; }) setTimeout(()=>{ promptAction.showToast({duration:5000,message:'columnWidth:'+this.columnWidth+',gutterWidth:'+ this.gutterWidth+',getColumns:'+this.columns}) }) }, getSizeType(){ this.$element('mygrid').getSizeType((result)=>{ promptAction.showToast({duration:2000,message:'get size type:'+result}) }) }, } ``` ![zh-cn_image_0000001227135613](figures/zh-cn_image_0000001227135613.gif) ## 添加grid-col 创建grid-container组件并添加grid-row,在grid-row组件内添加grid-col组件形成布局。 ```html
top
left
right
bottom
``` ```css /* xxx.css */ .container{ flex-direction: column; background-color: #F1F3F5; width: 100%; height: 100%; justify-content: center; align-items: center; } text{ color: white; font-size: 40px; } ``` ![zh-cn_image_0000001227135731](figures/zh-cn_image_0000001227135731.png) > **说明:** > grid-row仅支持grid-col为子组件,只能在grid-col组件中添加填充的内容。 ## 场景示例 本场景中循环输出list中的内容,创建出网格布局。进行下拉操时触发refresh(刷新页面)方法,这时会向list数组中添加一条数据并设置setTimeout(延迟触发),达到刷新请求数据的效果。 ```html
image{{item.id}}
``` ```css /* xxx.css */ .container{ flex-direction: column; background-color: #F1F3F5; width: 100%; height: 100%; } text{ color: #0a0aef; font-size: 60px; } ``` ```js // index.js import promptAction from '@ohos.promptAction'; export default { data:{ list:[ {src:'common/images/1.png',id:'1'}, {src:'common/images/2.png',id:'2'}, {src:'common/images/3.png',id:'3'} ], fresh:false }, refresh(e) { promptAction.showToast({ message: 'refreshing' }) var that = this; that.fresh = e.refreshing; setTimeout(function () { that.fresh = false; that.list.unshift({src: 'common/images/4.png',id:'4'}); promptAction.showToast({ message: 'succeed' }) }, 2000) } } ``` ![zh-cn_image_0000001263160403](figures/zh-cn_image_0000001263160403.gif)