目录
一,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
data:image/s3,"s3://crabby-images/b9c85/b9c855e9014fc8969773749ba8227835d1f6c498" alt=""
安装完成之后打开命令窗口并输入?vue -V(注意这里是大写的“V”),如果出现相应的版本号,则说明安装成功。然后可以看到我们的目录下出现了一些文件:
data:image/s3,"s3://crabby-images/fcb80/fcb804c864bbd279a8962c7bcb9e79c417f4b4ea" alt=""
data:image/s3,"s3://crabby-images/9f297/9f2970f9c3b8648e93b04d294f794469180d5cf0" alt=""
? ? ? ? 1.3创建SPA项目?
命令:
vue init webpack spa0911?
此命令用于创建SPA项目,它会在当前目录生成一个以“spa0911”命名的文件夹
data:image/s3,"s3://crabby-images/4ea58/4ea5849b0e123dbf7be63af9eeadc381a64af4ab" alt=""
?创建成功
data:image/s3,"s3://crabby-images/92ef8/92ef8deed62ab7897164243d79b5caf57458acad" alt=""
? ? ? ? 1.4?使用开发软件HBuilder?x?右键导入项目
data:image/s3,"s3://crabby-images/d8334/d8334e36155dc80c5395a7b418115d875131b4fd" alt="" data:image/s3,"s3://crabby-images/d2bad/d2bad37b71854f20f230025553a4c7963f1f30d2" alt=""
二,SPA项目结构
1)在项目的目录层次中打开cmd窗口来启动项目
命令: npm run dev
2)得到一个访问地址?
data:image/s3,"s3://crabby-images/33993/33993afb437516d6293cc740474aec726294befb" alt=""
3)访问地址:证明SPA项目创建成功!
data:image/s3,"s3://crabby-images/6d885/6d8857fe2d29fc4c3c79212c6014933aa0003408" alt=""
?注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,
????????},
?项目结构解析:
data:image/s3,"s3://crabby-images/16766/16766e5acf0386073501a16c77ff5fd2f8632ef7" alt=""
data:image/s3,"s3://crabby-images/4c094/4c094a0aa9dbf1680f678904071e402bc4c5fbae" alt=""
三、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的内容? ?
?当前后端分离时会启动两个一样的端口号?此时我们需要修改端口
data:image/s3,"s3://crabby-images/d27b0/d27b0641e572126740ef04a15b232bffece5f4bb" alt=""
?组件使用流程:
data:image/s3,"s3://crabby-images/4171e/4171eda0b3ec925d345f4f5982d69309503bdc82" alt=""
?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
}
]
})
data:image/s3,"s3://crabby-images/9c8bf/9c8bf47c13817b9d2a9f45389082912a173bb528" alt=""
?
四、嵌套路由的使用
其实嵌套路由就是在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
}
]
}
]
})
|