vue-cli是官方提供的一个脚手架,用于快速生成一vue项目,有点类似java中使用maven构建项目
需要环境
Node.js : http://nodejs.cn/download/ 安装完后在Windows的cmd窗口输入 node -v及npm -v 如果有版本号,那么说明安装成功 也可以安装淘宝的镜像,这样下载的话会快很多,安装淘宝镜像后可以使用cnpm指令
# -g 全局安装
npm install cnpm -g
npm config set registry https://registry.npm.taobao.org
npm install cnpm -g安装位置:C:\Users\Administrator\AppData\Roaming\npm
安装vue-cli
#在命令台输入
cnpm install vue-cli -g
#查看是否安装成功
vue list创建第一个vue-cli程序
1、在本地磁盘创建一个空文件夹用来存放项目 D:\vue\vuenote 2、使用控制台在该目录下执行创建vue应用程序指令
D:\vue\vuenote>vue init webpack first-vue3、一路选择no 4、进入项目目录,安装依赖
D:\vue\vuenote>cd first-vueD:\vue\vuenote\first-vue>cnpm install5、启动项目
npm run dev打开浏览器输入 http://localhost:8080/
webpack
webpack是一个现代JavaScript应用程序的静态模块打包器(module bundler)。当webpack处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个bundle.
webpack的使用
1、在本地磁盘上创建一个空目录,并使用idea打开
2、按如下结构创建目录和文件
3、在hello.js暴露一个sayhai的方法
exports.sayHai=function () {    document.write("hello world
")}4、在main.js导入该方法
var hello=require('./hello')hello.sayHai()5、在webpack.config.js中配置打包
module.exports={    entry:'./modules/main.js',    output:{        filename:'./js/bundle.js'    }}6、在idea控制台运行 webpack指令 运行webpack指令后,会在当前项目的生成dist/js/bundle.js 7、在index.html中引入bundle.js文件
        Title     Vue-Router路由
Vue Router是Vue.js官方的路由管理器(路径跳转)。它和Vue.js的核心深度集成,让构建单页面应用变得易如反掌。
安装路由
使用idea在当前项目的控制台上输入指令
cnpm install vue-router --save-dev路由的使用
1、在component目录下创建一个vue组件Content.vue
import Vue from 'vue'
import VueRouter from 'vue-router'
import Content from "../components/Content";
//安装路由
Vue.use(VueRouter);
export default new VueRouter({
  routes:
    [
      {
        //路由路径
        path: '/content',
        name: 'content',
        //跳转的组件
        component: Content
      }
    ]
})2、在当前项目下创建router目录,router目录下创建用来配置路由的配置文件index.js index.js内容如下:
import Vue from 'vue'
import VueRouter from 'vue-router'
import Content from "../components/Content";
//安装路由
Vue.use(VueRouter);
export default new VueRouter({
  routes:
    [
      {
        //路由路径
        path: '/content',
        name: 'content',
        //跳转的组件
        component: Content
      }
    ]
})3、在App.vue中配置请求路由
  
    
    //请求路由
    内容页 
    //路由结果在此处展示
     
  
vue+elementUI
vue配合elementUI可以使我们的页面更加美观
elementUI的使用
1、创建一个新的vue项目
vue init webpack vue_element2、安装插件(vue-router、element-ui、sass-loader、node-sass)
# 进入工程目录
cd vue_element
# 安装 vue-router
npm install vue-router --save-dev
# 安装 element-ui
npm i element-ui -S
# 安装依赖
npm install
# 安装 SASS 加载器
cnpm install sass-loader node-sass --save-dev
# 启动测试
npm run dev3、创建一个Login.vue组件,内容如下:
  
    
      欢迎登录
      
         
       
      
         
       
      
        登录 
       
     
    
      请输入账号和密码
      
     
  
4、配置路由
import Vue from 'vue'
import VueRouter from 'vue-router'
import Login from "../components/Login";
//安装路由
Vue.use(VueRouter)
export default new VueRouter({
  routes:[
    {
      path:'/login',
      name:'login',
      component:Login
    }
  ]
})5、在main.js引入路由和elementUI
// 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'
//导入elementUI
import ElementUI from "element-ui"
//导入element css
import 'element-ui/lib/theme-chalk/index.css'
Vue.config.productionTip = false
Vue.use(router);
Vue.use(ElementUI)
/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  render: h => h(App),//ElementUI规定这样使用
})6、在App.vue中请求路由
  
        登录 
         
  
7、测试 npm run dev
注意:如果项目运行失败,可以在package.json里降低sass-loader和node-sass的版本
"sass-loader": "^7.3.1",
"node-sass": "^4.9.0",嵌套路由
简单说就是在路由里再套一个子路由
1、创建一个作为子路由Profile.vue组件
    用户列表
2、Main.vue里请求路由
  
    
      
        
          
            用户管理
            
              
                
                个人信息 
               
              
                
                用户列表 
               
             
           
          
            内容管理
            
              分类管理 
              内容列表 
             
           
         
       
      
        
          
            
            
              个人信息 
              退出登录 
             
           
         
        
          
           
         
       
     
  
3、测试
参数传递
参数传递过程:url请求路径—->路由接收参数—->跳转套组件显示参数
1、url请求路径
个人信息 2、路由接收参数
方式一:
 {path:'/user/profile/:id',name:'Profile',component:Profile},方式二:
{path:'/user/profile/:id',name:'Profile',component:Profile,props:true}3、组件模板展示参数
方式一:
{ {$route.params.id} }方式二:
  
      { {id} }
    
路由钩子与异步请求
路由模式
hash:路径带 # 符号(默认),如 http://localhost/#/login history:路径不带 # 符号,如 http://localhost/login
路由钩子与异步请求
beforeRouteEnter:在进入路由前执行 beforeRouteLeave:在离开路由前执行 类似于过滤器,在进入模板前可以使用路由钩子进行异步请求数据,并在模板展示
  
      { {info.url} }
    
    
