目录
?一,vue-cli构建SPA项目
前提:
搭建好NodeJS环境
1.1 什么是vue-cli?
?1.2. 安装vue-cli
? ?npm install -g vue-cli? ?npm install -g webpack
? ?vue init webpack xxx? ?
??使用开发软件HBuilder?x?右键导入项目
二,SPA项目结构
?在项目的目录层次中打开cmd窗口来启动项目?编辑
得到一个访问地址?
结构解析
?spa的访问过程:
?在启动项目的窗口中Ctrl+c重启项目
三、SPA完成路由的开发
3.1 SPA路由的流程
三、嵌套路由的使用
?一,vue-cli构建SPA项目
前提:
搭建好NodeJS环境
???node -v ? ?npm -v
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 -g webpack
? ?注1:安装成功后,会出现如下文件 ? ? ? ? D:\initPath ? ? ? ? ? ? ?node-v10.15.3-win-x64 ? ? ? ? ? ? ? ?node_global ? ? ? ? ? ? ? ? ?vue ? ? ? ? ? ? ? ? ?vue.cmd? ? ? ? ? ? ? ? ? ?vue-init ? ? ? ? ? ? ? ? ?vue-init.cmd ? ? ? ? ? ? ? ? ?vue-list ? ? ? ? ? ? ? ? ?vue-list.cmd ? ?注2:安装完成之后打开命令窗口并输入 vue -V(注意这里是大写的“V”),如果出现相应的版本号,则说明安装成功。
data:image/s3,"s3://crabby-images/10641/106417244ca6491bb74279c3e8a04b469438d773" alt=""
?data:image/s3,"s3://crabby-images/d3e41/d3e41c3fb78508b5f2540dde427a1f3778b09c78" alt=""
? ?vue init webpack xxx? ?
? 注1:xxx 为自己创建项目的名称 ? ?注2:必须先安装vue,vue-cli,webpack,node等一些必要的环境
data:image/s3,"s3://crabby-images/f54e3/f54e3284c689df5735565113add23d981492c800" alt=""
?创建成功
?data:image/s3,"s3://crabby-images/af775/af7758103570685fcb0cd876169cddc2e6b21b0d" alt=""
?查看项目
data:image/s3,"s3://crabby-images/ff82a/ff82a80743c8d9f6aa470fc23cbcda406aa51d2c" alt=""
??使用开发软件HBuilder?x?右键导入项目
data:image/s3,"s3://crabby-images/d3919/d39191a20915c10bbd70e383cdfa46c6e2cad2a0" alt=""
?data:image/s3,"s3://crabby-images/f6996/f69964961b40717da25c27b550f22005aed90c93" alt=""
导入成功?
?data:image/s3,"s3://crabby-images/66486/66486bbac47bef806363a5178e0cddb2d6e40935" alt=""
二,SPA项目结构
?在项目的目录层次中打开cmd窗口来启动项目data:image/s3,"s3://crabby-images/9e5f7/9e5f712c6ddcb90289a54ab7566c49e696d554c6" alt=""
得到一个访问地址?
data:image/s3,"s3://crabby-images/b94eb/b94eb50e267d3a8297e66ef6425b592a489b8361" alt=""
?访问地址data:image/s3,"s3://crabby-images/0b0ad/0b0ade63f15d40429e8f166b30fd4a0c34307157" alt=""
结构解析
data:image/s3,"s3://crabby-images/89988/89988de17ebb7fac205e3e9c493491da3c3ea0c4" alt=""
?data:image/s3,"s3://crabby-images/f24de/f24de97a69f79fe7f78ac3a3129be0507d0a9f7b" alt=""
?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/6df37/6df37fd9f299b0213ec724dc4c456c3ecb5e44df" alt=""
当前后端分离时会启动两个一样的端口号?此时我们需要修改端口
data:image/s3,"s3://crabby-images/ff473/ff47383832182aad7c1077607e36f90d7b0a3cc7" alt=""
修改后需要重启项目
?data:image/s3,"s3://crabby-images/99062/990628ae2d369af01322f23c9eeb9e847f8f0ce7" alt=""
?在启动项目的窗口中Ctrl+c重启项目
data:image/s3,"s3://crabby-images/4e312/4e312f4205a5aaddcb460e4a3efe17eb11aa91f2" alt=""
访问端口号发送改变?
data:image/s3,"s3://crabby-images/aff99/aff99c8aedaa7f651737f23b1d0a28b6985850a7" alt=""
三、SPA完成路由的开发
3.1 SPA路由的流程
data:image/s3,"s3://crabby-images/d6fe4/d6fe49ea34fda230cb289103881d642ec0ee9af4" alt=""
data:image/s3,"s3://crabby-images/3576c/3576c1f36286acd7454c3bbd14247ed86f9d9bdd" alt=""
?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>
站长今年19岁,未婚,姓刘
</div>
</template>
<script>
export default{
name:"About",
data(){
return {
msg:'Welcome to Your Vue.js App'
};
}
}
</script>
<style>
</style>
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>
index.vue
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Home from '@/components/Home'
import About from '@/components/AboutMe'
Vue.use(Router)
export default new Router({
routes: [
{
path: '/Home',
name: 'Home',
component: Home
},
{
path: '/About',
name: 'About',
component: About
}
]
})
?其中我们的挂载在main.js已经完成了
// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
components: { App },
template: '<App/>'
})
三、嵌套路由的使用
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>
站长今年19岁,未婚,姓刘
</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/AboutSeit'
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: '/AboutSeit',
name: 'AboutSeit',
component: AboutSeit
}
]
}
]
})
效果展示:
data:image/s3,"s3://crabby-images/f6d19/f6d194d225e7fe66e84271db04c57e30f69d2e35" alt="" data:image/s3,"s3://crabby-images/52817/52817a25c1bf66894aec6b0c08a3d8e5f13ab118" alt=""
?data:image/s3,"s3://crabby-images/e34f1/e34f1442115266d0f15a64c387d28c3e2d48c157" alt=""
|