Yii2 使用Ajax自动获取表单数据

Yii2 使用Ajax自动获取表单数据

有两张表,表结构如下,locations表存放的省份和邮编等信息,两张表的model和curd均使用gii生成

yii2advanced.customers表

customer_id:int(11)

customer_name:varchar(100)

zip_code:varchar(20)

city:varchar(100)

province:varchar(100)


yii2advanced.locations表

location_id:int(11)

zip_code:varchar(20)

city:varchar(100)

province:varchar(100)


这里要通过在customer选择zip_code之后自动在表单中填充这个邮编对应的城市和省份信息


实现方法

首先需要在Locations控制器里面添加一个方法,他可以通过get过来的zip_id获取对应的location信息


  
  
  1. public function actionGetCityProvince($zipId)
  2. {
  3. $location = Locations::findOne($zipId);
  4. echo Json::encode($location);
  5. }

然后通过JS监听select,当select改变时,使用jQuery的get方法获取对应的信息,并使用jQuery的attr方法设置city和province的value即可

JS代码,位于customer的form视图

#zipCode 是select的id


  
  
  1. <?php
  2. $script = <<<JS
  3. jQuery('#zipCode').change(function(){
  4. var zipId = $(this).val();
  5. jQuery.get('index.php?r=locations/get-city-province',{zipId:zipId},function(data){
  6. var data = jQuery.parseJSON(data);
  7. jQuery("#customers-city").attr("value",data.city);
  8. jQuery("#customers-province").attr("value",data.province);
  9. });
  10.  
  11. });
  12. JS;
  13. $this->registerJs($script);
  14. ?>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值