function readOnly(count){ }
Starting November 20, the site will be set to read-only. On December 4, 2023,
forum discussions will move to the Trailblazer Community.
+ Start a Discussion
anjisalesforce@gmail.comanjisalesforce@gmail.com 

What is the Difference Between ActionFunction and ActionSupport?

Hi all,

 

What is the Difference Between ActionFunction and ActionSupport?

 

Please helpme it's very Urgent...

 

Thanks for your help

Devendra@SFDCDevendra@SFDC

Hi,

 

Please refer Here

 

Hope this helps:)

 

Thanks,

Devendra

 

If a reply to a post answers your question or resolves your problem, please mark it as the solution to the post so that others may benefit.

Navatar_DbSupNavatar_DbSup

Hi,

Action Function: provides support for invoking controller action methods directly from JavaScript code using an AJAXrequest Used when we need to perform similar action on various events. Even though you can use it in place of actionSupport as well where only event is related to only one control.

 Example:

Action Function: provides support for invoking controller action methods directly from JavaScript code using an AJAXrequest

 

Example :

<!-- Page: -->

<apex:page controller="exampleCon">

<apex:form>

<!-- Define the JavaScript function sayHello-->

<apex:actionFunction name="sayHello" action="{!sayHello}" rerender="out"

status="myStatus"/>

</apex:form>

<apex:outputPanel id="out">

<apex:outputText value="Hello "/>

<apex:actionStatus startText="requesting..." id="myStatus">

<apex:facet name="stop">{!username}</apex:facet>

</apex:actionStatus>

</apex:outputPanel>

<!-- Call the sayHello JavaScript function using a script element-->

<script>window.setTimeout(sayHello,2000)</script>

<p><apex:outputText value="Clicked? {!state}" id="showstate" /></p>

<!-- Add the onclick event listener to a panel. When clicked, the panel triggers

the methodOneInJavascript actionFunction with a param -->

<apex:outputPanel onclick="methodOneInJavascript('Yes!')" styleClass="btn">

Click Me

</apex:outputPanel>

<apex:form>

<apex:actionFunction action="{!methodOne}" name="methodOneInJavascript"

rerender="showstate">

<apex:param name="firstParam" assignTo="{!state}" value="" />

</apex:actionFunction>

</apex:form>

</apex:page>

 

/*** Controller ***/

public class exampleCon {

String uname;

public String getUsername() {

return uname;

}

public PageReference sayHello() {

uname = UserInfo.getName();

return null;

}

public void setState(String n) {

state = n;

}

public String getState() {

return state;

}

public PageReference methodOne() {

return null;

}

private String state = 'no';

}

 

 

ActionSupport : A component that adds AJAX support to another component, allowing the component to be refreshed asynchronously by theserver when a particular event occurs, such as a button click or mouseover.?

 

Used when we want to perform an action on a perticular eventof any control like onchange of any text box or picklist.

 

Example :

 

<!-- Page: -->

<apex:page controller="exampleCon">

<apex:form>

<apex:outputpanel id="counter">

<apex:outputText value="Click Me!: {!count}"/>

<apex:actionSupport event="onclick"

action="{!incrementCounter}"

rerender="counter" status="counterStatus"/>

</apex:outputpanel>

<apex:actionStatus id="counterStatus"

startText=" (incrementing...)"

stopText=" (done)"/>

</apex:form>

</apex:page>

 

 

/*** Controller: ***/

public class exampleCon {

Integer count = 0;

public PageReference incrementCounter() {

count++;

return null;

}

public Integer getCount() {

return count;

}

}

 

 

Did this answer your question? If not, let me know what didn't work, or if so, please mark it solved.