官术网_书友最值得收藏!

Passing parameters between Visualforce pages

If a user is redirected from one Visualforce page to another and they both share the same controller and extensions, the controller instance will be retained and re-used, allowing the second page to access any information captured by the first.

If the pages do not share the same controller and extensions, the controller instance will be discarded and the second page will have no access to any information captured by the first. If the state needs to be maintained across the pages in this case, it must be encapsulated in the parameters on the URL of the second page.

In this recipe, we will build on the example from the previous recipe to create a Visualforce search page to retrieve all accounts where the name contains a string entered by the user, and provide a way for the user to edit selected fields on all the accounts returned by the search. The record IDs of the accounts to edit will be passed as parameters on the URL to the edit page.

How to do it…

As the search page makes reference to the edit page, the edit page and associated custom controller must be created first.

  1. Navigate to the Apex Classes setup page by clicking on Your Name | Setup | Develop | Apex Classes.
  2. Click on the New button.
  3. Paste the contents of the EditFromSearchController.cls Apex class from the code download into the Apex Class area.
  4. Click on the Save button.
  5. Next, create the edit Visualforce page by navigating to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  6. Click on the New button.
  7. Enter EditFromSearch in the Label field.
  8. Accept the default EditFromSearch that is automatically generated for the Name field.
  9. Paste the contents of the EditFromSearch.page file from the code download into the Visualforce Markup area.
  10. Click on the Save button to save the page.
  11. Navigate to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  12. Locate the entry for the EditFromSearch page and click on the Security link.
  13. On the resulting page, select which profiles should have access and click the Save button.
  14. Next, create the search page by navigating to the Apex Classes setup page by clicking on Your Name | Setup | Develop | Apex Classes.
  15. Click on the New button.
  16. Paste the contents of the SearchAndEditController.cls Apex class from the code download into the Apex Class area.
  17. Click on the Save button.
  18. Next, create the Visualforce page by navigating to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  19. Click on the New button.
  20. Enter SearchAndEdit in the Label field.
  21. Accept the default SearchAndEdit that is automatically generated for the Name field.
  22. Paste the contents of the SearchAndEdit.page page from the code download into the Visualforce Markup area.
  23. Click on the Save button to save the page.
  24. Navigate to the Visualforce setup page by clicking on Your Name | Setup | Develop | Pages.
  25. Locate the entry for the SearchAndEdit page and click on the Security link.
  26. On the resulting page, select which profiles should have access and click on the Save button.

How it works…

Opening the following URL in your browser retrieves all accounts where the name field contains the string United: https://<instance>/apex/SearchAndEdit?name=United.

Here, <instance> is the Salesforce instance specific to your organization, for example, na6.salesforce.com.

Notice that the page contains an Edit button, and clicking on this executes the following action method:

public PageReference edit()
{
  PageReference pr=Page.EditFromSearch;
  Integer idx=1;
  for (Account acc : accounts)
  {
    pr.getParameters().put('account' + idx, acc.id);
    idx++;
  }
    
  return pr;
}

This method initially creates a page reference for the edit page—EditFromSearch. It then iterates the accounts in the search results and adds an entry to the page reference parameters for the account ID. Each parameter has the name account, concatenated with the index of the result, starting from 1. This will result in a URL of the form https://<instance>/apex/EditFromSearch?account1=001i0000006OVLIAA4&account2=001i0000006OVLJAA4.

The EditFromSearch page then renders a form with an editable row per account.

The constructor of EditFromSearchController that manages the data for the page extracts the IDs from the URL and adds them to a list, starting with account1, until it hits a parameter index that is not present in the URL.

Integer idx=1;
String accStr;
do 
{
  accStr=ApexPages.currentPage().getParameters().
get('account' + idx);
  if (accStr!=null)
  {
    ids.add(accStr);
  }
  idx++;
}
while (null!=accStr);

The action method that saves the user's edits redirects them to the standard account tab once the save is complete.

return new PageReference('/001/o');
Note

Note that accessing the standard tab via this URL is not supported by Salesforce, and if the URL scheme or three character prefix for account (001) were to change, this redirection would stop working.

See also

  • The Reacting to URL parameters recipe in this chapter shows how a controller can process URL parameters prior to rendering a Visualforce page.
主站蜘蛛池模板: 娄烦县| 义乌市| 丽水市| 滁州市| 湖北省| 阳朔县| 新昌县| 大同县| 闽侯县| 顺昌县| 依安县| 兴海县| 剑川县| 锡林浩特市| 迁安市| 武定县| 修水县| 天峨县| 大埔区| 东明县| 昭通市| 洛宁县| 汨罗市| 乌拉特中旗| 江永县| 松滋市| 塔河县| 三都| 渭南市| 开原市| 宁陕县| 云阳县| 阜城县| 淳化县| 沾化县| 新源县| 泸溪县| 梨树县| 永顺县| 镇原县| 顺平县|