大师偷学:vue-cli构建SPA项目和SPA项目结构

目录

一,vue-cli构建SPA项目

二,SPA项目结构

三、SPA完成路由的开发

四、嵌套路由的使用


一,vue-cli构建SPA项目

        前提:

想要实现vue-lic构建SPA项目,前提是搭建好nodeJS环境

我们使用两个命令来测试一下:

   node -v
   npm -v

如果出现版本号则表示nodeJS环境搭建好了

         1.1什么是Vue-cli?

  vue-cli是vue.js的脚手架,用于自动生成vue.js+webpack的项目模板,创建命令如下:        

  vue init webpack xxx                    

   注1:xxx 为自己创建项目的名称

   注2:必须先安装vue,vue-cli,webpack,node等一些必要的环境

         1.2安装vue-cli

命令:

npm install -g vue-cli

npm install webpack -g

安装完成之后打开命令窗口并输入 vue -V(注意这里是大写的“V”),如果出现相应的版本号,则说明安装成功。然后可以看到我们的目录下出现了一些文件:

        1.3创建SPA项目 

命令:

vue init webpack spa0911 

此命令用于创建SPA项目,它会在当前目录生成一个以“spa0911”命名的文件夹

 创建成功

        1.4 使用开发软件HBuilder x 右键导入项目

二,SPA项目结构

1)在项目的目录层次中打开cmd窗口来启动项目

命令:
npm run dev

2)得到一个访问地址 

3)访问地址:证明SPA项目创建成功!

 注2:vue-cli构建的项目,在控制台npm run dev启动后,默认的调试地址是8080端口的但是大部分时候,我们都要并行几个项目开发,很有可能已经占用了8080端口,所以就涉及到如何去更改调试地址的端口号了

        config --> index.js  

        dev: {

          // Paths

          assetsSubDirectory: 'static',

          assetsPublicPath: '/',

          proxyTable: {},

          host: 'localhost',

          port: 8083,       // 在这里修改端口号

          autoOpenBrowser: false,

          errorOverlay: true,

          notifyOnErrors: true,

        },

 项目结构解析

三、SPA完成路由的开发

 spa的访问过程:

1.访问index.html
2.index.html通过main.js中的vue实例管理#app边界,
同时指定App.vue模板
3.App.vue中包含了logo图片以及锚点,而锚点与组件的对应关系存在router/index.js中,所有就指向了一个组件
4.最终App.vue中就显示了logo图片以及hellowrld.vue的内容   

 当前后端分离时会启动两个一样的端口号 此时我们需要修改端口

 组件使用流程:

 APP.vue:

<template>
  <div id="app">
   <!-- 事件 -->
   <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>

Home.vue

<template>
  <div>
    这是首页内容,最新内容
  </div>
</template>

<script>
    export default{
      name:"Home",
      data(){
        return {
          msg:'Welcome to Your Vue.js App'
        };
      }
    }
</script>

<style>
</style>

 About.vue:

<template>
  <div>
    吾乃钮祜禄甄强!!!
  </div>
</template>

<script>
    export default{
      name:"About",
      data(){
        return {
          msg:'Welcome to Your Vue.js App'
        };
      }
    }
</script>

<style>
</style>

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'


Vue.use(Router)

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

 

四、嵌套路由的使用

其实嵌套路由就是在index.js中加入一个children的属性以及配置相关的关系
About.vue:

<template>
  <div>
   <!-- 这是关于本站内容 -->
   <router-link to="/AboutMe">关于站长</router-link>
    <router-link to="/AboutWebSeit">关于本站</router-link>
    <!-- 锚点 -->
    <router-view></router-view>
  </div>
</template>

<script>
    export default{
      name:"About",
      data(){
        return {
          msg:'Welcome to Your Vue.js App'
        };
      }
    }
</script>

<style>
</style>

AboutMe.vue:

<template>
  <div>
    吾乃钮祜禄甄强!!!
  </div>
</template>

<script>
    export default{
      name:"AboutMe",
      data(){
        return {
          msg:'Welcome to Your Vue.js App'
        };
      }
    }
</script>

<style>
</style>

AboutWebSeit.vue:

<template>
  <div>
    再见了!!!朕的江山!!!
  </div>
</template>

<script>
    export default{
      name:"AboutWebSeit",
      data(){
        return {
          msg:'Welcome to Your Vue.js App'
        };
      }
    }
</script>

<style>
</style>

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 AboutSeit from '@/components/AboutWebSeit'

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/Home',
      name: 'Home',
      component: Home
    },
		{
			path: '/About',
			name: 'About',
			component: About,
			children:[
				{
					path: '/AboutMe',
					name: 'AboutMe',
					component: AboutMe
				},
				{
					path: '/AboutWebSeit',
					name: 'AboutWebSeit',
					component: AboutWebSeit
				}
			]
		}
  ]
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秃头没秃头

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值