“高级SPA项目构建与路由实现“

目录

  • 引言
    • 1. SPA项目构建
      • 1.1 安装vue-cli,webpack
      • 1.2 创建 Vue.js项目
      • 1.3 “一问一答”模式
      • 1.4 启动项目
    • 2. SPA项目完成路由
    • 3. 基于SPA项目完成嵌套路由
    • 总结

在这里插入图片描述

引言

在现代Web开发中,单页应用(SPA)已经成为一种流行的开发模式。SPA通过在前端使用JavaScript框架来实现页面的动态加载和更新,提供了更好的用户体验和性能。本文将介绍如何构建一个高级的SPA项目,并实现路由功能,以及如何在SPA项目中实现嵌套路由。

1. SPA项目构建

在构建SPA项目之前,我们需要选择一个合适的JavaScript框架。常见的选择包括React、Angular和Vue.js等。这里我们选择Vue.js作为示例框架。

1.1 安装vue-cli,webpack

npm install -g vue-cli
npm install webpack -g

1.2 创建 Vue.js项目

首先,我们需要安装Vue.js的脚手架工具,通过以下命令进行安装:
vue init webpack spa1

npm install -g @vue/cli
安装完成后,我们可以使用Vue CLI来创建一个新的Vue.js项目:

1.3 “一问一答”模式

  • 1.Project name:项目名,默认是输入时的那个名称spa1,直接回车
  • 2.Project description:项目描述,直接回车
  • 3.Author:作者,随便填或直接回车
  • 4.Vue build:选择题,一般选第一个
    4.1Runtime + Compiler: recommended for most users//运行加编译,官方推荐,就选它了
    4.2Runtime-only: about 6KB lighter min+gzip, but templates (or any Vue-specific HTML) are ONLY allowed in .vue files
    render functions are required elsewhere//仅运行时,已经有推荐了就选择第一个了
  • 5.Install vue-router:是否需要vue-router,Y选择使用,这样生成好的项目就会有相关的路由配置文件
  • 6.Use ESLint to lint your code:是否用ESLint来限制你的代码错误和风格。N 新手就不用了,但实际项目中一般都会使用,这样多人开发也能达到一致的语法
  • 7.Set up unit tests:是否安装单元测试 N
  • 8.Setup e2e tests with Nightwatch?:是否安装e2e测试 N
  • 9.Should we run npm install for you after the project has been created? (recommended) (Use arrow keys)

以我的为例 在这里插入图片描述

1.4 启动项目

cmd继续输入
cd spa1
npm run dev
在这里插入图片描述
网址复制浏览器即可打开

2. SPA项目完成路由

在SPA项目中,路由功能是必不可少的。路由可以实现页面之间的切换和导航,使用户可以在不刷新整个页面的情况下浏览不同的内容。
2.1 安装Vue路由器
About.vue

<template>
  <div>
    <router-link to="/AboutMe">点我试试</router-link>a
  <router-link to="/AboutWebsite">关于本站</router-link>asdsad
  <router-view></router-view>
  </div>
</template>



<script>
  export default {
    name: 'About',
    data(){
      return {
          msg:'123123'
      }
    }
  }
</script>

<style>
</style>

Home.vue

<template>
  <div class="home">网址首页</div>
</template>

<script>
  export default {
    name: 'Home',
    data(){
      return {
          msg:'123123'
      }
    }
  }
</script>

<style>
</style>

2.2 配置路由
在router目录下创建index.js文件,并进行路由配置。以下是一个简单的路由配置示例:

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Home from '@/components/Home'
import About from '@/components/About'
import AboutMe from '@/components/AboutMe'
import AboutWebsite from '@/components/AboutWebsite'

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/',
      name: 'Home',
      component: Home
    },
    {
      path: '/Home',
      name: 'Home',
      component: Home
    },
    {
      path: '/About',
      name: 'About',
      component: About
    }
  ]
})

2.3 在根组件中使用路由

<template>
  <div id="app">
    <!-- <img src="./assets/logo.png"> -->
<router-link to = "/Home">首页</router-link>
<router-link to = "/About">关于</router-link>

    <router-view/>
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>

<style>
#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;
}
</style>

在这里插入图片描述

3. 基于SPA项目完成嵌套路由

在一些复杂的SPA项目中,可能需要实现嵌套路由的功能。嵌套路由可以让我们在一个页面中加载多个子组件,并实现各个子组件之间的导航。
3.1 配置嵌套路由
在路由配置中,我们可以通过children选项来定义子路由。以下是一个示例:


