Vue 整合 Element UI 、路由嵌套和参数传递(五)

03-10 1254阅读

一、整合 Element UI

1.1 工程初始化

        使用管理员的模式进入 cmd 的命令行模式,创建一个名为 hello-vue 的工程,命令为:

# 1、目录切换
cd F:\idea_home\vue
# 2、项目的初始化,记得一路的 no
vue init webpack hello-vue

1.2 安装依赖

        我们需要安装 vue-router、element-ui、sass-loader 和 node-sass 四个插件

# 1、进入工程目录
cd hello-vue
# 2、安装 vue-router
npm install i vue-router@3.5.2 --save-dev
# 3、安装 element-ui
npm i element-ui -S
# 4、安装工程依赖
npm install
# 5、安装 NODE-SASS 加载器
cnpm install node-sass@4.12.0 --save-dev
# 6、按照 SASS-LOADER
cnpm install sass-loader@7.3.1 --save-dev
# 7、启动测试
npm run dev

1.3 npm 命令解释

        npm install moduleName:安装模块到项目目录下

        npm install -g moduleName:意思是将模块安装到全局,具体安装到磁盘哪个位置要看 npm config prefix 的位置。

        npm install -save moduleName:--save 的意思是将模块安装到项目目录下,并在 package 文件的 dependencies 节点写入依赖,-S 为该命令的缩写。

        npm install -save-dev moduleNam e:--save-dev 的意思是将模块安装到项目目录下,并在 package 文件的 devDependencies 节点写入依赖,-D 为该命令的缩写。

1.4 删除文件和目录

        删除掉生成的基础工程的配置文件,目录结构和文件内容如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

  
  


export default {
  name: 'App'
}


#app {
  font-family: 'Avenir', Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
import Vue from 'vue'
import App from './App'
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
  el: '#app',
  components: { App },
  template: ''
})

1.5 创建 views 组件

        在 src 目录下创建 views 文件夹来存储视图类的组件,在 views 文件夹下创建两个组件: Main.vue 组件来充当首页和 Login.vue 组件来充当登录页,内容如下所示:

  

首页

export default { name: "Main" }
  
    
      

欢迎登录

