利用yii framework dropdown 创建级联菜单
你经常需要一个表单,级联城市,或者级联的分类等等功能,其中有两个下拉框,一个的值依赖于另外一个下拉框。使用yii 内置的 ajax 功能,你可以创建这样一个下拉框。下面将演示如何实现它。
首先是表单的视图。我们将展示一个表单,显示国家,以及根据国家将显示它的城市。
程序代码 程序代码
php
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' 参数。
0
0
相关文章
php增删改查在ajax里怎么用_异步请求实现无刷新操作【方法】
Ajax如何请求触发php代码执行_Ajax请求触发php代码执行方法【实例】
PHP 的 echo 输出如何在 AJAX 请求中查看与调试
Ajax 调用 PHP 并正确获取返回值的完整实践指南
PHP 的 echo 输出如何在 AJAX 请求中捕获并调试?
相关标签:
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!
41
2025.12.31
想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。
9
2025.12.31
想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!
2
2025.12.31
热门下载
相关下载
精品课程
共7课时 | 0.5万人学习
共18课时 | 1.2万人学习
共18课时 | 3.9万人学习
最新文章






