Use of Static Resources | Techila
1363
single,single-post,postid-1363,single-format-standard,ajax_updown_fade,page_not_loaded,,qode_grid_1300,footer_responsive_adv,hide_top_bar_on_mobile_header,qode-content-sidebar-responsive,qode-theme-ver-9.4.2,bridge,wpb-js-composer js-comp-ver-4.12,vc_responsive
 

Use of Static Resources

static-resource

Use of Static Resources

Static resources allow you to upload content that you can reference in a Visualforce page, including archives (such as .zip and .jar files), images, style sheets, JavaScript, and other files.

Using a static resource is preferable to uploading a file to the Documents tab because:

·         You can package a collection of related files into a directory hierarchy and upload that hierarchy as a .zip or .jar archive.

·         You can reference a static resource by name in page markup by using the $Resource global variable instead of hard coding document IDs.

A single static resource can be up to 5 MB in size, and an organization can have up to 250 MB of static resources, total.

·         Creating a Static Resource

To create a static resource:

1.      From Setup, enter Static Resources in the Quick Find box, and then select Static Resources.

2.      Click New.

3.      In the Name text box, enter the text that should be used to identify the resource in Visualforce markup. This name can contain only underscores and alphanumeric characters, and must be unique in your org. It must begin with a letter, not include spaces, not end with an underscore, and not contain two consecutive underscores.

4.      In the Description text area, specify an optional description of the resource.

5.      Next to the File text box, click Browse to navigate to a local copy of the resource that you want to upload. A single static resource can be up to 5 MB in size, and an organization can have up to 250 MB of static resources, total.

6.      Set the Cache Control:

    1. Private specifies that the static resource data cached on the Salesforce server shouldn’t be shared with other users. The static resource is only stored in cache for the current user’s session.
    2. Public specifies that the static resource data cached on the Salesforce server be shared with other users in your organization for faster load times.

7.      Click Save.

 

·         Referencing a Static Resource in Visualforce Markup

The way you reference a static resource in Visualforce markup depends on whether you want to reference a stand-alone file, or whether you want to reference a file that is contained in an archive (such as a .zip or .jar file):

·         To reference a stand-alone file, use $Resource.<resource_name> as a merge field, where <resource_name> is the name you specified when you uploaded the resource. For example:

1

<apex:image url=”{!$Resource.TestImage}” width=”50″ height=”50″/>

or

1

<apex:includeScript value=”{!$Resource.MyJavascriptFile}”/>

To reference a file in an archive, use the URLFOR function. Specify the static resource name that you provided when you uploaded the archive with the first parameter, and the path to the desired file within the archive with the second. For example:

1

<apex:image url=”{!URLFOR($Resource.TestZip,

2

‘images/Bluehills.jpg’)}” width=”50″ height=”50″/>

or

1

<apex:includeScript value=”{!URLFOR($Resource.LibraryJS, ‘/base/subdir/file.js’)}”/>

·         You can use relative paths in files in static resource archives to refer to other content within the archive. For example, in your CSS file, named styles.css, you have the following style:

1

table { background-image: url(‘img/testimage.gif’) }

When you use that CSS in a Visualforce page, you need to make sure the CSS file can find the image. To do that, create an archive (such as a zip file) that includes styles.css and img/testimage.gif. Make sure that the path structure is preserved in the archive. Then upload the archive file as a static resource named “style_resources”. Then, in your page, add the following component:

1

<apex:stylesheet value=”{!URLFOR($Resource.style_resources, ‘styles.css’)}”/>

Since the static resource contains both the style sheet and the image, the relative path in the style sheet resolves and the image is displayed.

·         Through a custom controller, you can dynamically refer to the contents of a static resource using the <apex:variable>tag. First, create the custom controller:

1

global class MyController {

2

    public String getImageName() {

· 

3

        return ‘Picture.gif’;//this is the name of the image

4

    }

· 

5

}

Then, refer to the getImageName method in your <apex:variable> tag:

1

<apex:page renderAs=”pdf” controller=”MyController”>

2

    <apex:variable var=”imageVar” value=”{!imageName}”/>

· 

3

    <apex:image url=”{!URLFOR($Resource.myZipFile, imageVar)}”/>

4

</apex:page>

If the name of the image changes in the zip file, you can just change the returned value in getImageName.

 

Courtesyhttps://developer.salesforce.com/docs/atlas.en-us.pages.meta/pages/pages_resources_reference.htm

Author: techila

No Comments

Post A Comment