export default new Router({
  routes: [
    {
      path: '/',
      name: 'Home',
      component: Home
    },
    {
      path: '/Home',
      name: 'Home',
      component: Home
    },
    {
      path: '/About',
      name: 'About',
      component: About,
      children:[
        {
          path: '/AboutMe',
          name: 'AboutMe',
          component: AboutMe
        },
        {
          path: '/AboutWebsite',
          name: 'AboutWebsite',
          component: AboutWebsite
        }
      ]
    }
  ]
})

3.2 在父组件中使用嵌套路由
在父组件中,我们需要使用组件来显示子路由对应的组件。以下是一个示例:

<template>
  <div>
    <router-link to="/AboutMe">点我试试</router-link>a
  <router-link to="/AboutWebsite">关于本站</router-link>asdsad
  <router-view></router-view>
  </div>
</template>



<script>
  export default {
    name: 'About',
    data(){
      return {
          msg:'123123'
      }
    }
  }
</script>

<style>
</style>

AboutMe

<template>
 <div>工卡就感觉爱国可能afaf</div>
</template>


<script>
  export default {
    name: 'AboutMe',
    data(){
      return {
          msg:'123123'
      }
    }
  }
</script>

<style>
</style>

AboutWebsite

<template>
 <div>上海,nalaglagkjagga</div>
</template>



<script>
  export default {
    name: 'AboutWebsite',
    data(){
      return {
          msg:'123123'
      }
    }
  }
</script>

<style>
</style>

在这里插入图片描述

总结

本文介绍了如何构建一个高级的SPA项目,并实现路由功能和嵌套路由功能。通过合理的项目结构和路由配置,我们可以更好地组织和管理SPA项目的代码,提供更好的用户体验和开发效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/344082.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

8 容器化微服务

文章目录 DockerSpring Boot和Buildpacks在Docker中运行系统Docker化微服务Docker化前端Docker化配置导入器Docker Compose使用Docker扩展系统共享Docker镜像小结 前面的文章&#xff1a; 1、1 一个测试驱动的Spring Boot应用程序开发 2、2 使用React构造前端应用 3、3 试驱动的…

RabbitMQ系列之交换机的使用

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是君易--鑨&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的博客专栏《RabbitMQ系列之交换机的使用》。&#x1f3af;&…

大白话解析LevelDB 3: SST Compaction

SST Compaction SST Compaction 什么是Compact SST什么时候触发Compact SST 第一处 读取 Key 的时候第二处 使用迭代器遍历数据库时第三处 写入 Key 时第四处 刚打开数据库时 如何进行Compact SST 计算Compaction范围进行Compaction 创建一个迭代器用于读取Compaction范围内的…

【linux】Debian挂起和休眠

一、挂起和休眠 在Debian桌面系统中&#xff0c;挂起和休眠是两种不同的状态&#xff0c;它们之间有一些区别。 挂起&#xff08;Suspend&#xff09;是将当前系统的状态保存到RAM&#xff08;内存&#xff09;中&#xff0c;然后关闭所有硬件设备&#xff0c;除了RAM之外。在…

(2)(2.4) CRSF/ELRS Telemetry

文章目录 前言 1 ArduPilot 参数编辑器 前言 &#xff01;Note ELRS&#xff08;ExpressLRS&#xff09;遥控系统使用穿越火线协议&#xff0c;连接方式类似。不过&#xff0c;它不像穿越火线那样提供双向遥测。 TBS CRSF 接收机与 ArduPilot 的接口中包含遥测和遥控信息。…

输入单词需要的最少按键次数 I

题目链接 输入单词需要的最少按键次数 I 题目描述 注意点 1 < word.length < 26word 仅由小写英文字母组成word 中的所有字母互不相同 解答思路 因为word 中的所有字母互不相同&#xff0c;可以以任意8个字符为一组&#xff0c;第一组每个字符需要按键一次&#xff…

服务器的异步通信——RabbitMQ

目录 一、同步通信 VS 异步通信 二、MQ——消息队列 RabbitMQ RabbitMQ安装 RabbitMQ的整体架构 常见消息模型 基本消息队列&#xff08;BasicQueue&#xff09; 工作消息队列&#xff08;WorkQueue&#xff09; 发布、订阅&#xff08;Publish、Subscribe&#xff0…

C#,生成图片的指定尺寸缩略图的源代码

编程的时候经常用到图像的缩略图。 本文发布一个用于生成指定尺寸的缩略图的简单方法。 1 文本格式 private void button1_Click(object sender, EventArgs e) { CreateThumbnail("demo.jpg", "demo_thumb.jpg", 128, 128); } private void CreateTh…

基于QEMU的vexpress-a9的初始化代码运行(一)

