小程序全局使用api

使用的是 Vue 插件(Plugin)机制,通过 install方法将 API 挂载到 Vue 的原型链或实例上,从而实现全局使用。

具体实现方式如下:

1. 核心机制:Vue Plugin (install)

在 http.api.js中,导出一个默认对象,该对象包含一个 install函数。这是 Vue 官方推荐的标准插件写法。

复制代码
const install = (Vue, vm) => {
    // ...
    vm.$u.api = { 
	postLogin: (params = {}) => vm.$u.post('/admin/login',
			params), //登录接口
		getKeyLogin: (params = {}) => vm.$u.get('/keylogin',
			params), //获取key
}; // 将 API 挂载到 vm.$u.api 上
}
export default { install }
  • Vue: Vue 构造器。
  • vm : 当前 Vue 实例(在 uView UI 框架中,通常指代 this 或全局上下文)。

2. 挂载位置:vm.$u.api

代码中将所有接口方法统一赋值给了 vm.$u.api。 这意味着,只要你能访问到 this.$u,你就可以通过 this.$u.api.xxx() 来调用接口。

复制代码
// 例如在页面中
this.$u.api.getKeyLogin({ uid: this.uid })

3初始化main,js

复制代码
// main.js 示例
import Vue from 'vue'
import uView from "uview-ui";
import httpApi from './common/http.api.js'; // 引入这个文件

Vue.use(uView);
Vue.use(httpApi); // <--- 这里执行了 install 方法,完成了全局挂载

4. 为什么可以直接用 this.$u.api

  • uView UI 框架基础u 是 uView UI 框架挂载在 Vue 原型上的全局对象(`Vue.prototype.u`)。
  • 扩展属性 :http.api.js 并没有创建新的全局变量,而是利用了 uView 已经存在的 $u 对象,在其下面新增了一个 api 属性。
  • 结果 :因为 u 是全局可用的,所以 `u.api` 也是全局可用的。

总结

这是一种典型的 Vue 插件扩展模式

  1. 定义 install 函数。
  2. 在 install 中将功能挂载到 Vue 实例或原型上(这里是挂载到 vm.$u 上)。
  3. 在主入口通过 Vue.use() 注册插件。
  4. 在组件中通过 this.$u.api.方法名() 直接调用。
相关推荐
代码煮茶15 小时前
React 组件封装方法论 —— 以 Todo App 为例
javascript·react.js
任沫15 小时前
Agent之Function Call
javascript·人工智能·go
默_笙17 小时前
🛬 我让 AI 帮我写了一个打飞机游戏,结果 Canvas 把我整不会了
前端·javascript
梯度不陡17 小时前
AI 到底能不能从零写软件?ProgramBench 和 RepoZero 给出了两种答案
前端·javascript·面试
胡萝卜术18 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
kyriewen20 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒21 小时前
bun直接tsx,优雅!
javascript·后端
假如让我当三天老蒯1 天前
Options API(选项式 API) 和 Composition API(组合式 API)
前端·vue.js·面试
_柳青杨1 天前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法