点餐小程序实战教程17角色管理

news2024/10/8 21:17:16

目录

  • 1 创建API
  • 2 创建全局变量
  • 3 加载角色
  • 4 引导用户注册
  • 总结

小程序中如果有多重角色人员使用的,通常需要根据用户的角色来进行页面跳转。我们点餐小程序也是区分不同的用户,有顾客和员工的区分,本篇我们讲解一下如何利用API来加载用户的角色

1 创建API

角色的话我们是先创建一个API来根据用户的openid去加载信息。打开应用编辑器,切换到数据模型视图,切换到APIs,点击+号进行创建
在这里插入图片描述
选择自定义代码
在这里插入图片描述
输入名称和标识
在这里插入图片描述
创建成功后修改方法的名称和标识
在这里插入图片描述
点击添加入参
在这里插入图片描述
输入openid
在这里插入图片描述
在代码区输入如下代码

module.exports = async function (params, context) {
  // 查询顾客表
  const customerResult = await context.callModel({
    name: 'customer_v7mamho', // 顾客表的模型名称
    methodName: 'wedaGetItemV2', // 查询顾客的函数
    params: {
      filter: {
          where: {
            $and: [
              {
                openid: {
                  $eq: params.openid, // 获取单条时,推荐传入_id数据标识进行操作
                },
              },
            ],
          },
        },
        select: {
          $master: true, // 常见的配置,返回主表
        },

    },
  });

  // 查询员工表
  const employeeResult = await context.callModel({
    name: 'employee_5kkehvv', // 员工表的模型名称
    methodName: 'wedaGetItemV2', // 查询员工的函数
    params: {
      filter: {
          where: {
            $and: [
              {
                openid: {
                  $eq: params.openid, // 获取单条时,推荐传入_id数据标识进行操作
                },
              },
            ],
          },
        },
        select: {
          $master: true, // 常见的配置,返回主表
        },

    },
  });
console.log("Customer Result:", customerResult);
console.log("Employee Result:", employeeResult);
  // 判断用户注册状态
  let isRegistered = false;
  let roles = [];
  let userData = {
    customer:  null,
    employee:  null,
  };

  if (customerResult&& Object.keys(customerResult).length > 0) {
    isRegistered = true; // 用户是顾客
    roles.push('customer');
    userData.customer = customerResult; // 设置用户数据为顾客数据
  }
  if (employeeResult&& Object.keys(employeeResult).length > 0) {
    isRegistered = true; // 用户是员工
    roles.push('employee');
    userData.employee = employeeResult; // 设置用户数据为员工数据
  }

  return {
    isRegistered: isRegistered, // 返回注册状态
    roles: roles, // 返回角色数组
    userData: userData, // 返回用户数据
  };


};

代码的逻辑是先分别去员工表和顾客表根据openid获取信息,根据返回的结果来分配角色并且将用户的信息返回

输入测试条件,执行测试,将返回的结果映射到出参里
在这里插入图片描述

2 创建全局变量

后端API开发好了之后,我们就可以加载角色信息了,需要创建一个全局变量用来存储角色,类型选择数组
在这里插入图片描述
在这里插入图片描述

3 加载角色

加载角色我们需要通过前端的自定义方法进行加载,修改一下我们原来创建的init方法,修改为如下代码

export default async function ({ event, data }) {
  try {
    // 获取用户信息
    const userinfo = await $w.auth.getUserInfo();
    console.log("userinfo", userinfo);

    // 使用用户的 openid,若未获取则使用默认值 "123"
    const openid = userinfo.openId || "123"; 
    console.log("openid", openid);

    // 调用云函数获取角色信息
    const result = await $w.cloud.callDataSource({
      dataSourceName: 'jsgl_ml92z65',
      methodName: 'getRoleInfo',
      params: { openid: openid },
    });

    console.log("result", result);

    // 检查用户是否注册
    if (result.isRegistered) {
      // 更新应用状态
      $w.app.dataset.state.role = result.roles;

      // 根据角色更新用户数据
      if (result.roles.includes("customer")) {
        $w.app.dataset.state.customer = result.userData.customer || null; // 确保存在数据
      }
      if (result.roles.includes("employee")) {
        $w.app.dataset.state.employee = result.userData.employee || null; // 确保存在数据
      }
    } else {
      console.log("用户未注册");
      // 这里可以添加未注册用户的处理逻辑,例如弹窗提示
    }
    
  } catch (error) {
    console.error("Error in main function:", error);
    // 这里可以添加错误处理逻辑,例如弹窗提示用户
  }
}

