Friday, 17 January 2020

Access attributes in component

NOTE: To access an attribute in a component, use expressions as {! v.<Attribute Name>}.
----------------------------------------------------------------------------------------------------------------------

<aura:component >
    <!--Basic types-->
    <aura:attribute name="ItemName" type="String" default="Bag"/>
    <aura:attribute name="SerialNumber" type="Long" default="1"/>
    <aura:attribute name="Quantity" type="Integer" default="2"/>
    <aura:attribute name="Price" type="Decimal" default="blue"/>
    <aura:attribute name="PurchaseDate" type="Date" default="2018-11-9"/>
    <aura:attribute name="Dispatched" type="Boolean" default="true"/>
    <aura:attribute name="Color" type="String" default="blue"/>
   
    <!--Collection types-->
    <aura:attribute name="ColorArray" type="String[]" default="['red', 'green', 'blue']"/>
    <aura:attribute name="ColorList" type="List" default="['red', 'green', 'blue']"/>
    <aura:attribute name="ColorMap" type="Map" default="{a: 'red', b: 'green', c: 'blue'}"/>
    <aura:attribute name="ColorSet" type="Set" default="['red', 'green', 'blue','red']"/>
   
    <!--Object types-->
    <aura:attribute name="PersonObject" type="Object" default="{'name': 'John', 'age': '25'}"/>
   
    <a><b>My component</b></a>
   
    <h1>This is a test component</h1>
    <p>Your component code goes here.</p>
    <p>
<!--Using collection Types-->
    <strong>Array values</strong>
        <aura:iteration items="{! v.ColorArray}" var="color">
        <div>{! color} </div>
        </aura:iteration>
       
        <strong>List values</strong>
        <aura:iteration items="{! v.ColorList}" var="color">
        <div>{! color} </div>
        </aura:iteration>
       
        <strong>Map values</strong>
       
        <div>{! v.ColorMap.a} </div>
        <div>{! v.ColorMap.b} </div>
        <div>{! v.ColorMap.c} </div>
       
        <strong>Set values</strong>
        <aura:iteration items="{! v.ColorSet}" var="color" indexVar="index">
        <div>{! color} </div>
        </aura:iteration>
    </p>

</aura:component>




Note: To access an attribute in a controller and helper, use expressions as {v.<Attribute Name>}:
=======================================================================

({
doInit : function(component, event, helper) {
//javascript to initialize the component
var color = component.get("v.Color");
        var Price = component.get("v.Price");
        console.log('color is ',color);
        console.log('Price is ',Price);
}

})

Note: When we using the attribute in Component, we must use the exclamatory sign. But when we access the attribute in Controller and Helper, we do not use exclamatory sign.

OUTPUT









How to declare different types of attributes in component

<aura:component >
    
    <!--Basic types-->
    <aura:attribute name="ItemName" type="String" default="Bag"/>
    <aura:attribute name="SerialNumber" type="Long" default="1"/>
    <aura:attribute name="Quantity" type="Integer" default="2"/>
    <aura:attribute name="Price" type="Decimal" default="4578.67"/>
    <aura:attribute name="PurchaseDate" type="Date" default="2018-11-9"/>
    <aura:attribute name="Dispatched" type="Boolean" default="true"/>
    <aura:attribute name="Color" type="String" default="blue"/>
    
    <!--Collection types-->
    <aura:attribute name="ColorArray" type="String[]" default="['red', 'green', 'blue']"/>
    <aura:attribute name="ColorList" type="List" default="['red', 'green', 'blue']"/>
    <aura:attribute name="ColorMap" type="Map" default="{a: 'red', b: 'green', c: 'blue'}"/>
    <aura:attribute name="ColorSet" type="Set" default="['red', 'green', 'blue','red']"/>
    
    <!--Object types-->
    <aura:attribute name="PersonObject" type="Object" default="{'name': 'John', 'age': '25'}"/>
    
    <p>Your component code goes here.</p>
    
</aura:component>



Note :  The type value of an attribute is case insensitive, and also when you use a particular attribute in an expression the name of the attribute should match with the name specified in attribute definition i.e. the name inside expressions is case sensitive.

Parameters of attribute:

Access : Indicates whether the attribute can be used outside of its own namespace. Possible values are public (default), and global, and private.
Name : The name of the attribute. It is required and must be provided.
Type  : Type of the attribute. It could be any of the type that we discussed above like String, Boolean etc.
Default : The default value that you want to provide to the attribute.
Required : It contains boolean value true or false.  The default value is false.

Description : A brief summary of the attribute and its usage.

What is aura attribute and what are the types in lightning?

Aura Attribute

====================================================================
An aura attribute is like a variable that we use in a programming language or in Apex class. These are typed fields and set on a specific instance of a component. These attributes can be used inside the component as expressions and in controller and helper as well.


Types of Attributes

=====================================================================

A: Basic Types: 
---------------------------------

These are the basic attributes that contain values of primitive types like integer, string, boolean etc.
1. String :- It stores simple text values like color, name etc.
2. Boolean :- It stores boolean values like true or false.
3. Decimal :- It stores values with fractional part. Used to store values like price.
4. Integer :- It stores integer/Number values like quantity etc.
5. Double :- It stores fractional values like price, currency values.
6. Date :- It stores date values in yyyy-mm-dd format.
7. DateTime :- It stores date values with timestamp.
8. Long :- It stores non fractional values with wider range than integer.


B: Collection Types:
--------------------------------
Lightning supports the collection type attributes like an array, list and map.
  1. Array : An array of items of a defined type
  2. List: An ordered collection of items.
  3. Map: A collection that maps keys to values. A map can’t contain duplicate keys. Each key can map to at most one value. Defaults to an empty object, {}.
  4. Set: A collection that contains no duplicate elements. The order for set items is not guaranteed. For example, “[‘red’, ‘green’, ‘blue’]” might be returned as blue, green, red.
Attributes of these types are typically used in iterations in lightning to display data.
C: Object Types
-----------------------------------
An attribute can have the type as “Object”. The object is stored in JSON format.

D: Apex Class Types
-----------------------------------
An attribute can have the type as “Apex Class”.

Access attributes in component

NOTE: To access an attribute in a  component , use expressions as  {! v.<Attribute Name>} . ----------------------------------------...