Book Image

Visualforce Development Cookbook - Second Edition

By : Keir Bowden
Book Image

Visualforce Development Cookbook - Second Edition

By: Keir Bowden

Overview of this book

Visualforce is a framework that allows developers to build sophisticated, custom user interfaces that can be hosted natively on the Force.com platform. The Visualforce framework includes a tag-based markup language, similar to HTML that is used to write the Visualforce pages and a set of controllers that are used to write business logic to the Visualforce pages. Visualforce Development Cookbook provides solutions to a variety of challenges faced by Salesforce developers and demonstrates how easy it is to build rich, interactive pages using Visualforce. Whether you are looking to make a minor addition to the standard page functionality or override it completely, this book will provide you with the help you require throughout. You will start by learning about the simple utilities and will build up to more advanced techniques for data visualization and to reuse functionality. You will learn how to perform various tasks such as creating multiple records from a single page, visualizing data as charts, using JavaScript to enhance client-side functionality, building a public website, and making data available to a mobile device. With an interesting chapter on tackling common issues faced while developing Visualforce pages, the book provides lots of practical examples to enhance and extend your Salesforce user interface.
Table of Contents (16 chapters)
Visualforce Development Cookbook - Second Edition
Credits
About the Author
About the Reviewer
www.PacktPub.com
Preface

Reacting to URL parameters


The URL parameters are used to pass information to Visualforce pages that the page or controller can then react to. For example, setting a record ID parameter into the URL for a page that uses a standard controller causes the controller to retrieve the record from the database and make it available to the page.

In this recipe, we will create a Visualforce search page to retrieve all accounts where the name contains a string entered by the user. If the parameter name is present in the page URL, a search will be run against the supplied value prior to the page being rendered for the first time.

Getting ready

This recipe makes use of a custom controller, so this will need to be created before the Visualforce page.

How to do it...

  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 SearchFromURLController.cls Apex class from the code download into the Apex Class area.

  4. Click on the Save button.

  5. Next, create the 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 SearchFromURL in the Label field.

  8. Accept the default SearchFromURL that is automatically generated for the Name field.

  9. Paste the contents of the SearchFromURL.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 SearchFromURL page and click on the Security link.

  13. 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 text ni :  https://<instance>/apex/SearchFromURL?name=ni.

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

The constructor of the custom controller is the first method to be called when a Visualforce page is retrieved. This attempts to extract a value for the parameter Name from the page URL, and if one has been supplied, executes the search:

public SearchFromURLController() 
{ 
  searched=false; 
  String nameStr= 
    ApexPages.currentPage().getParameters().get('name'); 
  if (null!=nameStr) 
  { 
      name=nameStr; 
      executeSearch(); 
  } 
} 

Note

Note that the constructor also sets the value retrieved from the URL in the Name property. This property is bound to the input field on the page, and causes the input field to be prepopulated with the value retrieved from the URL when the page is first rendered.

The action method that executes the search is as follows:

public PageReference executeSearch() 
{ 
  searched=true; 
  String searchStr='%' + name + '%'; 
  accounts=[select id, Name, Industry, Type from Account where name LIKE :searchStr]; 
     
  return null; 
} 

Note

Note that searchStr is constructed by concatenating the search term with the % wildcard characters; this allows the user to enter a fragment of text rather than full words. Also, note that the concatenation takes place outside the SOQL query and the resulting variable is included as a bind expression in the query. If the concatenation takes place directly in the SOQL query, no matches will be found. This approach also helps to defend against SOQL injection attacks, as any text input by the user is surrounded by characters that stop embedded database commands from being executed.

See also

  • The Passing parameters between Visualforce pages recipe in this chapter shows how URL parameters can be used to maintain the state across pages that do not share the same controller.