vue技术栈实战开发(课程笔记)



2018-11-12更新

Router(一)

  • router-link和router-view组件

  • 路由配置

    • 动态路由
    {
        path:"/argu/:name",
        component:()=> import("@views/argu.vue")
    }
    
    • 嵌套路由
    {
        path: "/parent",
        name: parent,
        component: () => import("@/views/home.vue"),
        children:[
            {
                path:"child",
                component:() => import("@views/child.vue")
            }
        ]
    }
    
    • 命名路由
       <router-link :to="{name: "home"}">Home</router-link>
       
       {
           path: "/home",
           name: home,
           component: () => import("@/views/home.vue")
       }
    
    • 命名视图
       <router-view/>
       <router-view name="email"></router-view>
       
       {
           path:"/named_view",
           components:{
               default:() => import("@/views/child.vue"),
               email:()=> impotr("@/views/email.vue")
           }
       }
    
  • js操作路由

    const name = 'gyh'
    this.router.push({
      path: `/argu/${name}` 
    })
    
  • 重定向(redirect)和别名(alias)

Router(二)

  • 编程式的导航
方式1:
直接修改地址栏

方式2:
this.$router.push(‘路由地址’);
this.$router.replace(‘路由地址’);
this.$router.go(int);

还可以这样用:
router.push({ path: 'home' })
// 命名的路由
router.push({ name: 'user', params: { userId: 123 }})
在路由到的页面中使用this.$route.params接受,即this.$route.params.userId

// 带查询参数,变成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})
在路由到的页面中使用this.$route.query接受,即this.$route.query.plan

其中,使用params的时候,必须要用name传路由名称而非path。

方式3:
<router-link to="路由地址" replace></router-link>
使用replace不会留下History记录,不能用后退键返回上一个页面

Router(三)

  • 路由组件传参

    页面需要写的内容是一样的,区别主要在于路由配置

    • 动态匹配页面(布尔模式)

      {
              path: 'params/:id',
              name: 'params',
              meta: {
                title: '参数'
              },
              component: () => import('@/views/argu.vue'),
              props: true
      }
      
      <template>
        <div>
          {{ id }}
        </div>
      </template>
      
      <script>
      export default {
        props: {
          id: {
            type: String,
            default: 'lison'
          }
        }
      }
      </script>
      
      
    • 普通页面(对象模式)

      {
              path: 'params/:id',
              name: 'params',
              meta: {
                title: '参数'
              },
              component: () => import('@/views/argu.vue'),
              props: {
                  food:'banana'
              }
      }
      
      <template>
        <div>
          {{ food }}
        </div>
      </template>
      
      <script>
      export default {
        props: {
          food: {
            type: String,
            default: 'apple'
          }
        }
      }
      </script>
      
    • 函数模式

      {
              path: 'params/:id',
              name: 'params',
              meta: {
                title: '参数'
              },
              component: () => import('@/views/argu.vue'),
              props: router => ({
                  food:route.query.food
              })
      }
      
      <template>
        <div>
          {{ food }}
        </div>
      </template>
      
      <script>
      export default {
        props: {
          food: {
            type: String,
            default: 'apple'
          }
        }
      }
      </script>
      
  • HTML5 History模式

    mode:'history'
    
  • 路由导航

    /**
     * 1. 导航被触发
     * 2. 在失活的组件(即将离开的页面组件)里调用离开守卫 beforeRouteLeave
     * 3. 调用全局的前置守卫 beforeEach
     * 4. 在重用的组件里调用 beforeRouteUpdate
     * 5. 调用路由独享的守卫 beforeEnter
     * 6. 解析异步路由组件
     * 7. 在被激活的组件(即将进入的页面组件)里调用 beforeRouteEnter
     * 8. 调用全局的解析守卫 beforeResolve
     * 9. 导航被确认
     * 10. 调用全局的后置守卫 afterEach
     * 11. 触发DOM更新
     * 12. 用创建好的实例调用beforeRouterEnter守卫里传给next的回调函数
     */
    
    router.beforeEach((to,from,next)=>{
        
    })
    
  • 路由元信息(meta)

    meat:{
        title: '首页'
    }
    
  • 过渡效果

    <transition-group :name="routerTransition">
        <router-view key="default"/>
        <router-view key="email" name="email"/>
        <router-view key="tel" name="tel"/>
    </transition-group>
    
     data () {
        return {
          routerTransition: ''
        }
      },
      watch: {
        '$route' (to) {
          to.query && to.query.transitionName && this.routerTransition = to.query.transitonName
        }
      },
    
    .router-enter{
      opacity: 0;
    }
    .router-enter-active{
      transition: opacity 1s ease;
    }
    .router-enter-to{
      opacity: 1;
    }
    .router-leave{
      opacity: 1;
    }
    .router-leave-active{
      transition: opacity 1s ease;
    }
    .router-leave-to{
      opacity: 0;
    }
    

