iView 实战系列教程(21课时)_3.iView 实战教程之布局篇(一)

Grid布局

先了解一下iview的24栅格布局

清理一下App.vue


然后从iview的color里面获取推荐的背景色

我们先渲染栅格 24列,然后再讲解他是一个什么东西:


栅格外面row包裹的,里面是一个Col组件

使用v-for循环24列,类一列里面用Card


Grid布局就是将整个页面等宽度的划分为了24列,可以解决业务中大部分的布局问题。

只要col的span的值相加等于24就可以

我们写一个两列的布局,两列分别值为12,加起来就是24

如果说内容大于了24怎么办?

超出的部分自动换行了。

我们在列和列之间加空隙:


空隙为16宽度



Gutter的值建议是 16+8*n这样排列:就是8的倍数

Gutter是16或者32是比较好的


里面做一个嵌套,grid布局是可以无限嵌套的



某一列随着浏览器的滚动,能够固定在某一个位置:

展示的效果。我们希望右侧的部分随着浏览器的滚动,能够悬停


当前两部分都是随着滚动条 网上走的

现在我们就需要固定右边的列,
可以单独给右边的card加css position:fixs
但是我们尽可能少使用css打到我们想要的效果。

我们把他嵌套在affix标签内








顶部有个header的导航条。滚动的时候会吸在导航条的一个位置悬停




悬停会盖住导航条


导航条的高度是50 所以这里设置offset-top我们设置为50就可以了


这样就不会被盖住了

布局小技巧

24列布局实现垂直居中的效果
在modal中有个垂直居中的效果

弹窗是上下高度和左右的宽度都是一样的,并且随着拖动浏览器 也是会根据浏览器的高度和宽度的变化 依然垂直居中。





缩小浏览器的效果。


我们要实现的效果就是 随着改变浏览器的大小 头像和对号都居中


Row布局的flex布局,并且规定了居中的方式 都是中间


全屏的情况下 头像和对号已经和顶部有一定的距离了

改变浏览器的大小

技巧2

4+18=22后面空出来一列




现在要实现的效果是让第一列和第二列都居中显示。也就是最左边再空出来一列来。

Offset属性就是给这一列一个向右的一个位移!,位移的尺寸就是栅格的列数

技巧3

20分钟开始


规定左边18列 右边4列

左边18列应该是在左边的。但是由于18列左边是空的 所以把右边的四列顶到了左边。

当点击左边的填充内容的时候。18列有了内容显示了出来。

假设填充内容是提供过ajax去填充的话,也是需要几秒的时候闪动左边的18列。那么我们怎么解决这个默认没有内容 右边挤到左边了呢?

我们只需要在左边的内容加一个空的div标签就可以了。 当然也可以把这个空的div封装成一个组件。

查看默认的页面效果

这样做的好处,不会影响里面正文的内容,加一个1像素的空的元素去占位的话,不会影响你大体的内容。虽然看起来不是很优雅,但是却很简单的解决了这个闪动的问题。比较推荐用这种方法。

使用iview的gird布局 实现响应式布局


响应式布局:一套代码在不同的屏幕或者分辨率下、浏览器中预览的时候呈现出来的了效果是不一样的


重新初始化代码一下:


缩放到很小的时候:

在col上使用我们响应式的属性

左边当小于768的时候 让他占满一整行

当小于768的时候 占满一整行,当大于768的时候就是占6列

当小于768的时候占满一整行,当大于768的时候只占18列

我们打开F12的控制台 托送窗体,会显示宽度和高度

小于了768的情况:

当大于768的时候 还是各自 6:18的比例


当时宽屏的时候 左边留一个像素 右边留一个像素
当变为手机窄屏的时候

宽屏的时候 ,向右便宜一个列,6+16=22因为左右都便宜


小于768的时候 各自占满为24

还有其他用的比较少的 也可以实现相应式布局的,他们在flex布局用的。视频在这里就不多讲了。

posted @ 2019-07-16 16:44  高山-景行  阅读(2196)  评论(0编辑  收藏  举报