当前位置: 首页 > news >正文

实验4 Vue.js路由实验

Web前端开发技术实验报告

实验4 Vue.js路由实验

一、实验目的:

  1. 理解Vue路由及相关概念并掌握路由的编写与使用

二、实验要求:

  1. 掌握Vue.js路由的基本语法和相关插件、loader的安装与使用编写程序并调试,完成以下实验内容。
  2. 上交实验报告电子文档。文档包含源程序,以班级、学号后两位、姓名依次出现组成的字符串如“计算机20-1班01张三实验4” 标识。各班学委收齐本班本次实验后进行打包(打包文件为.rar或.zip类型),使用名称如“1班Web前端开发技术实验4”提交。

三、实验内容:

请使用Vue路由相关知识手动实现Tab栏切换案例,要求如下。

1、创建一个components/Message.vue组件,用来展示页面内容。

2、创建3个子路由,分别是“待付款”、“待发货”、“待收货”页面,在每个子路由页面单独写出相应的内容,页面效果如图1所示。

图1 实验题运行截图

四、实验过程中遇到的问题及解决手段:

1.报错截图如图e

                                                 图e

解决方法:原因是没有暴露Message组件,在Message组件中加上export default {

name:'Message'

       }即可

五、实验结果和代码

1.实验结果

              图1 实验运行截图

                     图2 实验运行截图

2.实验代码

components/Message.vue

<template>

    <div>

        <ul>

            <li>

                <a href="/message1">message001</a>&nbsp;&nbsp;

            </li>

            <li>

                <a href="/message2">message002</a>&nbsp;&nbsp;

            </li>

            <li>

                <a href="/message/3">message003</a>&nbsp;&nbsp;

            </li>

        </ul>

    </div>

</template>

<script>

    export default {

        name:'Message'

    }

</script>

components/Banner.vue

<template>

    <div class="col-xs-offset-2 col-xs-8">

        <div class="page-header"><h2>Vue Router Demo</h2></div>

    </div>

</template>

<script>

    export default {

        name:'Banner'

    }

</script>

page/About.vue

<template>

    <h2>我是About的内容</h2>

</template>

<script>

    export default {

        name:'About',

        /* beforeDestroy() {

            console.log('About组件即将被销毁了')

        },*/

        /* mounted() {

            console.log('About组件挂载完毕了',this)

            window.aboutRoute = this.$route

            window.aboutRouter = this.$router

        },  */

    }

</script>

page/Home.vue

<template>

    <div>

        <h2>Home组件内容</h2>

        <div>

            <ul class="nav nav-tabs">

                <li>

                    <router-link class="list-group-item" active-class="active" to="/home/news">News</router-link>

                </li>

                <li>

                    <router-link class="list-group-item" active-class="active" to="/home/message">Message</router-link>

                </li>

            </ul>

            <router-view></router-view>

        </div>

    </div>

</template>

<script>

    export default {

        name:'Home',

        /* beforeDestroy() {

            console.log('Home组件即将被销毁了')

        }, */

        /* mounted() {

            console.log('Home组件挂载完毕了',this)

            window.homeRoute = this.$route

            window.homeRouter = this.$router

        },  */

    }

</script>

page/New.vue

<template>

    <ul>

        <li>news001</li>

        <li>news002</li>

        <li>news003</li>

    </ul>

</template>

<script>

    export default {

        name:'News'

    }

</script>

router/index.js

import Vue from 'vue'

import VueRouter from 'vue-router'

import Home from '../views/obligation.vue'

Vue.use(VueRouter)

const routes = [

  {

    path: '/',

    name: 'home',

    component: Home

  },

  {

    path: '/about',

    name: 'about',

    component: () => import('../views/ToBeDelivered.vue')

  },

  {

    path: '/receive',

    name: 'receive',

    component: () => import('../views/receive.vue')

  }

]

const router = new VueRouter({

  routes

})

export default router

App.vue

<template>

  <div>

    <div class="row">

      <Banner/>

    </div>

    <div class="row">

      <div class="col-xs-2 col-xs-offset-2">

        <div class="list-group">

          <!-- 原始html中我们使用a标签实现页面的跳转 -->

          <!-- <a class="list-group-item active" href="./about.html">About</a> -->

          <!-- <a class="list-group-item" href="./home.html">Home</a> -->

          <!-- Vue中借助router-link标签实现路由的切换 -->

          <router-link class="list-group-item" active-class="active" to="/about">About</router-link>

          <router-link class="list-group-item" active-class="active" to="/home">Home</router-link>

        </div>

      </div>

      <div class="col-xs-6">

        <div class="panel">

          <div class="panel-body">

            <!-- 指定组件的呈现位置 -->

            <router-view></router-view>

          </div>

        </div>

      </div>

    </div>

  </div>

</template>

<script>

  import Banner from './components/Banner'

  export default {

    name:'App',

    components:{Banner}

  }

</script>

  • 本次实验的体会(结论):

通过这次实验我理解Vue路由及相关概念并掌握路由的编写与使用,同时明白了只有自己亲自动手去编写程序才能把书本的内容与实际结合起来,才能更容易的把知识牢记于心。在动手真正的去编程往往会发生各种各样的问题,如果不去实践就会永远堆积问题,停滞不前,就会落后。编程需要沉淀,不能急功近利,欲速则不达,花时间打好基础,基础不牢地动山摇。

相关文章:

  • Can通信流程
  • 【Linux网络-数据链路层】以太网(以太网帧格式|MAC地址+模拟一次性局域网通信+MTU)+ARP协议
  • 09 python函数(上)
  • UE学习记录part7
  • 免密登录远程服务器shell脚本
  • 【Linux】:守护进程化
  • 工具层handle_excel
  • Java-泛型总结
  • 蓝桥杯备考:奶牛晒衣服
  • Android NDK --- JNI从入门到基础的全面掌握 (上)
  • github上传本地文件到远程仓库(空仓库/已有文件的仓库)
  • python环境集成整理
  • Linux动态库和静态库
  • RAGFlow + LlamaIndex 本地知识库RAG增强架构与实现直播智能复盘
  • 【入门初级篇】布局类组件的使用(1)
  • 如何通过Python实现自动化任务:从入门到实践
  • 2025年 cocosCreator 1.8 定制 JavaScript 引擎
  • Web Component 教程(五):从 Lit-html 到 LitElement,简化组件开发
  • 用css绘制收银键盘
  • 实验三 内存管理
  • 观察|英国航母再次部署印太,“高桅行动”也是“高危行动”
  • 上海乐高乐园建设进入最后冲刺,开园限量纪念年卡将于5月开售
  • 4月份全国93个国家气象站日最高气温达到或突破极值
  • 五一期间上海景观照明开启重大活动模式,外滩不展演光影秀
  • 起底网红热敷贴“苗古金贴”:“传承人”系AI生成,“千年秘方”实为贴牌货
  • 伤者升至80人,伊朗港口爆炸源头或为“危险品和化学品仓库”