状态管理

1、BUS

2、Vuex-基础-state&getter

3、Vuex-基础-mutation&action&moodule

4、Vuex-进阶(插件、严格模式、Vuex+双向绑定)

  • action使用

    import { getAppName } from '@/api/app'
    
    const actions = {
      // updateAppName ({ commit }) {
      //   getAppName().then(res => {
      //     const { info: { appName } } = res
      //     commit('SET_APP_NAME', appName)
      //   }).catch(err => {
      //     console.log(err)
      //   })
      // }
      async updateAppName ({ commit }) {
        try {
          const { info: { appName } } = await getAppName()
          commit('SET_APP_NAME', appName)
        } catch (err) {
          console.log(err)
        }
      }
    }
    export default actions
    
    import { mapState, mapGetters, mapMutations, mapActions } from 'vuex'
    
     ...mapActions([
          'updateAppName'
    ]),
    
    this.updateAppName()
    
  • 动态注册模块(this.$store.registerModule)

  • 插件(持久化存储的案例)

    plugins: [ saveInLocal ]
    
      export default store => {
        if (localStorage.state) store.replaceState(JSON.parse(localStorage.state))
        store.subscribe((mutation, state) => {
          localStorage.state = JSON.stringify(state)
        })
      }
      //replaceState vuex提供的替换state方法
      //subscribe vuex提供的订阅store的mutation,handler会在每个mutation完成后调用,接收 mutation和经过mutation后的状态作为参数
    
  • 严格模式

    strict: process.env.NODE_ENV === 'development'
    
  • 双向绑定

    stateValue: {
          get () {
            return this.$store.state.stateValue
          },
          set (val) {
            this.SET_STATE_VALUE(val)
          }
    },
    

Ajax请求

  • 解决跨域问题

    • 前端解决

      //vue.config.js
      devServe{
          proxy: 'http://localhost:4000'
      }
      
    • 后端解决

  • 封装axios

    • 请求拦截
    • 响应拦截
  • 请求实战

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容

  • vue笔记 一.vue实例 vue的生命周期 beforeCreate(创建前), created(创建后), b...
    秋殇1002阅读 1,051评论 0 1
  • vue-cli搭建项目 确保安装了node与npm 再目标文件夹下打开终端 执行cnpm i vue-cli -g...
    Akiko_秋子阅读 3,219评论 1 22
  • ## 框架和库的区别?> 框架(framework):一套完整的软件设计架构和**解决方案**。> > 库(lib...
    Rui_bdad阅读 2,899评论 1 4
  • 项目地址https://github.com/hongchh/timeline-x 一、成品展示 二、项目需求 添...
    前端杨肖阅读 9,366评论 0 10
  • 2018年9月1日是个大日子! 这一天,我竣迎着火红的日出,沐浴着阳光,脚下生风,雄赳赳气昂昂,意气风发头也不回走...
    沧海一霸阅读 174评论 2 1