uni-data-picker級聯選擇器、fastadmin后端api

記錄一個部門及部門人員選擇的功能,效果如下:

組件用到了uni-ui的級聯選擇uni-data-picker

開發文檔:uni-app官網

組件要求的數據格式如下:

后端使用的是fastadmin,需要用到fastadmin自帶的tree類生成部門樹 ,后端代碼如下:

 /*** 獲取部門及員工數據(樹形結構)適用于uni-ui的uni-data-picker*/public function getDepartmentAndStaff(){// 獲取所有部門(含層級關系)$departments = Db::name('wecom_department')->field('id, name, parent_id')->order('id ASC')->select();// 構建部門樹$tree = new Tree();$tree->init($departments,'parent_id','    ');$treeList = $tree->getTreeList($tree->getTreeArray(210), 'name'); // 從頂級部門開始// 處理每個部門下的員工$result = [];foreach ($treeList as $dept) {$deptData = ['text' => $dept['name'],       // 前端顯示名稱'value' => 'dept_' . $dept['id'], // 部門唯一標識'children' => [],              // 子節點(員工或子部門)// 保留元數據(可選,前端如需區分部門/員工可使用)'meta' => ['type' => 'department','id' => $dept['id']]];// 查詢部門下的員工(假設部門ID字段為department,需根據實際表結構調整)$staffList = Db::name('wecom_staff')->where('department', $dept['id']) // 員工表中部門關聯字段->field('id, name')->order('id ASC')->select(); // 轉換為數組// 轉換員工數據格式$deptData['children'] = array_map(function ($staff) {return ['text' => $staff['name'],      // 員工顯示名稱'value' => 'staff_' . $staff['id'], // 員工唯一標識'isLeaf' => true,              // 標記為葉子節點(無子節點)'meta' => ['type' => 'employee','id' => $staff['id']]];}, $staffList);$result[] = $deptData;}$this->success('獲取成功', $result);}

注意的點:tree->init()要傳三個參數,特別是第二第三個參數,第二個參數應該為父id的字段名,第三個是空格占位符,默認是  在html會正常識別,但是小程序不行,所以要自己定義占位符。

tree類文件的注釋也寫的非常 清晰了。

設置了自定義占位符和默認的區別。

前端頁面的調用,截取了部分:

<template><!-- 借用信息表單 --><view class="form-section"><view class="form-item"><text class="label">所屬部門</text><uni-data-picker :localdata="departmentData" popup-title="請選擇班級" @change="onchange"@nodeclick="onnodeclick"></uni-data-picker></view></view>
</template><script setup>import {ref,computed} from 'vue'import request from '@/utils/http2.js'const departmentData = ref([])onMounted(() => {// 加載部門樹request({url: '/api/wecomapi/getDepartmentAndStaff',method: 'GET'}).then(res=>{if (res.code) {departmentData.value = res.data;}})})</script>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/83385.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/83385.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/83385.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Mac電腦上本地安裝 redis并配置開啟自啟完整流程

文章目錄 一、安裝 Redis方法 1&#xff1a;通過源碼編譯安裝&#xff08;推薦&#xff09;方法 2&#xff1a;通過 Homebrew 安裝&#xff08;可選&#xff09; 二、配置 Redis1. 創建配置文件和數據目錄2. 修改配置文件 三、配置開機自啟1、通過 launchd 系統服務&#xff08…

wsl安裝linux

安裝wsl 啟用適用于 Linux 的 Windows 子系統 以管理員身份打開 PowerShell &#xff08;> PowerShell > 右鍵單擊 > 以管理員身份運行&#xff09; 并輸入以下命令&#xff0c;然后重啟 dism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsyste…

OpenGL 3D 編程

OpenGL 是一個強大的跨平臺圖形 API,用于渲染 2D 和 3D 圖形。以下是 OpenGL 3D 編程的入門基礎。 一. 環境設置 安裝必要的庫 GLFW: 用于創建窗口和處理輸入 GLEW 或 GLAD: 用于加載 OpenGL 函數 GLM: 數學庫,用于 3D 變換 // 基本 OpenGL 程序結構示例 #include <GL/g…

Android基于LiquidFun引擎實現軟體碰撞效果

一、實現效果 Android使用LiquidFun物理引擎實現果凍碰撞效果 二、Android代碼 // 加載liquidfun動態庫static {System.loadLibrary("liquidfun");System.loadLibrary("liquidfun_jni");}class ParticleData {long id;ParticleSystem particleSystem;float…

Redis持久化機制詳解:RDB與AOF的深度剖析

一、為什么需要持久化&#xff1f; Redis作為內存數據庫&#xff0c;數據存儲在易失性內存中。持久化機制解決兩大核心問題&#xff1a; 數據安全&#xff1a;防止服務器宕機導致數據丟失災難恢復&#xff1a;支持數據備份與快速重建 二、RDB&#xff1a;內存快照持久化 ? …

Netty學習example示例

文章目錄 simpleServer端NettyServerNettyServerHandler Client端NettyClientNettyClientHandler tcp&#xff08;粘包和拆包&#xff09;Server端NettyTcpServerNettyTcpServerHandler Client端NettyTcpClientNettyTcpClientHandler protocolcodecCustomMessageDecoderCustomM…

ThreadLocal ,底層原理,強引用,弱引用,內存泄漏

目錄 ThreadLocal的基本概念 底層實現原理 強引用與弱引用 內存泄漏問題 內存泄漏的解決方案 示例代碼 ThreadLocal的基本概念 ThreadLocal是Java中的一個類&#xff0c;位于java.lang包下&#xff0c;它提供了線程局部變量的功能。每個使用該變量的線程都有自己獨立的初…

TomSolver 庫 | config詳解及其測試

一、C 關鍵特性解析 1. enum class 強類型枚舉 enum class LogLevel { OFF, FATAL, ERROR, WARN, INFO, DEBUG, TRACE, ALL }; enum class NonlinearMethod { NEWTON_RAPHSON, LM };核心特性&#xff1a; 類型安全&#xff1a;禁止隱式轉換為整數作用域限定&#xff1a;必須…

【DB2】ERRORCODE=-4499, SQLSTATE=08001

客戶在連接DB2壓測時報錯ERRORCODE-4499, SQLSTATE08001&#xff0c;連接失敗&#xff0c;主要是因為通信失敗 在本地進行復現&#xff0c;用DBeaver代替java程序&#xff0c;將DB2COMM從TCPIP置為空&#xff0c;重啟后重新連接&#xff0c;報一樣的錯誤 而將防火墻開啟&…

MicroPython+L298N+ESP32控制電機轉速

要使用MicroPython控制L298N電機驅動板來控制電機的轉速&#xff0c;你可以通過PWM&#xff08;脈沖寬度調制&#xff09;信號來調節電機速度。L298N是一個雙H橋驅動器&#xff0c;可以同時控制兩個電機的正反轉和速度。 硬件準備&#xff1a; 1. L298N 電機控制板 2. ESP32…

WPF 全局加載界面、多界面實現漸變過渡效果

WPF 全局加載界面與漸變過渡效果 完整實現方案 MainWindow.xaml <Window x:Class"LoadingScreenDemo.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml&quo…

RabbitMQ深度解析:從基礎實踐到高階架構設計

引言?? 在分布式系統與微服務架構主導的現代軟件開發中&#xff0c;服務間通信的可靠性、異步處理能力及流量管控成為核心挑戰。??RabbitMQ??作為基于AMQP協議的企業級消息中間件&#xff0c;憑借其靈活的路由機制、高可用架構與豐富的擴展能力&#xff0c;成為異步通信…

華為OD機試真題——矩形相交的面積(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳實現

2025 A卷 100分 題型 本專欄內全部題目均提供Java、python、JavaScript、C、C++、GO六種語言的最佳實現方式; 并且每種語言均涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、3個測試用例以及綜合分析; 本文收錄于專欄:《2025華為OD真題目錄+全流程解析+備考攻略+經驗分…

基于隨機函數鏈接神經網絡(RVFL)的鋰電池健康狀態(SOH)預測

基于隨機函數鏈接神經網絡(RVFL)的鋰電池健康狀態(SOH)預測 一、RVFL網絡的基本原理與結構 隨機向量功能鏈接(Random Vector Functional Link, RVFL)網絡是一種單隱藏層前饋神經網絡的隨機化版本,其核心特征在于輸入層到隱藏層的權重隨機生成且固定,輸出層權重通過最…

阿里云國際站,如何通過代理商邀請的鏈接注冊賬號

阿里云國際站&#xff1a;如何通過代理商邀請鏈接注冊&#xff0c;解鎖“云端超能力”與專屬福利&#xff1f; 渴望在全球化浪潮中搶占先機&#xff1f;想獲得阿里云國際站的海量云資源、遍布全球的加速節點與前沿AI服務&#xff0c;同時又能享受專屬折扣、VIP級增值服務支持或…

PMOS以及電源轉換電路設計

PMOS的使用 5V_EN5V時&#xff0c;PMOS截止&#xff1b; 5V_EN0V時&#xff0c;PMOS導通&#xff1b; 電源轉換電路 當Vout0V時&#xff0c;Vg0V, Vgs>Vth, PMOS導通&#xff0c;只有電池供電&#xff1b; 當Vout5V時&#xff0c;Vg4.9V, Vs4.8V?, Vgs<Vth, PMOS截止&am…

云時代:DMZ安全架構的演進與實踐

隨著云計算的普及,傳統的DMZ安全邊界正在經歷根本性變革。本文探討如何在云環境中重新設計和實現DMZ架構,以應對現代安全挑戰。 1. 傳統DMZ與云DMZ的對比 傳統DMZ(隔離區)是網絡安全的經典架構,但云環境帶來了新的挑戰: 特性傳統DMZ云DMZ物理邊界明確的物理網絡分區虛擬網…

mqtt協議連接阿里云平臺

首先現在的阿里云物聯網平臺已經不在新購了&#xff0c;如下圖所示&#xff1a; 解決辦法&#xff1a;在咸魚上租用一個賬號&#xff0c;先用起來。 搭建阿里云平臺&#xff0c;參考博客&#xff1a; &#xff08;一&#xff09;MQTT連接阿里云物聯網平臺&#xff08;小白向&…

職業本科院校無人機專業人才培養解決方案

2023年的中央經濟工作會議強調了以科技創新推動現代化產業體系構建的重要性&#xff0c;并提出發展生物制造、商業航天、低空經濟等戰略性新興產業。低空經濟&#xff0c;依托民用無人機等低空飛行器&#xff0c;在多場景低空飛行活動的牽引下&#xff0c;正逐步形成一個輻射廣…

Go語言字符串類型詳解

1. 定義字符串類型 package mainimport ("fmt");func main() {var str1 string "你好 GoLang 1"var str2 "你好 GoLang 2"str3 : "你好 GoLang 3"fmt.Printf("%v--%T\n", str1, str1)// 你好 GoLang 1--stringfmt.Printf…