Easyui 实现3级联动的用户选择功能
3级联动用户选择功能
由于最近开发了一个新的办公信息系统,需要用到站内信功能,发站内信时接受人的信息是用点选的,找了好多资料,但实现起来还是比较麻烦,做完上去easyui的官网看了下,已经更新到1.4.2了,看了下更新内容新增了datalist的功能,昨晚睡前想好实现的思路,今天一早开始码代码!很简单的一个方法,放上来分享,没有demo,只说说实现的方法和简单的代码。
先上一张图吧!
左边的部门是个tree,点击部门的时候,会获取该部门的用户,获取到的用户显示到中间的“待选用户”里,单击"待选用户"的姓名,会直接在已选用户中插入。
单击部门的tree组件的时候,会获取“已选用户”的uid,然后将获取到的uid和部门id发给后台过滤,这样,“待选用户”里的数据就不会和“已选用户”的数据重复。
先看看selectUser.html的代码吧!<div>
<br>
<div>
<br>
<div>
<br>
<div>
<br>
<table></table>
<br>
</div>
<br>
<div>
<br>
<br>
</div>
<br>
</div>
<br>
</div>
<br>
<div>
<br>
<ul></ul>
<br>
</div>
<br>
<div>
<br>
<a></a><br>
</div>
<br>
<div>
<br>
<ul></ul>
<br>
</div>
<br>
</div>
JS代码:Hzcwd.ns("Hzcwd.Admin.Common.SelectUser");<br>
<br>
var $selectUserTree = $('#admin_common_selectuser_tree'), $selectUserUnselectDataList = $('#admin_common_selectuser_unselect_datalist'), $selectUserSelectDataList = $('#admin_common_selectuser_selected_datalist');<br>
<br>
$(function() {<br>
$selectUserTree.tree({<br>
url: '{:U("/Admin/Common/getDeptTree")}',<br>
fit: true,<br>
animate: true,<br>
nowarp: false,<br>
border: false,<br>
idField: 'id',<br>
treeField: 'deptname',<br>
columns: [<br>
[{<br>
field: 'deptname',<br>
title: '部门名称',<br>
width: 180<br>
}]<br>
],<br>
onClick: function(node) {<br>
if ($(this).tree('isLeaf', node.target) ==true) {<br>
var selected = $selectUserSelectDataList.datalist('getRows');<br>
var uids = [];<br>
$.each(selected, function() {<br>
uids.push(this.uid);<br>
});<br>
$selectUserUnselectDataList.datalist('load',{<br>
deptid:node.id,<br>
uids:uids,<br>
})<br>
}else{<br>
$(this).tree('toggle', node.target);<br>
}<br>
}<br>
});<br>
<br>
$selectUserUnselectDataList.datalist({<br>
title:'待选用户',<br>
fit:true, <br>
border:true, <br>
plain:false, <br>
valueField: 'uid', <br>
textField: 'username', <br>
singleSelect: false,<br>
url: '{:U("./Admin/Common/getUserList")}',<br>
onClickRow:function(index,row){<br>
$selectUserSelectDataList.datalist('appendRow',row)<br>
$(this).datalist('deleteRow',index)<br>
}<br>
<br>
})<br>
<br>
$selectUserSelectDataList.datalist({<br>
title:'已选用户',<br>
fit:true, <br>
border:true, <br>
plain:false, <br>
valueField: 'uid', <br>
textField: 'username', <br>
singleSelect: false,<br>
<br>
onClickRow:function(index,row){<br>
$selectUserUnselectDataList.datalist('appendRow',row)<br>
$(this).datalist('deleteRow',index)<br>
}<br>
})<br>
<br>
Hzcwd.Admin.Common.SelectUser.selectAll = function(){<br>
var data = $selectUserSelectDataList.datalist('getRows');<br>
var uids = [];<br>
$.each(data, function() {<br>
uids.push(this.uid);<br>
});<br>
console.info(uids)<br>
}<br>
})
后台代码:public function selectUser() {<br>
$this->display();<br>
}<br>
<br>
public function getDeptTree(){ //部门树形表格数据<br>
$data = M('Department')->order('sort')->select();<br>
$this->ajaxReturn(getTree($data,'id','pid','deptname'));<br>
}<br>
<br>
public function getUserList(){ //获取部门列表<br>
$deptid = I('deptid');<br>
$uids = I('uids');<br>
$where['department'] = array('eq',$deptid);<br>
$where['uid'] = array('not in',$uids);<br>
if (empty($deptid)) {<br>
$dataArr[0]['username'] = '没有数据';<br>
}else{<br>
$dataArr = M('User')->where($where)->field('uid,department,username')->order('sort')->select();<br>
if (empty($dataArr)) {<br>
$dataArr[0]['username'] = '没有数据';<br>
}<br>
}<br>
$this->ajaxReturn($dataArr);<br>
}
不太懂去表达要去表达的东西,希望可以看得懂,也希望可以帮到您,更希望大家可以给更好的建议!!勿喷~~~~
pm:easyui是最新的1.4.2版本,老版本没有datalist组件的!!
AD:真正免费,域名+虚机+企业邮箱=0元

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Erfahren Sie anhand einführender Codebeispiele mehr über die Python-Programmierung. Python ist eine leicht zu erlernende und dennoch leistungsstarke Programmiersprache. Für Anfänger ist es sehr wichtig, die einführenden Codebeispiele der Python-Programmierung zu verstehen. In diesem Artikel finden Sie einige konkrete Codebeispiele, die Ihnen den schnellen Einstieg erleichtern. Print HelloWorldprint("HelloWorld") Dies ist das einfachste Codebeispiel in Python. Mit der Funktion print() wird der angegebene Inhalt ausgegeben

