之前的一篇介绍过关于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,有兴趣的朋友可以自己添加以及完善。

salesforce 零基础学习(二十八)使用ajax方式实现联动的更多相关文章

  1. salesforce 零基础学习(十八)WorkFlow介绍及用法

    说起workflow大家肯定都不陌生,这里简单介绍一下salesforce中什么情况下使用workflow. 当你分配许多任务,定期发送电子邮件,记录修改时,可以通过自动配置workflow来完成以上 ...

  2. salesforce零基础学习(九十八)Salesforce Connect & External Object

    本篇参考: https://trailhead.salesforce.com/en/content/learn/modules/lightning_connect https://help.sales ...

  3. salesforce 零基础学习(十九)Permission sets 讲解及设置

    Permission sets以及Profile是常见的设置访问权限的方式. Profile规则为'who see what'.通过Profile可以将一类的用户设置相同的访问权限.对于有着相同Pro ...

  4. salesforce 零基础学习(十六)Validation Rules & Date/time

    上一篇介绍的内容为Formula,其中的Date/time部分未指出,此篇主要介绍Date/time部分以及Validation rules. 本篇参考PDF: Date/time:https://r ...

  5. salesforce零基础学习(九十八)Type浅谈

    在Salesforce的世界,凡事皆Metadata. 先通过一句经常使用的代码带入一下: Account accountItem = (Account)JSON.deserialize(accoun ...

  6. salesforce零基础学习(八十二)审批邮件获取最终审批人和审批意见

    项目中,审批操作无处不在.配置审批流时,我们有时候会用到queue,related user设置当前步骤的审批人,审批人可以一个或者多个.当审批人有多个时,邮件中获取当前记录的审批人和审批意见就不能随 ...

  7. salesforce零基础学习(八十)使用autoComplete 输入内容自动联想结果以及去重实现

    项目中,我们有时候会需要实现自动联想功能,比如我们想输入用户或者联系人名称,去联想出系统中有的相关的用户和联系人,当点击以后获取相关的邮箱或者其他信息等等.这种情况下可以使用jquery ui中的au ...

  8. salesforce零基础学习(八十九)使用 input type=file 以及RemoteAction方式上传附件

    在classic环境中,salesforce提供了<apex:inputFile>标签用来实现附件的上传以及内容获取.salesforce 零基础学习(二十四)解析csv格式内容中有类似的 ...

  9. salesforce 零基础学习(五十二)Trigger使用篇(二)

    第十七篇的Trigger用法为通过Handler方式实现Trigger的封装,此种好处是一个Handler对应一个sObject,使本该在Trigger中写的代码分到Handler中,代码更加清晰. ...

  10. salesforce 零基础学习(六十八)http callout test class写法

    此篇可以参考: https://developer.salesforce.com/docs/atlas.en-us.apexcode.meta/apexcode/apex_classes_restfu ...

随机推荐

  1. ftp 服务器搭建和添加用户和目录

    安装: yum install  -y vsftpd 修改配置: vsftpd.conf 修改:anonymous_enable=YES 改为:anonymous_enable=NO 启动/停止/重启 ...

  2. 【OSG学习笔记之一:】OSG+VS2010+win7 64位环境搭建

    虽然出生的时候,没有说过“Hello World!”,但是自从走上了编程之路,每一次输出“Hello World!”的时候,都觉得好比中了彩票大奖似的: 仔细算算,从2012年暑假到现在,经历了3年半 ...

  3. Build Android Webrtc Libjingle Library On Ubuntu

    Our team is developing an app to help people solve problem face to face. We choose webrtc protocol a ...

  4. velocity模板入门

    $!{velocityCount}  随机

  5. 网页中插入FLASH(swf文件)的html代码

    一.简单插入flash图像<embed src="你的flash地址.swf"width="300" height="220"> ...

  6. H5 canvas填充文字自动换行

    canvas是H5中非常重要,非常常用,也是非常强大的一个新标签,美中不足的事,canvas中没没有自动换行的属性,我的第一反应是,字符串截取,然后计算每行的距离来实现自动换行.. 然后百度了一下,已 ...

  7. git 证书错误

    git clone https://github.com/openstack-dev/devstack.git Cloning into 'devstack'... error: server cer ...

  8. nginx实时记录请求状态信息( ngx_realtime_request_module)

    cd /usr/local/src/ wget "http://nginx.org/download/nginx-1.4.2.tar.gz" tar -xzvf nginx.tar ...

  9. Android Meun 用法

    Android Meun 用法 点击菜单实体键弹出菜单:如下图 main_activity.xml <?xml version="1.0" encoding="ut ...

  10. 从现在开始,使用简单优雅的validata.js

    表单验证,是后台开发中万年不变的话题,在经历许多实战之后发现 使用优雅便捷的validate.js实现验证实在是一件非常愉悦的事情 <form data-validate> Enter: ...