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

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


http://www.kler.cn/a/593222.html

相关文章:

  • 【AI论文】ReCamMaster:基于单视频的相机控制式生成渲染
  • 如何打造企业 DevOps 文化
  • LeetCode 第22~24题
  • Java学习------初识JVM体系结构
  • 【C++】 —— 笔试刷题day_6
  • 如何实现一个DNS
  • Lora 中 怎么 实现 矩阵压缩
  • 天翼云:Apache Doris + Iceberg 超大规模湖仓一体实践
  • 1-1 MATLAB深度极限学习机
  • Mac:JMeter 下载+安装+环境配置(图文详细讲解)
  • C#命令行参数用法
  • Python-docx库详解:轻松实现Word文档自动化生成与图片尺寸控制
  • 组播实验--IGMP、IGMP Snooping 及 PIM-DM 协议
  • 大语言模型(LLM)解析:从 GPT 到 DeepSeek(Transformer 结构、主流 LLM 的对比)
  • 在 STM32 的程序中,HAL_UART_Receive_IT 的调用位置
  • 以太坊节点间通信机制 DEVp2p 协议
  • DevEco Studio的使用
  • Unity 运行报错:InvalidOperationException: Insecure connection not allowed 的原因
  • 让 Google Play 成为助力 PC 游戏增长的最佳平台
  • k8s 配置imagePullSecrets仓库认证