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就能够了


这样就不会被盖住了
css

布局小技巧

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

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





缩小浏览器的效果。


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


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


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

改变浏览器的大小
vue

技巧2

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




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

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

ajax

技巧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布局用的。视频在这里就很少讲了。
iview

相关文章
相关标签/搜索