vue学习笔记(十一)——开发心得(axios的封装、promise细节、vue-router开发中的使用、vuex在开发中的使用)

1. axios的网络请求的封装

1.1 为什么要封装api?

        代码分层,便于以后的修改,无需触碰逻辑页面
目标:
        网络请求,不散落在各个逻辑页面里,封装起来方便以后修改

1.2 封装api步骤

① 在项目 src 下新建目录 utlis ,此目录一般用于管理项目下所使用到的工具,如 axios。

② 在 utils 目录下新建 request.js 文件,对axios进行二次封装,并且制定项目的根地址并使用默认导出将 axios 导出。(每个模块中,只允许使用唯一的一次 export default,否则会报错!

③ 在 src 下新建目录 api ,用于统一管理所有需要的 url地址,封装网络请求方法导出。

如在 api 目录下新建 home.js 用于统一管理首页 Home 组件中的所有网络请求

④ 在 api 目录下新建 index.js,将 api 文件夹下各个请求模块的 js 都统一导入到 index.js 中,再统一向外导出接口,导出的方法统一加一个 API 后缀,开发时使用时就知道这是接口函数了。

⑤ 在某个组件中使用的时候,直接导入使用该方法。

2. promise 的使用细节

2.1 async修饰的函数 -> 默认返回一个全新Promise对象

        如在 methods 方法中使用的 getSongList 方法,由于 searchResultAPI 是使用 axios 封装的一个接口函数,所以该接口函数返回的是一个 promise 对象,可以通过使用 await 修饰直接拿到返回的结果。如果某个方法内部使用了 await 修饰,那么这个方法需要使用 async 来修饰该方法。

        在 hotsFun 函数中调用 getSongList 方法时,getSongList方法返回值的是一个 promise 对象。因为 getSongList 用了 async 方法修饰,所以返回了一个新的 promise 对象。因此可以使用 await 来修饰,直接拿到返回的结果。某个函数内部用了 await 修饰后,需要加 async 修饰。

3. vue-router 开发中的使用细节

3.1 vue-router 开发中的统一管理

① router/index.js – 配置路由规则和对应路由页面        

        在 src 下新建目录 router,再新建文件 index.js,在 index.js 中配置路由规则和对应路由页面,之后使用默认导出。

② main.js – 引入路由对象注入到vue中

③ App.vue – 留好router-view显示路由页面(挂载)

3.2 $router 和 $route 的区别

  • $router 为 vueRouter 的实例,相当于一个全局路由对象,里面含有很多属性和子对象。
    • 如 this.$router.push(路由path 或 路由name) 

  • $route 为当前正在跳转的路由对象。
    • ​​​​​​​​​​​​​​如 this.$route.meta.属性名 

3.3 路由元信息-meta

① meta是什么?

        是用来存储路由相关的一些额外信息。可以把它理解为附加在路由上的标签或属性,这些标签或属性对应的信息可以在路由守卫、组件等地方被访问和利用。

② meta 的使用

        直接写在路由规则的配置里

        

        在组件里可以通过 this.$route.meta.属性名 的方式拿到具体的值。

4. vuex在开发中的使用细节

4.1 采用模块化的管理模式

案列: 在vuex中加载分类和频道数据,实现数据的共享

步骤:

        ① 在 src 目录下创建一个名为 store 的文件夹,并在该文件夹中创建一个名为 index.js 的文件,用于管理共享的数据。代码如下,并且导出该 store 对象。

        ② 在 main.js 文件中导入 store 实例,并且将该实例注入Vue 实例中。

        ③ 在 store 文件下新建文件夹 modules,建立一个专门的模块来管理分类(category.js)和新闻数据(newList.js)。

  • category.js代码如下:

  • newList.js 代码如下:

  • namespaced 保证内部模块的高封闭性,不能通过全局直接使用内部子模块内的方法。
  • 21
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值