利用yiiframeworkdropdown创建级联菜单
作者:伤心脑残猪_940 | 来源:互联网 | 2023-05-18 13:17
利用yiiframeworkdropdown创建级联菜单:利用yiiframeworkdropdown创建级联菜单你经常需要一个表单,级联城市,或者级联的分类等等功能,其中有两个下
利用yii framework dropdown 创建级联菜单 你经常需要一个表单,级联城市,或者级联的分类等等功能,其中有两个下拉框,一个的值依赖于另外一个下拉框。使用Yii 内置的 ajax 功能,你可以创建这样一个下拉框。下面将演示如何实现它。 首先是表单的视图。我们将展示一个表单,显示国家,以及根据国家将显示它的城市。 程序代码 程序代码 echo CHtml::dropDownList('country_id','', array(1=>'USA',2=>'France',3=>'Japan'), array( 'ajax' => array( 'type'=>'POST', //request type 'url'=>'dynamiccities', //url to call 'update'=>'#city_id', //selector to update //'data'=>'js:Javascript statement' //leave out the data key to pass all form values through ))); //empty since it will be filled by the other dropdown echo CHtml::dropDownList('city_id','', array()); ?> 第一个下拉框由 几个代表国家的 value/name 对组成。。当它被改变时,一个 ajax 请求将被当前 controller 的 'dynamiccities' action完成。请求的结果( 'dynamiccities' action的输出) 将被替换到第二个id 是#city_id的下拉框。 接下来是 controller action,它将输出 html 以填充第二个下拉框。此外它将依赖于第一个下拉框的值。 程序代码 程序代码 public function actionDynamiccities() { $data=Location::model()->findAll('parent_id=:parent_id', array(':parent_id'=>(int) $_POST['country_id'])); $data=CHtml::listData($data,'id','name'); foreach($data as $value=>$name) { echo CHtml::tag('option', array('value'=>$value),CHtml::encode($name),true); } } ?> 它将检索所有 parent_id 是第一个下拉框值的城市。然后将输出所有这些城市到标签中,最终形成第二个下拉框。 你可能想知道 $_POST['country_id'] 来自哪里。非常简单,当第一个下拉框中的 ajax 数组的 'data' 键为空时,下拉框所在表单所有元素的值将被传递到 controller ,通过 ajax 请求。若你在使用 Firebug 你可以查看这个请求。 这个 behaviour 也可以被改变。默认地,ajax 配置数组 中 'data' 键的值是 js:jQuery(this).parents("form").serialize()。 开头的 js: 告诉 Yii 后面跟的是一个 Javascript 语句,不应被转义。因此,若你改变 'data' 键为另外以 'js:' 开始的语句,你可以填写自己的语句。也适用于 'success' 参数。
推荐阅读
在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ...
[详细]
蜡笔小新 2024-11-12 13:59:27
Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ...
[详细]
蜡笔小新 2024-11-09 11:59:38
Web前端开发源于传统的互联网,互联网普及让人才需求量居高不下,随着移动互联网的高速发展,移动终端的前端开发也越来越受到重视, ...
[详细]
蜡笔小新 2023-10-12 14:13:27
1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ...
[详细]
蜡笔小新 2024-11-12 06:43:20
如何在页面底部添加倾斜样式效果? ...
[详细]
蜡笔小新 2024-11-06 17:52:52
本文针对个人计算机上虚拟机网络配置与数据库远程连接的问题,提供了一套详细的优化指南。在探讨远程数据库访问前,需确保网络配置正确,特别是桥接模式的设置。通过合理的网络配置,可以有效解决因虚拟机或网络问题导致的连接失败,提升远程访问的稳定性和效率。 ...
[详细]
蜡笔小新 2024-11-04 11:43:08
本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ...
[详细]
蜡笔小新 2023-12-13 17:48:58
ItriedtouseFirebugLite(viathebookmarkletandalsoaddingittooneofmywebsites).我尝试使用Fi ...
[详细]
蜡笔小新 2023-10-12 14:37:04
本文是《JavaScript深度解析》系列文章第23篇(共51篇)文档对象模 ...
[详细]
蜡笔小新 2023-10-11 22:37:09
JSCoverage-->JavaScript测试覆盖率检测工具(转),Go语言社区,Golang程序员人脉社 ...
[详细]
蜡笔小新 2023-10-10 16:48:01
打开http:www.vancl.com发现采用的Asp.net,这点我感到很欣慰,毕竟国内采用.net技术体系的优秀网站少之又少。好奇之余右键-查看源 ...
[详细]
蜡笔小新 2023-10-10 16:27:40
本文介绍如何在 Spring Boot 项目中配置全局文件上传路径,并通过读取配置项实现文件上传功能。通过这种方式,可以更好地管理和维护文件路径。 ...
[详细]
蜡笔小新 2024-11-13 11:19:38
重要知识点有:函数参数默许值、盈余参数、扩大运算符、new.target属性、块级函数、箭头函数以及尾挪用优化《深切明白ES6》笔记目次函数的默许参数在ES5中,我们给函数传参数, ...
[详细]
蜡笔小新 2024-11-12 14:57:05
在List和Set集合中存储Object类型的数据元素 ...
[详细]
蜡笔小新 2024-11-09 18:55:32
在本文中,我们将为 HelloWorld 项目添加视图组件,以确保控制器返回的视图路径能够正确映射到指定页面。这一步骤将为后续的测试和开发奠定基础。首先,我们将介绍如何配置视图解析器,以便 SpringMVC 能够识别并渲染相应的视图文件。 ...
[详细]
蜡笔小新 2024-11-07 10:52:57