这里我们会根据API的返回结果来给全局变量赋值

4 引导用户注册

如果用户未注册,我们需要引导用户注册,这个时候需要弹出一个弹窗让用户点击对应的注册按钮进行注册。

在当前页面下添加弹窗组件,弹窗内容添加两个按钮
在这里插入图片描述
在init方法里,当用户未注册的时候,我们调用弹窗的api来打开弹窗

 $w.modal1.open({})

总结

我们本篇介绍了一下角色加载的逻辑,先定义好API加载好角色信息,前端调用的时候将获取的角色信息赋值给变量,后续就可以按照业务逻辑进行处理了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2197264.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

移除元素(算法题分享)

移除元素 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。 假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作&#xf…

使用欧拉安装ceph分布式存储,ceph的集群安装、添加主机集群和删除主机、添加osd硬盘和手动添加硬盘为osd和移除osd。

1.ceph安装 1.1 首先准备3台机子,配置ip,给每台机子添加3块硬盘,设置主机名为ceph01、ceph02、ceph03。 192.168.10.20ceph01192.168.10.21ceph02192.168.10.22ceph03 1.2 三台机子关闭防火墙,setenforce 0,添加hosts解析、配置…

【数据结构 | PTA】表

文章目录 7-1 重排链表7-2 链表去重7-3 两个有序链表序列的合并7-4 两个有序链表序列的交集 7-1 重排链表 输入格式: 每个输入包含1个测试用例。每个测试用例第1行给出第1个结点的地址和结点总个数,即正整数N (≤105)。结点的地址是5位非负整数&#xff…

OgreNext高级材质中增加线宽,点大小,虚线模式绘制支持

修改Ogre高级材质系统,增加线宽,点大小,虚线模式,虚线参数的支持,效果如下: 需要修改的代码文件如下: 修改如下 代码文本: //范围[0.2 - 51] 0.2 * [0,255];Ogre::uint8 mLineWidth;//范围[0.5 - 127.5] 0.5 * [0, 255];Ogre::uint8 mPointSize;//虚线标记Ogre::ui…

【Redis】Redis线程模型

目录 1. Redis 是单线程的,还是多线程的?2. Redis单线程模式是怎么样的?Redis 单线程模式的优势Redis 单线程的局限性Redis 单线程的优化策略 3. Redis采用单线程为什么还这么快4. Redis 6.0 之前为什么使用单线程?5. Redis 6.0 之…

每日学习一个数据结构-图

文章目录 图基础一、图的定义二、图的相关概念三、图的分类四、图的使用场景 和图相关的算法一、图的遍历算法二、最短路径算法三、最小生成树算法四、图匹配算法五、网络流算法 图基础 一、图的定义 在数学中,图是描述于一组对象的结构,其中某些对象对…

数据结构单向链表

单向链表的转置 转置的思想: (1) 将头节点与当前链表断开,断开前保存下头节点的下一个节点,保证后面链表能找得到,定义一个q保存头节点的下一个节点,断开后前面相当于一个空的链表,后面是一个无头的单向链表…

动态内存管理练习题的反汇编代码分析(底层)

1.C语言代码 #include <stdio.h> char* GetMemory(void) {char p[] "hello world";return p; }void Test(void) {char* str NULL;str GetMemory();printf(str); }int main() {Test();return 0; } 2.反汇编代码 VS2022x64debug #include <stdio.h>…

给普通的div或者view等元素添加onblur事件的方式

一般只有input元素有blur事件&#xff0c;但是如果想给普通的元素设置了blur事件之后&#xff0c;它是不会正常直行的。还需要再给元素添加tabindex属性&#xff0c;设置了tabindex属性之后&#xff0c;元素会带有一个下划线&#xff0c;还要去掉下划线&#xff0c;而且聚焦的时…

PostgreSQL学习笔记二:PostgreSQL的系统架构

PostgreSQL 是一种功能强大的开源关系型数据库管理系统&#xff0c;其架构具有以下特点&#xff1a; 一、客户端/服务器架构 客户端 客户端可以是各种应用程序&#xff0c;如 Web 应用、桌面应用等&#xff0c;它们通过网络连接与 PostgreSQL 服务器进行通信。客户端使用标准的…

