uni-app:利用Vue的原型对象Vue.prototype设置全局方法及其引用

一、在main.js中设置方法checkPermission绑定到Vue.prototype

核心代码

javascript 复制代码
Vue.prototype.$checkPermission = function(username) {
  console.log('Checking permission for:', username);
};

完整代码

javascript 复制代码
import App from './App'

// 添加 checkPermission 方法到 Vue.prototype 上,检查权限(这一段是方法的设置)
Vue.prototype.$checkPermission = function(username) {
  console.log('Checking permission for:', username);
};

// #ifndef VUE3
import Vue from 'vue'
Vue.config.productionTip = false
App.mpType = 'app'
const app = new Vue({
    ...App
})

app.$mount()
// #endif

// #ifdef VUE3
import { createSSRApp } from 'vue'
export function createApp() {
  const app = createSSRApp(App)
  return {
    app
  }
}
// #endif

二、在页面引用全局方法

核心代码

javascript 复制代码
this.$checkPermission(this.username);

完整代码

javascript 复制代码
export default {
    data() {
        return {
            username: 'testuser'
        };
    },
    methods: {
        onLoad() {
            this.$checkPermission(this.username);//调用方法,传递参数username
        }
    }
};

补充:涉及到异步问题

一、main.js(全局方法有请求服务器的操作)

javascript 复制代码
import App from './App'
// 添加 checkPermission 方法到 Vue.prototype 上,检查权限
Vue.prototype.$checkPermission = function(username) {
  return new Promise((resolve, reject) => {
    uni.request({
      url: getApp().globalData.position + 'Xcxuser/checkpermission',
      header: {
        "Content-Type": "application/x-www-form-urlencoded"
      },
      method: 'POST',
      dataType: 'json',
      data: {
        username: username,
      },
      success: res => {
        // console.log('Server Response:', res);
        resolve(res);
      },
      fail: err => {
        console.log(err);
        reject(err);
      }
    });
  });
};




// #ifndef VUE3
import Vue from 'vue'
Vue.config.productionTip = false
App.mpType = 'app'
const app = new Vue({
    ...App
})

app.$mount()
// #endif

// #ifdef VUE3
import { createSSRApp } from 'vue'
export function createApp() {
  const app = createSSRApp(App)
  return {
    app
  }
}
// #endif

二、userlogin.vue(调用方法)

javascript 复制代码
methods: {
	//权限检查
	async checkUserPermission(username) {
		  try {
			const response = await this.$checkPermission(username);
			console.log('Server Response:', response);
			this.permissionResult = response.data; // 假设服务器返回的数据在response.data中
			this.permissionChecked = true;
		  } catch (error) {
			console.error('Error checking permission:', error);
		  }
	  },
    mounted() {
        // 页面加载时调用权限检查
        this.checkUserPermission('yourUsername');
    }

}
相关推荐
蜡台29 分钟前
vue.config.js 配置
前端·javascript·vue.js·webpack
踩着两条虫1 小时前
AI驱动的Vue3应用开发平台 深入探究(十六):扩展与定制之自定义组件与设计器面板
前端·vue.js·人工智能·开源·ai编程
棋鬼王1 小时前
Cesium(十) 动态修改白模颜色、白模渐变色、白模光圈特效、白模动态扫描光效、白模着色器
前端·javascript·vue.js·智慧城市·数字孪生·cesium
ThridTianFuStreet小貂蝉1 小时前
面试题1:请系统讲讲 Vue2 与 Vue3 的核心差异(响应式、API 设计、性能与编译器)。
前端·javascript·vue.js
布局呆星2 小时前
Vue3 | 事件绑定与双向数据绑定
前端·javascript·vue.js
@菜菜_达2 小时前
Vue 入门学习
前端·vue.js·学习
daols882 小时前
vue甘特图vxe-gantt定位到对应的行于列,定位到对应的任务视图任务条
javascript·vue.js·甘特图
终端鹿2 小时前
手写 Vue3 自定义指令:防抖、点击外部、权限控制
前端·javascript·vue.js
关中老四2 小时前
简单易用的vue3甘特图组件:mzgantt-vue3
javascript·vue.js·甘特图
洗发水很好用2 小时前
uniapp纯css实现基础多选组件
前端·css·uni-app