之前的一篇介绍过关于salesforce手动配置关联关系实现PickList的联动效果,但是现实的开发中,很多数据不是定死的,应该通过ajax来动态获取,本篇讲述通过JavaScript Remoting 方式实现联动效果。
一、JavaScript Remoting简单介绍
上图为PDF中基本介绍,在VF中调用格式如下:
1 Visualforce.remoting.Manager.invokeAction ( '{!$RemoteAction.MyController.myFunction}',
2 param1,param2,
3 function(result, event){
4 //TODO 处理返回结果
5 },
6 {escape: true}
7 );
其中需要在MyController的myFunction上通过@RemoteAction注解标识一下,即
1 public class MyController {
2 @RemoteAction
3 public returnType myFunction(param1,param2) {
4 //returnType为方法需要返回的类型
5 }
6 }
二.联动制作
1.省市关联表制作
省和市具有关联关系,不同的省对应着不同的城市。设计省市关联表:Province_City__c,主要字段包括Name(存储省或市名称),ID__c(编号),Parent_ID__c(此记录对应的父)以及Order_Number__c(此条记录的排序号)
并添加几条记录,记录如下所示:
2.ProvinceCityController的制作
此类中应该实现以下功能:
1.加载需要显示的省;
2.选中某个省后通过省得ID获取此省对应所有的市。
类的内容如下所示:
1 public with sharing class ProvinceCityController {
2
3 public List<SelectOption> provinceOptionList{get;set;}
4
5 public String provinceId{get;set;}
6
7 public static String cityId{get;set;}
8
9 public ProvinceCityController() {
10 List<Province_City__c> provinceList = [select Id,Name,ID__c from Province_City__c where Parent_Id__c = '0' order by Order_Number__c asc];
11 if(provinceList == null) {
12 provinceList = new List<Province_City__c>();
13 }
14 provinceOptionList = new List<SelectOption>();
15 for(Province_City__c province : provinceList) {
16 provinceOptionList.add(new SelectOption(province.ID__c,province.Name));
17 }
18 }
19
20 @RemoteAction
21 public static List<Province_City__c> getCityListByProvince(String provinceId) {
22 List<Province_City__c> cityList;
23 if(provinceId != null && provinceId.length() > 0) {
24 cityList = [select Id,Name,ID__c from Province_City__c where Parent_Id__c = :provinceId order by Order_Number__c asc];
25 }
26 if(cityList == null) {
27 cityId = null;
28 cityList = new List<Province_City__c>();
29 }
30 return cityList;
31 }
32 }
3.ProvinceCityPage页面制作
页面中包含两个下拉框,选择省以后才可以显示市,选择市以后弹出对话框显示市的ID__c
页面代码如下:
1 <apex:page controller="ProvinceCityController">
2 <apex:form id="form">
3 <apex:selectList value="{!provinceId}" id="province" multiselect="false" size="1" onchange="showCity();">
4 <apex:selectOption itemLabel="--None--" itemValue="--None--" rendered="{!if(provinceId==null,true,false)}" />
5 <apex:selectOptions value="{!provinceOptionList}">
6 </apex:selectOptions>
7 </apex:selectList>
8
9 <apex:selectList value="{!cityId}" id="city" multiselect="false" size="1" onchange="showDetail();">
10 <apex:selectOption itemLabel="--None--" itemValue="--None--" rendered="{!if(cityId==null,true,false)}" />
11 </apex:selectList>
12 </apex:form>
13
14 <script>
15 function showCity() {
16 var provinceId = document.getElementById("{!$Component.form.province}").value;
17 console.log(provinceId);
18 Visualforce.remoting.Manager.invokeAction (
19 '{!$RemoteAction.ProvinceCityController.getCityListByProvince}',
20 provinceId,
21 function(result, event){
22 //clear options
23 document.getElementById("{!$Component.form.city}").length = 0;
24 if (event.status) {
25 if(result != null && result.length > 0) {
26 for(var i=0;i<result.length;i++) {
27 var tempOption = new Option();
28 tempOption.value=result[i].ID__c;
29 tempOption.text = result[i].Name;
30 document.getElementById("{!$Component.form.city}").add(tempOption);
31 }
32 } else {
33 var tempOption = new Option();
34 tempOption.value= '--None--';
35 tempOption.text = '--None--';
36 document.getElementById("{!$Component.form.city}").add(tempOption);
37 }
38 }
39 },
40 {escape: true}
41 );
42 }
43
44 function showDetail() {
45 var cityId = document.getElementById("{!$Component.form.city}").value;
46 alert(cityId);
47 }
48 </script>
49 </apex:page>
显示效果如下所示:
当选择黑龙江以后,右侧的市便会显示黑龙江省所包含的市。
当选中具体的市的item,会弹出此城市对应的ID__c。
总结:项目中实现关联主要用到的是js Remoting,只要掌握其基本写法,远程调用请求写法将会很简单方便,代码中只是实现基本功能,未作相关的check,有兴趣的朋友可以自己添加以及完善。