如何利用PHP实现开发中基于layUI的三级联动效果的代码

如何利用PHP实现开发中基于layUI的三级联动效果的代码

内容导读

收集整理的这篇技术教程文章主要介绍了如何利用PHP实现开发中基于layUI的三级联动效果的代码,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3844字,纯文字阅读大概需要6分钟

内容图文

这篇文章主要介绍了关于如何利用PHP实现开发中基于layUI的三级联动效果的代码,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

后台开发常常用到layUI框架,这样才能让整个页面效果看起来美观大方,然而有时候一些原生的效果放到layUI框架上是无法使用的,比如最近遇到了省市县三级联动的select效果。不同于之前的,layUI框架里,需要重视select的lay-filter属性,来监听事件,另外需要form.render()来重新渲染,解决这两大难题,联动也就不再是难题。下面就来为大家分享下吧。

实现代码:

<!DOCTYPE html><html><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"><title>基于 Layui form 组件的省市区级联的实现</title><link rel="stylesheet" href="http://www.zhengjinfan.cn/plugins/layui/css/layui.css" /></head><body><div style="margin: 50px auto; "><form class="layui-form"><div class="layui-form-item"><label class="layui-form-label">选择地区</label><div class="layui-input-inline"><select name="province" lay-filter="province"><option value="">请选择省</option></select></div><div class="layui-input-inline" style="display: none;"><select name="city" lay-filter="city"><option value="">请选择市</option></select></div><div class="layui-input-inline" style="display: none;"><select name="area" lay-filter="area"><option value="">请选择县/区</option></select></div></div></form></div><script type="text/javascript" src="http://www.zhengjinfan.cn/plugins/layui/layui.js"></script><script type="text/javascript" src="http://www.zhengjinfan.cn/js/area.js"></script><script>(function(){var areaData=Area;var $, $form,form;var $selectProvince,$selectCity,$selectArea;layui.use(['jquery', 'form'], function() {$ = layui.jquery;form = layui.form();$form = $('form');$selectProvince=$form.find('select[name=province]');$selectCity=$form.find('select[name=city]');$selectArea=$form.find('select[name=area]');form.on('select(province)', function(data){var value = data.value;var d = value.split('_');var code = d[0];var count = d[1];var index = d[2];if(count > 0) {loadCity(areaData[index].mallCityList,index);$selectCity.parent().show();} else {$selectCity.parent().hide();$selectArea.parent().hide();$selectCity.find('[data-new=1]').remove();$selectArea.find('[data-new=1]').remove();form.render('select');}});form.on('select(city)', function(data){var value = data.value;var d = value.split('_');var code = d[0];var count = d[1];var index = d[2];var areaIndex=d[3];if(count > 0) {loadArea(areaData[index].mallCityList[index].mallAreaList);$selectArea.parent().show();} else {$selectArea.parent().hide();}});form.on('select(area)', function(data){});loadProvince();});function loadProvince(){for(var i=0,length=areaData.length;i<length;i++){$selectProvince.append('<option value="'+ areaData[i].provinceCode + '_' + areaData[i].mallCityList.length + '_' + i + '">'+areaData[i].provinceName+'</option>')}form.render('select');}function loadCity(citys,areaIndex){$selectCity.find('[data-new=1]').remove();$selectArea.find('[data-new=1]').remove();for(var i=0,length=citys.length;i<length;i++){$selectCity.append('<option data-new ="1" value="'+ citys[i].cityCode + '_' + citys[i].mallAreaList.length + '_' + i + '_'+areaIndex+'">'+citys[i].cityName+'</option>')}form.render('select');}function loadArea(areas){$selectArea.find('[data-new=1]').remove();$selectArea.find('[data-new=1]').remove();for(var i=0,length=areas.length;i<length;i++){$selectArea.append('<option data-new ="1" value="'+ areas[i].areaCode+'">'+areas[i].areaName +'</option>')}form.render('select');}})()</script></body></html>

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于PHP中debug_backtrace() 函数打印调用处的调试信息

聊聊框架开发的依赖注入,容器与外观模式(下部)

以上就是如何利用PHP实现开发中基于layUI的三级联动效果的代码的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的如何利用PHP实现开发中基于layUI的三级联动效果的代码全部内容,希望文章能够帮你解决如何利用PHP实现开发中基于layUI的三级联动效果的代码所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com