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

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.
主站蜘蛛池模板: 鞍山市| 濮阳市| 栖霞市| 沙洋县| 东明县| 繁昌县| 五常市| 仁怀市| 唐河县| 清河县| 大新县| 阜平县| 白朗县| 徐汇区| 寿宁县| 华阴市| 大洼县| 玛多县| 南川市| 布尔津县| 阜康市| 陵川县| 徐汇区| 全椒县| 贵港市| 万盛区| 西和县| 鹿泉市| 和硕县| 额敏县| 平湖市| 沽源县| 科尔| 水城县| 沅江市| 炎陵县| 年辖:市辖区| 莎车县| 保靖县| 丰县| 普格县|