ホームページ php教程 php手册 Easyui 实现3级联动的用户选择功能

Easyui 实现3级联动的用户选择功能

Jun 07, 2016 am 11:39 AM

3级联动用户选择功能
由于最近开发了一个新的办公信息系统,需要用到站内信功能,发站内信时接受人的信息是用点选的,找了好多资料,但实现起来还是比较麻烦,做完上去easyui的官网看了下,已经更新到1.4.2了,看了下更新内容新增了datalist的功能,昨晚睡前想好实现的思路,今天一早开始码代码!很简单的一个方法,放上来分享,没有demo,只说说实现的方法和简单的代码。
先上一张图吧!
Easyui 实现3级联动的用户选择功能

左边的部门是个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-&gt;display();<br>     }<br> <br>     public function getDeptTree(){    //部门树形表格数据<br>         $data = M('Department')-&gt;order('sort')-&gt;select();<br>         $this-&gt;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')-&gt;where($where)-&gt;field('uid,department,username')-&gt;order('sort')-&gt;select();<br>             if (empty($dataArr)) {<br>                 $dataArr[0]['username'] = '没有数据';<br>             }<br>         }<br>         $this-&gt;ajaxReturn($dataArr);<br>     }不太懂去表达要去表达的东西,希望可以看得懂,也希望可以帮到您,更希望大家可以给更好的建议!!勿喷~~~~

pm:easyui是最新的1.4.2版本,老版本没有datalist组件的!!

AD:真正免费,域名+虚机+企业邮箱=0元

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Python プログラミングの入門コード例について学びます。 Python プログラミングの入門コード例について学びます。 Jan 04, 2024 am 10:50 AM

Python プログラミングの入門コード例について学びます。

PHP 変数の実際の使用: 10 の実際の使用例 PHP 変数の実際の使用: 10 の実際の使用例 Feb 19, 2024 pm 03:00 PM

PHP 変数の実際の使用: 10 の実際の使用例

初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 Mar 04, 2024 pm 03:09 PM

初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装

PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法 PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法 Aug 06, 2023 pm 04:49 PM

PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法

Java は単純なバブルソートコードを実装します Java は単純なバブルソートコードを実装します Jan 30, 2024 am 09:34 AM

Java は単純なバブルソートコードを実装します

Go 言語プログラミングの例: Web 開発のコード例 Go 言語プログラミングの例: Web 開発のコード例 Mar 04, 2024 pm 04:54 PM

Go 言語プログラミングの例: Web 開発のコード例

Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例 Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例 Jul 05, 2023 pm 09:57 PM

Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例

ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。 ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。 Feb 18, 2024 am 10:52 AM

ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。

See all articles