登录 请输入账号和密码 确 定 export default { name: "Login", data(){ return { form:{ username:'', password:'' }, rules:{ username:[ {required: true,message:'账号不可为空',trigger:'blur'} ], password:[ {required: true,message:'密码不可为空',trigger:'blur'} ] }, // 对话框的显示和隐藏 dialogVisible:false } }, methods:{ onSubmit(formName){ // 为表单绑定验证功能 this.$refs[formName].validate((valid) => { if(valid){ // 使用 vue-router 路由到指定页面,该方式称之为编程式导航 this.$router.push("/main"); }else{ this.dialogVisible =true; return false; } }); } } } .login-box { border: 1px solid #DCDFE6; width: 350px; margin: 180px auto; padding: 35px 35px 15px 35px; border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; box-shadow: 0 0 25px #909399; } .login-title{ text-align: center; margin:0 auto 40px auto; color:#303133; }

1.6 创建 router 路由        

        在 src 目录下创建 router 文件夹用于存储路由的配置信息,并在 router 文件夹里创建 index.js 来配置路由信息 ,内容如下所示:

import Vue from 'vue'
import Router from 'vue-router'
import Main from '../views/Main'
import Login from '../views/Login'
Vue.use(Router);
export default new Router({
  routes:[
    {
      path:'/main',
      component:Main
    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

1.7 修改 main.js 和App.vue 

        修改 main.js 文件,将路由信息配置进去

import Vue from 'vue'
import App from './App'
import router from './router'
// 官方规定的引入写法
import ElementUI from "element-ui";
import 'element-ui/lib/theme-chalk/index.css'
Vue.use(router);
Vue.use(ElementUI)
new Vue({
  el: '#app',
  router,
  render: h => h(App)
})

        修改 App.vue,添加路由的组件信息,内容如下所示:

  
    
    
    
  


export default {
  name: 'App'
}

1.8 测试

        启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

        在地址栏的后缀输入login 如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

        随便输入账号和密码,点击登录,即可跳转到首页,如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

1.9 总结 

        vue 整合 ElementUI,分为两步:

        第一步:安装依赖

npm i element-ui -S

        第二步:在 main.js 中写入以下内容:

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import App from './App.vue';
Vue.use(ElementUI);
new Vue({
  el: '#app',
  render: h => h(App)
});

二、路由嵌套

2.1 简介

        嵌套路由又称子路由,在实际应用中,通常由多层嵌套的组件组合而成。同样地,URL 中各段动态路径按某种结构对应嵌套的各层组件,说白了就是 vue 界面的部分内容发生变化,例如:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

2.2 创建 user 目录

        在 views 文件夹下新创建一个文件夹 user,并创建两个 vue 组件,List.vue 和 Profile.vue,内容如下所示:

  

用户列表

export default { name: "List" }
  

个人信息

export default { name: "Profile" }

2.3 修改 Main.vue

  
    
      
        
          
            用户管理
            
              
                个人信息
              
              
                用户列表
              
            
          
          
            内容管理
            
              分类管理
              内容列表
            
          
        
      
      
        
          
            
            
              个人信息
              退出登录
            
          
        
        
          
        
      
    
  


export default {
  name: "Main"
}


.el-header {
  background-color: yellow;
  color: blue;
  line-height: 60px;
}
.el-aside {
  color: #333;
}

2.4 修改 router 路由

        需要将新添加的两个 vue 组件配置到 router 的路由里面,即修改 router 文件夹下的 index.js,内容如下所示:

import Vue from 'vue'
import Router from 'vue-router'
import Main from '../views/Main'
import Login from '../views/Login'
import List from '../views/user/List'
import Profile from '../views/user/Profile'
Vue.use(Router);
export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        { path:'/user/list',component:List},
        { path:'/user/profile',component:Profile}
      ]
    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

2.5 测试

   启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

        在地址栏的后缀输入 main 如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

三、参数传递

3.1 修改 App.vue 

  
    
      
        
          
            用户管理
            
              
                
                个人信息
              
              
                用户列表
              
            
          
          
            内容管理
            
              分类管理
              内容列表
            
          
        
      
      
        
          
            
            
              个人信息
              退出登录
            
          
        
        
          
        
      
    
  


export default {
  name: "Main"
}


.el-header {
  background-color: yellow;
  color: blue;
  line-height: 60px;
}
.el-aside {
  color: #333;
}

3.2 修改 router 路由

        修改 router 文件夹下的 index.js,内容如下所示:

import Vue from 'vue'
import Router from 'vue-router'
import Main from '../views/Main'
import Login from '../views/Login'
import List from '../views/user/List'
import Profile from '../views/user/Profile'
Vue.use(Router);
export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        {
          path:'/user/list',
          component:List
        },
        {
          // 使用:id 进行参数接收
          path:'/user/profile/:id',
          name:'Profile222',
          component:Profile
        }
      ]
    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

3.3 修改 Profile.vue 文件

  
  
    

个人信息

{{$route.params.id}} export default { name: "Profile" }

3.4 测试

   启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

         在地址栏的后缀输入 main 如下所示:

Vue 整合 Element UI 、路由嵌套和参数传递(五)

Vue 整合 Element UI 、路由嵌套和参数传递(五)

3.5 第二种传参方式

        App.vue 内容不用改动,修改 router 目录下的 index.js 内容如下所示:

import Vue from 'vue'
import Router from 'vue-router'
import Main from '../views/Main'
import Login from '../views/Login'
import List from '../views/user/List'
import Profile from '../views/user/Profile'
Vue.use(Router);
export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        {
          path:'/user/list',
          component:List
        },
        {
          // 第一种方式:使用:id 进行参数接收
          path:'/user/profile/:id',
          name:'Profile222',
          component:Profile,
          // 第二种方式:使用 props 来接收参数
          props:true
        }
      ]
    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

        修改 Profile.vue 文件,内容如下所示:

  
  
    

个人信息

{{id}} export default { props: ['id'], name: "Profile" }
VPS购买请点击我

文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。

目录[+]