这个part是想详细走读一下用qemu运行kernel的最初始代码&#xff0c;也就是使用qemu运行kernel代码的详细逻辑&#xff0c;从qemu加载根目录下vmlinux镜像的逻辑&#xff0c;也就是运行arch/arm/kernel/head.S的整个过程&#xff0c;直到跳转到start_kernel&#xff0c;使用的k…

IT大侦“碳”:Concept Luna向循环设计持续演进

今天聊点轻松的话题。上个月&#xff0c;小编用来吃饭的家伙开始闹罢工&#xff0c;笔记本的触控和键盘突然没了反应&#xff0c;电脑虽然还能打开&#xff0c;但嗡嗡直叫的风扇让我意识到这件事并不简单。 你问我为什么电脑会出问题&#xff1f;好吧&#xff0c;那我得先搞清楚…

领势 跨越|美创科技数据安全管理平台2023年度回顾

领势 跨越 数据安全管理平台的2023 以数字化安全平台为基础的数据安全体系是未来安全建设的重要方向。 研究咨询机构IDC指出&#xff1a;未来&#xff0c;数据安全基础设施管理平台将逐步发展成为各组织数据安全建设的基础设施。 Gartner《中国数据安全治理解析》预测&…

141:vue+leaflet 利用高德逆地理编码,点击地图标记marker,popup地址信息

第141个 点击查看专栏目录 本示例的目的是介绍演示如何在vue+leaflet中利用高德逆地理编码,点击地图标记marker,popup地址信息 。主要利用高德地图的api将坐标转化为地址,然后在点击的位置,弹出弹窗,在里面显示出地址信息。 直接复制下面的 vue+leaflet源代码,操作2分钟…

cad二次开发autolisp(二)

目录 一、选择集1.1 选择集的创建1.2 选择集的编辑1.3 操作选择集 二、命令行设置对话框2.1 设置图层2.2 加载线型2.3 设置字体样式2.4 设置标注样式&#xff08;了解即可&#xff09; 三、符号表3.1 简介3.2 符号表查找3.2 符号表删改增 一、选择集 定义&#xff1a;批量选择…

【数据结构与算法】4.自主实现单链表的增删查改

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ &#x1f64f;小杨水平有限&#xff0c;欢迎各位大佬指点&…

在SpringBoot中基于CanvasLabel的地震基础信息展示实践

目录 前言 一、数据库设计 1、数据库设计 2、sql脚本 3、数据记录 二、SpringBoot后台设计与实现 1、Mapper访问层及实体定义 2、Service层实现 3、控制层实现 三、地震信息展示 1、展示数据接入 2、最终效果 总结 前言 在上一篇博客中&#xff0c;对于在Leafle…

直播录屏工具哪家强?让你的直播更精彩!

随着网络技术的不断发展&#xff0c;直播行业逐渐兴起。无论是游戏直播、教育直播还是娱乐直播&#xff0c;人们都希望能够记录这些精彩瞬间。因此&#xff0c;一款好用的直播录屏工具显得尤为重要。本文将详细介绍两款流行的直播录屏工具&#xff0c;通过这些工具&#xff0c;…

亚马逊、eBay、TikTok等平台的综合运营实用工具分享!

亚马逊、eBay等电商平台为卖家提供了广阔的销售机会&#xff0c;但同时也带来了运营管理的挑战。为了提高运营效率和销售业绩&#xff0c;卖家需要借助一些实用工具。本文将介绍一些在亚马逊、eBay等平台上综合运营中非常有用的工具&#xff0c;帮助卖家更高效地管理店铺&#…

flutter底层架构初探

本文出处&#xff1a;​​​​​​​​​​​​​Flutter 中文开发者网站 架构 embedder嵌入层 提供程序入口&#xff08;其他原生应用也采用此方式&#xff09;&#xff0c;程序由此和底层操作系统协调&#xff08;surface渲染、辅助功能和输入服务&#xff0c;管理事件循环…

HTTP3/QUIC 性能测试与配套组件

背景 最近一年很多关于QUIC的文章层出&#xff0c;但是发现一个问题&#xff0c;这些文章都是在介绍QUIC或HTTP3是怎样的一个东西&#xff0c;以及它的优点和机制&#xff0c;将它夸的近乎上天了。然而有心的人估计会亲手做一些测试&#xff0c;就会发现这个被捧上天的东西性能…

如何预防服务器IP被劫持,危害有什么?

服务器IP被劫持是一种严重的网络安全问题&#xff0c;攻击者通过篡改服务器的IP地址&#xff0c;将网络流量重定向到恶意服务器或网站&#xff0c;导致用户无法正常访问目标服务器&#xff0c;并可能面临数据泄露、恶意软件感染等安全风险。了解服务器IP被劫持的危害和预防措施…