ThinkPHP使用心得分享-ThinkPHP + Ajax 实现2级联动下拉菜单


Posted in PHP onMay 15, 2014

首先是数据库的设计。分类表叫cate.

我做的是分类数据的二级联动,数据需要的字段有:id,name(中文名),pid(父id).

父id的设置: 若数据没有上一级,则父id为0,若有上级,则父id为上一级的id。

数据库有内容后,就可以开始写代码,进行二级联动的实现。

先在后台php获取所有pid为0的数据,保存到$cate中,然后在第一层的<select>中用foreach循环输出。

Html代码:

<select name="type" size="1" id="type">
    <option>请选择类型</option>
     <foreach name='cate' item='v'>
         <option value="{$v['ca_id']}">{$v.ca_name}</option>
     </foreach>
 </select>
 标签:
 <select name="lable" size="1" id="lables">
 </select>

Ajax代码:

  $('#type').click(function(){
            $(this).change(function(){
                var objectModel = {};
                var   value = $(this).val();
               var   type = $(this).attr('id');
                objectModel[type] =value;
                $.ajax({
                    cache:false,
                    type:"POST",
                    url:site.web+"lable",
                    dataType:"json",
                    data:objectModel,
                    timeout:30000,
                    error:function(){
                        alert(site.web+"lable");
                    },
                    success:function(data){
                        $("#lables").empty();
                        var count = data.length;
                        var i = 0;
                        var b="";
                           for(i=0;i<count;i++){
                               b+="<option value='"+data[i].ca_id+"'>"+data[i].ca_name+"</option>";
                           }
                        $("#lables").append(b);
                    }
                });
               });
        }
    );

Ajax代码在第一层类型改变后触发,ajax方法的主要参数有

      1.url:后台接收ajax的地址;

      2.data:传到后台的数据,一般用json传递;这里传递的是选中类的id值。

      3.type:传递方法,有get和post方法,我一般用post,可以传输的数据比get多,安全性也高些;

      4.error:ajax执行失败的方法;

      5.success:ajax执行成功的方法,也就是回调函数。这里在执行success时,我先用empty()清空了第二个下拉菜单的内容,然后再输出从后台获取的数据。

下面是Thinkphp接收ajax数据并处理的页面

//后台ajax验证
  $result = array();
  $cate =$_POST['type'];
  $result = M('cate')->where(array('ca_pid'=> $cate))->field('ca_id,ca_name')->select();
  $this->ajaxReturn($result,"JSON");

Thinkphp的I()方法其实可以看成$_POST[],这样来获取ajax传递过来的第一层选中内容的id,接着,获取其子类,然后用ajaxReturn()返回给ajax,这里设置了返回数据以json形式,所以ajax会以json形式接收到数据

原生php的返回数据方式:

   //搜索结果为$result
   .....
   echo json_encode($result);

这样就完成了2级联动下拉菜单的实现,需要注意的是,url得保证正确,后台接收到也需要有返回值,不然ajax也不会执行success方法的。

PHP 相关文章推荐
PHP4在WinXP下IIS和Apache2服务器上的安装实例
Oct 09 PHP
PHP session常见问题集锦及解决办法总结
Mar 18 PHP
简单示例AJAX结合PHP代码实现登录效果代码
Jul 25 PHP
PHP 一个比较完善的简单文件上传
Mar 25 PHP
PHP file_exists问题杂谈
May 07 PHP
显示youtube视频缩略图和Vimeo视频缩略图代码分享
Feb 13 PHP
php中heredoc与nowdoc介绍
Dec 25 PHP
php防止用户重复提交表单
Nov 02 PHP
php json相关函数用法示例
Mar 28 PHP
php实现的中秋博饼游戏之绘制骰子图案功能示例
Nov 06 PHP
ajax+php实现无刷新验证手机号的实例
Dec 22 PHP
PHP命名空间(namespace)原理与用法详解
Dec 11 PHP
ThinkPHP使用心得分享-上传类UploadFile的使用
May 15 #PHP
ThinkPHP使用心得分享-分页类Page的用法
May 15 #PHP
php自定义函数截取汉字长度
May 15 #PHP
php获取服务器端mac和客户端mac的地址支持WIN/LINUX
May 15 #PHP
php小技巧之过滤ascii控制字符
May 14 #PHP
PHP 之 写时复制介绍(Copy On Write)
May 13 #PHP
PHP中copy on write写时复制机制介绍
May 13 #PHP
You might like
一些关于PHP的知识
2006/11/17 PHP
php at(@)符号的用法简介
2009/07/11 PHP
PHP+Ajax实时自动检测是否联网的方法
2015/07/01 PHP
PHP页面转UTF-8中文编码乱码的解决办法
2015/10/20 PHP
大家须知简单的php性能优化注意点
2016/01/04 PHP
使用PHP处理数据库数据如何将数据返回客户端并显示当前状态
2016/02/16 PHP
分享一个漂亮的php验证码类
2016/09/29 PHP
javascript 极速 隐藏/显示万行表格列只需 60毫秒
2009/03/28 Javascript
Javascript 面向对象 继承
2010/05/13 Javascript
javascript getElementsByClassName实现代码
2010/10/11 Javascript
js实现的切换面板实例代码
2013/06/17 Javascript
探讨js中的双感叹号判断
2013/11/11 Javascript
JS获取浏览器语言动态加载JS文件示例代码
2014/10/31 Javascript
javascript实现label标签跳出循环操作
2016/03/06 Javascript
CodeMirror js代码加亮使用总结
2017/03/25 Javascript
MUI实现上拉加载和下拉刷新效果
2017/06/30 Javascript
vue进入页面时滚动条始终在底部代码实例
2019/03/26 Javascript
layui radio单选限制下一个radio单选的实例
2019/09/03 Javascript
Python写的一个简单监控系统
2015/06/19 Python
Python入门_条件控制(详解)
2017/05/16 Python
详解python OpenCV学习笔记之直方图均衡化
2018/02/08 Python
解决pycharm 误删掉项目文件的处理方法
2018/10/22 Python
Python设计模式之组合模式原理与用法实例分析
2019/01/11 Python
PyQt弹出式对话框的常用方法及标准按钮类型
2019/02/27 Python
Python 经典算法100及解析(小结)
2019/09/13 Python
Pandas时间序列:时期(period)及其算术运算详解
2020/02/25 Python
如何让PyQt5中QWebEngineView与JavaScript交互
2020/10/21 Python
Numpy数组的广播机制的实现
2020/11/03 Python
Python大批量搜索引擎图像爬虫工具详解
2020/11/16 Python
华为消费者德国官方网站:HUAWEI德国
2020/11/03 全球购物
高中生毕业自我鉴定
2013/10/10 职场文书
领导干部考察材料
2014/02/08 职场文书
党员廉洁自律承诺书
2014/05/26 职场文书
2015年感恩节演讲稿(优选篇)
2015/03/20 职场文书
反邪教教育心得体会
2016/01/15 职场文书
win10滚动条自动往上跑怎么办?win10滚动条自动往上跑的解决方法
2022/08/05 数码科技