PHP-Variablen speichern Werte während der Programmlaufzeit und sind für den Aufbau dynamischer und interaktiver WEB-Anwendungen von entscheidender Bedeutung. Dieser Artikel wirft einen detaillierten Blick auf PHP-Variablen und zeigt sie anhand von 10 Beispielen aus der Praxis. 1. Benutzereingaben speichern $username=$_POST["username"];$passWord=$_POST["password"]; Dieses Beispiel extrahiert den Benutzernamen und das Passwort aus der Formularübermittlung und speichert sie zur weiteren Verarbeitung in Variablen. 2. Legen Sie den Konfigurationswert $database_host="localhost";$database_username="username";$database_pa fest

Titel: Vom Anfänger zur Meisterschaft: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache. Datenstrukturen spielen eine wichtige Rolle in der Programmierung und sind die Grundlage der Programmierung. In der Go-Sprache gibt es viele häufig verwendete Datenstrukturen, und die Beherrschung der Implementierung dieser Datenstrukturen ist entscheidend, um ein guter Programmierer zu werden. In diesem Artikel werden die häufig verwendeten Datenstrukturen in der Go-Sprache vorgestellt und entsprechende Codebeispiele gegeben, um den Lesern den Einstieg bis zur Beherrschung dieser Datenstrukturen zu erleichtern. 1. Array Array ist eine grundlegende Datenstruktur, bei der es sich um eine Gruppe desselben Typs handelt.

„Beispiele zur Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung“ Mit der rasanten Entwicklung des Internets ist die Webentwicklung zu einem unverzichtbaren Bestandteil verschiedener Branchen geworden. Als Programmiersprache mit leistungsstarken Funktionen und überlegener Leistung wird die Go-Sprache von Entwicklern in der Webentwicklung zunehmend bevorzugt. In diesem Artikel wird anhand spezifischer Codebeispiele erläutert, wie die Go-Sprache für die Webentwicklung verwendet wird, damit die Leser die Go-Sprache besser verstehen und zum Erstellen ihrer eigenen Webanwendungen verwenden können. 1. Einfacher HTTP-Server Beginnen wir zunächst mit a

Das einfachste Codebeispiel für die Blasensortierung in Java ist ein allgemeiner Sortieralgorithmus. Seine Grundidee besteht darin, die zu sortierende Reihenfolge durch Vergleich und Austausch benachbarter Elemente schrittweise anzupassen. Hier ist ein einfaches Java-Codebeispiel, das zeigt, wie die Blasensortierung implementiert wird: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

So schreiben Sie mit PHP den Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem. Die Bestandsverwaltung ist für viele Unternehmen ein unverzichtbarer Bestandteil. Für Unternehmen mit mehreren Lagern ist die Bestandsverwaltungsfunktion besonders wichtig. Durch die ordnungsgemäße Verwaltung und Nachverfolgung des Lagerbestands können Unternehmen den Lagerbestand auf verschiedene Lager verteilen, die Betriebskosten optimieren und die Effizienz der Zusammenarbeit verbessern. In diesem Artikel erfahren Sie, wie Sie mit PHP Code für Lagerverwaltungsfunktionen schreiben und erhalten relevante Codebeispiele. 1. Richten Sie die Datenbank ein, bevor Sie mit dem Schreiben des Codes für die Lagerverwaltungsfunktion beginnen.

Code-Schreibanleitung und Beispiele für die Java-Auswahlsortierung Die Auswahlsortierung ist ein einfacher und intuitiver Sortieralgorithmus. Die Idee besteht darin, jedes Mal das kleinste (oder größte) Element aus den unsortierten Elementen auszuwählen und es auszutauschen, bis alle Elemente sortiert sind. Dieser Artikel enthält eine Anleitung zum Schreiben von Code für die Auswahlsortierung und fügt spezifischen Java-Beispielcode hinzu. Algorithmusprinzip Das Grundprinzip der Auswahlsortierung besteht darin, das zu sortierende Array in zwei Teile zu unterteilen: sortiert und unsortiert. Dabei wird jeweils das kleinste (oder größte) Element aus dem unsortierten Teil ausgewählt und am Ende des sortierten Teils platziert. Wiederholen Sie das oben Gesagte

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Mit der rasanten Entwicklung der IoT-Technologie und dem Aufstieg des Edge Computing beginnen immer mehr Unternehmen, der Anwendung von Edge Computing Aufmerksamkeit zu schenken. Huawei Cloud bietet Edge-Computing-Dienste und stellt Unternehmen äußerst zuverlässige Computerressourcen und eine praktische Entwicklungsumgebung zur Verfügung, wodurch Edge-Computing-Anwendungen einfacher zu implementieren sind. In diesem Artikel erfahren Sie, wie Sie die Huawei Cloud Edge Computing-Schnittstelle schnell über Java-Code implementieren. Zuerst müssen wir die Entwicklungsumgebung vorbereiten. Stellen Sie sicher, dass Sie das Java Development Kit installiert haben (
