多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
[TOC] >[success] # 响应式布局 本章主要对 **页面布局** 来进行一些学习,包括 **3** 个内容: 1. **vue-cli3.0** 中使用 **iview** 2. **布局组件** 的使用 3. **栅格组件** 实现 **响应式布局** >[success] ## vue-cli3.0 中使用 iview 接下来讲解如何在 **vue-cli3.0** 中如何引入 **iview** ,以及如何 **配置** 它的 **iview-loader** ,如何 **全局引入** 、 **按需引入 iview** 。之前很多开发者都使用过 **iview** ,那么在 **vue-cli3.0** 中对 **iview** 的 **配置有一些改变** ,主要是在 **iview-loader** 这的 **配置有改变** ,因为在 **vue-cli3.0** 生成的项目中,是 **没有 webpack 配置文件** 的 ,所以需要在 **vue.config.js** 里面去配置 **iview-loader** 。 1. **首先用 npm 安装 iview** 如果是 **iview 3.1.0** 版本,我们可以使用 **vue ui** 进行安装,步骤如下: 1. 执行指令 ~~~ vue ui ~~~ 2. 打开界面后选择要安装 **iview** 的项目 ![](https://img.kancloud.cn/a7/b2/a7b219d4b55d46c88a985df1dd23c4b6_1920x937.png) 3. 点击 **插件 > 添加插件** ![](https://img.kancloud.cn/57/64/576443503fbc8fb1647ec860e4e7ac92_1920x937.png) 4. 搜索插件进行安装 ![](https://img.kancloud.cn/74/84/748479874c1fae9e3e415b9391cf4105_1920x937.png) 5. 出现下面界面就进行安装了 ![](https://img.kancloud.cn/5c/60/5c60e739e3b49502a3fa1df1a9195bfb_1074x624.png) 6. 安装成功后会让勾选3个选项, 如下图: 选项1:**你想如何导入 ViewUI(iView)?** 默认是 **全局导入** 选项2:**你想覆盖 ViewUI(iView) 的 Less 变量吗?** 默认 **否** 选项3:**选择要加载的语言环境** 默认 **zh-CN** ![](https://img.kancloud.cn/6e/8b/6e8b6d0388508cbad6de51510b0dcf72_1920x937.png) 此时直接勾选下方 **完成安装按钮** 即可。 7. 也可以用**npm 指令安装方式** ~~~ npm install iview ~~~ 2. **全局引入iview** **全局引入介绍** : **一次性引入全部 iview 组件** 。 在项目入口文件 **src\main.js** 中需要配置如下: **src\main.js** ~~~ import Vue from 'vue' import iview from 'iview' // 引入iview import 'iview/dist/styles/iview.css' // 引入iview样式 Vue.use(iview) // iview作为插件,需要用Vue.use方法来引入 ~~~ 3. **按需引入** **按需引入介绍**: **iview** 中有很多 **组件** ,项目中有些 **组件** 可能用不到,如果使用 **全局引入** 的方式,就会 **增大了编译后的文件体积** ,所以可以使用 **按需引入** , 用哪个 **组件** ,就在 **全局里把它引入**,然后 **打包后的文件体积就会小很多** ,如果项目基本上用到所有组件,还是用**全局引入**。 1. 首先你需要 **安装一个 babel 插件** ~~~ npm install babel-plugin-import --save-dev ~~~ 2. 在 **vue-cli3.0** 生成的项目中,**babel** 的配置文件 **babel.config.js**,**默认配置** 是这样的: ~~~ module.exports = { presets: [ '@vue/app' ] } ~~~ 需要把刚刚安装的插件添加进去,添加后的内容如下: ~~~ module.exports = { presets: [ '@vue/app' ], 'plugins': [['import', { 'libraryName': 'iview', // 仓库名字 'libraryDirectory': 'src/components' // 仓库的文件夹 }]] } ~~~ 3. 接下来在 **main.js** 里,可以这样 **按需引入** : ~~~ import 'iview/dist/styles/iview.css' // iview的样式文件还是要引入的 import { Button, Table } from 'iview' // 用ES6的解构赋值,来按需引入使用的组件 Vue.component('Button', Button) // 注册组件,Vue.component('组件名字', 引进来的组件) ~~~ 4. **需要注意** 问题:在 **非template/render模式** 下,包括 **JSX** 写法中,**组件名** 要用 **分隔形式**,如 **DataPicker** 要写为 **data-picker** ,而对于 **iview** 中名称和 **原生HTML标签** 相同的 **组件**,需要加 **i-前缀** ,如 **Button** 要写成 **i-button**。 解决办法: **我们可以通过配置 iview-loader 来解决 Switch 在任何模式下都必须写为 i-switch ,Cirele要写为 i-cirele的问题。** 4. **vue-cli3.0中配置iview-loader** 1. 首先需要 **安装 iview-loader** ~~~ npm install iview-loader --save-dev ~~~ 2. 在 **vue.config.js** 中添加 **iview-loader** ~~~ const path = require('path') // 引入nodejs的path模块 const resolve = dir => path.join(__dirname, dir) // resolve方法用来加载路径 const BASE_URL = process.env.NODE_ENV === 'production' ? '/iview-admin/' : '/' // 判断当前为开发环境还是打包环境, '/'意思是代表指定在域名的根目录下,如果要指定到iview-admin下就这样写'/iview-admin/', production为生产坏境,development为开发环境 module.exports = { lintOnSave: false, // 取消每次保存时都进行一次' ESLint '检测 publicPath: BASE_URL, // 项目的基本路径,vuecli2.0时打包经常静态文件找不到,就是需要配置这个属性为'./' chainWebpack: config => { // 配置Webpack config.resolve.alias .set('@', resolve('src')) // 引入文件时候“ @ ”符号就代表src .set('_c', resolve('src/components')) // 引入组件文件夹中的文件就可以用“ _c ”代替src/components config.module // 添加iview-loader .rule('vue') .use('iview') .loader('iview-loader') .options({ prefix: false }) }, productionSourceMap: false, // 打包时不生成.map文件,会减少打包体积,同时加快打包速度 devServer: { // 跨域有2种解决方案: 1. 在后端的header中配置, 2. 使用devServer来配置代理解决跨域 proxy: 'http://localhost:3000/' // 这里写需要代理的URL,这里会告诉开发服务器,将任何未知请求匹配不到静态文件的请求,都代理到这个URL来满足跨域 } } ~~~ 在 **chainWebpack** 中 **链式调用** 方法来添加 **iview-loader** ,这样使用组件时候就可以不写 **i-前缀** 了。 5. **注意** 如果使用的是 **全局引入** ,不要配置这个 **babel插件** ,如果配置了 **babel插件** ,会在 **main.js** ,**报一个错误:import iview from 'iview' 它会报 iview 为 undefined** >[success] ## 布局组件的使用 使用 **iview** 中的 **layout组件** 来进行一个 **页面的总体布局** ,里面包括几个**组件**:**Header** 、 **Sider** 、 **Content** 、 **Footer** ,以及 **最外层** 的 **Layout** ,这 **5个组件** 。 >[success] ## 栅格组件实现响应式布局 使用 **iview** 的 **栅格组件(row、col)** ,来实现 **响应式布局** ,能够 **根据网页宽度实现不同的布局** 。 **实现效果图**: ![](https://img.kancloud.cn/52/8d/528d4cbc5249234f3ee1db091b903289_1920x937.png) **GIF动图**: 支持 **展开收起侧边栏** ,以及 **嵌套路由** 跳转页面 ![](https://img.kancloud.cn/4d/8b/4d8be99037f046173f6d5c92fe327bb0_1831x967.png) 1. **创建一个 layout.vue 文件** **src/views/layout.vue** ~~~ <template> <div class="layout-wrapper"> <Layout class="layout-outer"> <!-- 侧边栏 --> <Sider collapsible hide-trigger breakpoint="sm" v-model="collapsed"></Sider> <!-- 布局容器 --> <Layout> <!-- 顶部布局 --> <Header class="header-wrapper"> <Icon :class="triggerClasses" @click.native="handleCollapsed" type="md-menu" :size="32" /> </Header> <!-- 内容部分 --> <Content class="content-con"> <Card shadow class="page-card"> <!-- 做【嵌套路由】,用于展示子路由 --> <router-view /> </Card> </Content> </Layout> </Layout> </div> </template> <script> export default { data(){ return{ collapsed: false // 控制收缩变量 } }, computed: { triggerClasses(){ return [ 'trigger-icon', this.collapsed ? 'rotate' : '' ] } }, methods: { // 展开 / 收起 handleCollapsed(){ this.collapsed = !this.collapsed } } } </script> <style lang="scss"> .layout-wrapper,.layout-outer{ height: 100%; .header-wrapper{ background: #fff; box-shadow: 0 1px 1px 1px rgba($color: #000000, $alpha: .1); padding: 0 23px; .trigger-icon{ cursor: pointer; &.rotate{ transform: rotateZ(-90deg); transition: transform .3s ease; } } } .content-con{ padding: 10px; .page-card{ min-height: calc(100vh - 84px); } } } </style> ~~~ **嵌套路由** 页面,**Home.vue** **src/views/Home.vue** ~~~ <template> <div class="home"> <Row> <i-col></i-col> </Row> <Row :gutter="10"> <i-col span="12"></i-col> <i-col span="12"></i-col> </Row> <Row :gutter="10" class="blue"> <i-col :md="6" :sm="12"></i-col> <i-col :md="6" :sm="12"></i-col> <i-col :md="6" :sm="12"></i-col> <i-col :md="6" :sm="12"></i-col> </Row> </div> </template> <style lang="scss"> .home{ .ivu-col{ height: 50px; background: pink; margin-top: 10px; background-clip: content-box; } .blue{ .ivu-col{ background: blue; background-clip: content-box; } } } </style> ~~~ 2. **在路由中配置,把 layout 作为首页展示** **src/router/router.js** ~~~ import Home from '@/views/Home' import Layout from '@/views/layout' export default [ { // 把 Layout 作为首页展示 path: '/', name: 'home', component: Layout, children: [ // 创建嵌套路由 { path: 'home', component: Home } ] }, { path: '/login', name: 'login', component: () => import('@/views/login.vue'), }, { path: '*', // * 符号,代表匹配任何的路径 component: () => import('@/views/error_404.vue') } ] ~~~ 3. **调整页面高度** 现在的 **页面高度** 是 **0** ,如果想调整 **高度** ,需要调整 **app.vue** 页面的 **高度** **src/App.vue** ~~~ <template> <div id="app"> <router-view /> </div> </template> <script> export default { name: 'App' } </script> <style lang="scss"> html,body,#app{ height: 100%; } body{ margin: 0; } </style> ~~~