salesforce 零基础学习(六十二)获取sObject中类型为Picklist的field values(含record type)

本篇引用以下三个链接:

http://www.tgerm.com/2012/01/recordtype-specific-picklist-values.html?m=1

https://github.com/abhinavguptas/Multi-RecordType-Sobject-Picklist-Describer

http://bobbuzzard.blogspot.com/2012/01/record-type-picklist-values.html

我们知道,record type可以设置不同的profile针对类型为picklist的字段显示不同的values,但是apex的API中,通过schema取出的Picklist的values为全部的值,并不能直接通过指定的方法取出指定的values。通过上述三个链接可以很好的解决。

原理图如下:

用法:

1.通过Record ID获取其对应的record type name 以及类型为picklist的field values。

2.通过sObjectType,Record Type Name以及field Name 获取类型为picklist的field values。

其实,每个customer object都会有一个recordtype字段,用来记录当前的record的record type id。所以如果仅仅想在页面上通过record id获取当前record 具有的field 的picklist values,只需要用<apex:inputField>来盛装此字段即可.inputField可以根据字段的类型显示不同的样式。

PicklistController:通过URL传递的不同参数进行不同的处理,点击按钮后显示所选的项的value

public with sharing class PicklistController {
    public Goods__c goods {get;set;}
    public String pickListFieldName {get;set;}  
    
    public PicklistController() {
        Map<String, String> req = ApexPages.currentPage().getParameters();
        PageReference ref = ApexPages.currentPage();
        //设置当前的页面开发模式开启
        //ref.getParameters().put('core.apexpages.devmode.url', '1');
        String goodsId = req.get('id');
        this.pickListFieldName = req.get('picklistFieldName'); 
        String recordTypeId = req.get('recordTypeId');
        goods = new Goods__c();
        if(goodsId != null) {
            goods = [SELECT GoodsBrand__c, RecordTypeId FROM Goods__c where Id=:goodsId limit 1];
        }
        if(goods.RecordTypeId == null) {
            goods.put('RecordTypeId', recordTypeId);
        }
    }
    
    public void showSelectedValue() {
        ApexPages.addMessage(new ApexPages.Message(ApexPages.SEVERITY.INFO,goods.GoodsBrand__c));
    }
}

 PickListDemoPage:显示相关record type对应的picklist items以及button显示所选择的picklist的value值

<apex:page controller="PicklistController"
    showHeader="false" sidebar="false" >
    <apex:form >
        <apex:pageMessages />
        <apex:inputField value="{!goods[pickListFieldName]}"/>
        <apex:commandButton action="{!showSelectedValue}" value="显示所选值"/>
    </apex:form>
    
</apex:page>

效果:

1.通过record id获取此record的record type应该具有的picklist values

2.通过record type id获取相关字段应该具有的picklist values

总结:如果需要在apex中获取相关的picklist values然后进行相关后续处理可以参看上方引用的链接以及源码,如果只是想要页面中显示相关使用record type的picklist values,则可以对相关object配置相关的record type id,前台使用apex:inputField即可。篇中有错误欢迎指出,有问题欢迎留言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏赵俊的Java专栏

手撸 Java Web RBAC 权限管理

权限管理是在项目中经常要使用到的模块,有着极其重要的功能。 在 Java 帝国中有两个比较出名的权限框架,分别为 Shiro 和 Spring Security...

1122
来自专栏用户2442861的专栏

mysql update,insert常用

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/haluoluo211/article/d...

673
来自专栏技术碎碎念

mysql使用基础 sql语句(一)

命令行输入mysql -u root -p,回车再输入密码,进入mysql。 终端命令以分号作为一条语句的结束,可分为多行输入,只需在最后加上分号即可。如下图:...

33910
来自专栏PHP技术

MYSQL数据库设计的一些小技巧[转载]

常用数据操作语言DML笔记(select insert update delete) select 语句 高级的查询功能,见下面的详细内容 s...

3795
来自专栏用户2442861的专栏

cmake教程5-macro宏定义以及传递参数给源文件

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/haluoluo211/article/d...

903
来自专栏农夫安全

注入学习之sqli-labs-3(第二关)

前言 本来是想一个个关卡讲下去,后来自己测试了一下,发现第二、三、四这三关跟第一关,起始原理是一样的,只不过是单引号,双引号,带不带括号的区别,只要我们带入的语...

3296
来自专栏Django Scrapy

mysql相关命令

安装 在ubuntu 14.04 x64下 1 安装 # 安装服务端 (需要中途设置root密码) sudo apt-get install mysql-ser...

3157
来自专栏Hongten

Hibernate中使用memcached

Hibernate-memcached是CacheProvider接口的memcached实现

932
来自专栏www.96php.cn

Discuz分页方法演示

if(!defined('IN_DISCUZ') || !defined('IN_DISCUZ')) {     exit('Access Denied'); ...

39611
来自专栏linux驱动个人学习

分析uboot中 make xxx_config过程

make xxx_config实质上就是调用了 ? 首先看MKCONFIG: ? 【注意】SRCTREE=源文件下的目录 之后的语句: @$(MKCONFIG)...

3385

扫码关注云+社区