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

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, clicking on Your Name|Setup|Develop|Visualforce 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|Visualforce 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, 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, clicking on Your Name|Setup|Develop|Visualforce 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|Visualforce 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.
主站蜘蛛池模板: 石渠县| 县级市| 洪雅县| 东山县| 桃江县| 江达县| 元朗区| 和政县| 时尚| 历史| 杭州市| 新泰市| 长岛县| 龙州县| 临桂县| 禄丰县| 漾濞| 额尔古纳市| 仁化县| 房山区| 太和县| 得荣县| 花莲市| 肃宁县| 平山县| 合肥市| 辽中县| 阿拉善右旗| 石柱| 望江县| 阿瓦提县| 平凉市| 舒兰市| 黑水县| 荆州市| 张家港市| 图们市| 昔阳县| 土默特左旗| 青铜峡市| 巴东县|