力扣之603.连续空余座位

文章目录 1. 603.连续空余座位1.1 题干1.2 准备数据1.3 思路分析1.4 解法1.5 结果截图 1. 603.连续空余座位 1.1 题干 表: Cinema ----------------- | Column Name | Type | ----------------- | seat_id | int | | free | bool | ----------------- Seat_id 是该表的自动递…

2024-你自学网络安全的顺序可能一直是反的!

作为一名在网络安全领域工作了八年的技术人员&#xff0c;我想分享一些经验给2024年学习黑客技术的朋友们。 千万不要毫无基础就开始学黑客!一定要先了解相关的信息和知识! 对于刚入行的朋友&#xff0c;我建议先从网络安全或Web安全/渗透测试入手&#xff0c;这些方向市场需求…

【可答疑】基于51单片机的光照强度检测(含仿真、代码、报告、演示视频等)

✨哈喽大家好&#xff0c;这里是每天一杯冰美式oh&#xff0c;985电子本硕&#xff0c;大厂嵌入式在职0.3年&#xff0c;业余时间做做单片机小项目&#xff0c;有需要也可以提供就业指导&#xff08;免费&#xff09;~ &#x1f431;‍&#x1f409;这是51单片机毕业设计100篇…

基于STM32的智能仓库温湿度监控系统设计

引言 本项目设计了一个基于STM32的智能仓库温湿度监控系统&#xff0c;能够实时监测仓库内的温度和湿度&#xff0c;并根据设定的阈值触发报警或启动风扇调节环境。该系统通过DHT11温湿度传感器获取环境数据&#xff0c;结合OLED显示屏、风扇和蜂鸣器&#xff0c;实现对仓库环…

python中的数组模块numpy(一)(适用物联网数据可视化及数据分析)

一、创建数组对象array&#xff0c;认识数组的格式 array函数的格式:np.array(object,dtype,ndmin) 以下是示例代码&#xff1a; # coding:utf-8 import numpy as np d1[1.1,2.1,3.1] d2(1,2,3,4) d3[[a,b],[c,d],[e,f]] print(d1) print(d2) print(d3) print("以上是数…

无法编辑PDF文件?试试这3个解决方法!

PDF文件格式广泛应用于工作中&#xff0c;但有时候我们可能遇到无法编辑PDF文件的情况。这可能导致工作效率降低&#xff0c;特别是在需要修改文件内容时显得尤为棘手。遇到PDF不能编辑时&#xff0c;可以看看是否以下3个原因导致的。 原因一&#xff1a;PDF文件设置了编辑权限…

八大排序--06基数排序(桶排序)

【本质--先排序个位&#xff0c;再排序十位&#xff0c;排百位...依次类推的过程】 获取待排序数组中的最高位数 //取计算最大值的位数int maxarr[0];for(int j0;j<arr.length;j) {if(arr[j]>max) {maxarr[j];}} 存储数据&#xff08;桶排序中除了游标遍历外&#xff…

【数据结构 | PTA】栈

文章目录 7-1 汉诺塔的非递归实现7-2 出栈序列的合法性**7-3 简单计算器**7-4 盲盒包装流水线 7-1 汉诺塔的非递归实现 借助堆栈以非递归&#xff08;循环&#xff09;方式求解汉诺塔的问题&#xff08;n, a, b, c&#xff09;&#xff0c;即将N个盘子从起始柱&#xff08;标记…

分析和解决js运算精度问题,出现多位小数

加减乘除都会出现小数精度错误的问题 (见图) 原因&#xff1a;js进行运算时会将数字先转为二进制再进行运算。 错误思路&#xff1a;之前在做数字运算时都是将数字转化为整数再进行运算&#xff0c;某次突然发现在变整数的时候也会出现精度问题&#xff0c;比如上图中的数据。…

LINUX——内核移植、内核编译教程

Linux内核编译是一个将内核源代码转换成可在特定硬件架构上运行的二进制文件的过程。以下是编译Linux内核的一般步骤&#xff1a; 1、准备工作&#xff1a; 确保安装了必要的编译工具&#xff0c;如gcc、make、ncurses库&#xff08;用于make menuconfig&#xff09;等。 2、…