Loading

22_路由介绍

路由的本质就是一种对应关系,比如说我们在url地址中输入我们要访问的url地址之后,浏览器要去请求这个url地址对应的资源。那么url地址和真实的资源之间就有一种对应的关系,就是路由。

路由分为前端路由和后端路由1).后端路由是由服务器端进行实现,并完成资源的分发2).前端路由是依靠hash值(锚链接)的变化进行实现

后端路由性能相对前端路由来说较低,所以,我们接下来主要学习的是前端路由前端路由的基本概念:根据不同的事件来显示不同的页面内容,即事件与事件处理函数之间的对应关系前端路由主要做的事情就是监听事件并分发执行事件处理函数

模拟路由案例:

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <meta http-equiv="X-UA-Compatible" content="ie=edge" />
  <title>Document</title>
  <!-- 导入 vue 文件 -->
  <script src="./lib/vue_2.5.22.js"></script>
</head>

<body>
  <!-- 被 vue 实例控制的 div 区域 -->
  <div id="app">
    <!-- 切换组件的超链接 -->
    <a href="#/zhuye">主页</a>
    <a href="#/keji">科技</a>
    <a href="#/caijing">财经</a>
    <a href="#/yule">娱乐</a>

    <!-- 根据 :is 属性指定的组件名称,把对应的组件渲染到 component 标签所在的位置 -->
    <!-- 可以把 component 标签当做是【组件的占位符】 -->
    <component :is="comName"></component>
  </div>

  <script>
    // #region 定义需要被切换的 4 个组件
    // 主页组件
    const zhuye = {
      template: '<h1>主页信息</h1>'
    }

    // 科技组件
    const keji = {
      template: '<h1>科技信息</h1>'
    }

    // 财经组件
    const caijing = {
      template: '<h1>财经信息</h1>'
    }

    // 娱乐组件
    const yule = {
      template: '<h1>娱乐信息</h1>'
    }
    // #endregion

    // #region vue 实例对象
    const vm = new Vue({
      el: '#app',
      data: {
        comName: 'zhuye'
      },
      // 注册私有组件
      components: {
        zhuye,
        keji,
        caijing,
        yule
      }
    })
    // #endregion

    // 监听 window 的 onhashchange 事件,根据获取到的最新的 hash 值,切换要显示的组件的名称
    window.onhashchange = function () {
      // 通过 location.hash 获取到最新的 hash 值
      console.log(location.hash);
      switch (location.hash.slice(1)) {
        case '/zhuye':
          vm.comName = 'zhuye'
          break
        case '/keji':
          vm.comName = 'keji'
          break
        case '/caijing':
          vm.comName = 'caijing'
          break
        case '/yule':
          vm.comName = 'yule'
          break
      }
    }
  </script>
</body>

</html>

 

posted @ 2022-08-21 22:00  1640808365  阅读(51)  评论(0编辑  收藏  举报