Labels
apex
(17)
salesforce
(15)
code
(11)
force.com
(11)
best practices
(7)
visualforce
(7)
Artical
(6)
class
(6)
method
(6)
sObject
(6)
tricks
(6)
JS
(5)
SOQL
(5)
tips
(5)
visualforce pages
(5)
helper
(4)
jQuery
(4)
manament
(4)
methods
(4)
101
(3)
CSS
(3)
clases
(3)
classes
(3)
queue
(3)
support
(3)
tablesorter
(3)
Cases
(2)
Contact
(2)
HTML5
(2)
Knowledge Base
(2)
Maps
(2)
Object
(2)
benchmark test
(2)
bug
(2)
challenge
(2)
knowledge
(2)
sites
(2)
style
(2)
user lists
(2)
8 bit
(1)
CSS3
(1)
Canvas
(1)
Comcast
(1)
DataCategories
(1)
Google
(1)
HTML
(1)
JavaScript
(1)
K.I.S.S.
(1)
Keep it simple stupid
(1)
Mario
(1)
Prevent duplicate
(1)
Resources
(1)
SOSL
(1)
Speed
(1)
UX
(1)
Usability
(1)
User interface
(1)
User org shart
(1)
Xfinity
(1)
apex:commandButton
(1)
apex:repeat
(1)
apex:selectCheckboxes
(1)
apex:selectList
(1)
assignTo
(1)
attachments
(1)
batman
(1)
cloudspokes
(1)
component
(1)
controllers
(1)
debug
(1)
debugging
(1)
efficiency
(1)
errors
(1)
for-loop
(1)
gif
(1)
google visualization
(1)
how to
(1)
images
(1)
issue
(1)
jpg
(1)
kiss
(1)
language
(1)
logo
(1)
methodology
(1)
multi-lingual
(1)
no images
(1)
null
(1)
photo
(1)
related list
(1)
rounded
(1)
rounded corners
(1)
set
(1)
spring'11
(1)
standardstylesheets
(1)
static Resources
(1)
system
(1)
test class
(1)
testing
(1)
trigger
(1)
troubleshooting
(1)
user prompt
(1)
variable
(1)
Wednesday, April 9, 2014
Troubleshooting of Set's with sObjects in an apex:repeat
Below is the troubleshooting steps/thought process I took to figure out why my Set wasn't working when it contained sObjects in an apex:repeat. Long story short, its just not possible, it seems that since sets are unordered lists, it cant iterate over sObjects.. I think it still should be able to :-P
I have some code that creates a set (using set so it will be unique) of sObjects and then on the page it iterates over the set using an apex:repeat. The problem is that it wont save. If I change the Set to a List it saves and works fine. Here is the code (simplified) and the errors:
public class CreateOrders {
public Set<Item__c> selectedItems {get; set;}
public CreateOrders() {
selectedItems = new Set<Item__c>();
for (Item__c i : findItems()) {
selectedItems.add(i);
}
}
}
then on the page:
<apex:repeat value="{!selectedItems}" var="itm">
<apex:outputfield value="{!itm.Name}" />
</apex:repeat>
and the resulting error is:
Save error: Could not resolve the entity from apex:outputField value binding '{!itm.Name}'. apex:outputField can only be used with SObjects, or objects that are Visualforce field component resolvable.
When I try removing the apex:outputfield by using apex:outputtext or nothing like so:
<apex:repeat value="{!selectedItems}" var="itm">
<apex:outputtext value="{!itm.Name}" />
</apex:repeat>
OR
<apex:repeat value="{!selectedItems}" var="itm">
{!itm.Name}
</apex:repeat>
I get this error:
Save error: Unknown property 'SetValue.Name'
Its the same with any field/object. But when I switch the Set over to a List it works without any issues... So on a hunch I checked the version, and it was on 28. When I upgraded it to 29, it allowed me to save with apex:outputfield only, but on refresh of the page I still got the same errors:
Could not resolve the entity from apex:outputField value binding '{!itm.Name}'. apex:outputField can only be used with SObjects, or objects that are Visualforce field component resolvable.
It still wouldn't let me save if I changed the apex:outputfield to apex:outputtext or used no apex tags it would still not save and give me the error:
Save error: Unknown property 'SetValue.Name'
On versions older than 29 (20-28 that I have tested) they all error like 28, 29 is the only one with a slightly different behavior. Also when saving with just {!itm} it allows the save to happen, and the page just shows the Id of the Item.
Here is the original stackexchange post with comments from other sfdc users as we tried to figure out this problem, along with the answer :-P I'll be posting more on sets/maps soon :-P
Labels:
apex,
apex:repeat,
debugging,
errors,
force.com,
set,
troubleshooting
Subscribe to:
Posts (Atom)