Skip to main content

React Basics Part -1

How To install :
before install you should have node & npm installed in the system.
 
npx create-react-app food-order
cd food-order
npm start
 
 
Props : We use to pass the values from one component to another.
For exam,
<Expenses items={expenses} /> //in app.js

  • React component names must always start with a capital letter, while HTML tags must be lowercase.like <Expense items>
  • Your component also can’t return multiple JSX tags. You have to wrap them into a shared parent

Import Notes:

  1. For creating new component & files
  • component folder name would be pascal case (Fisrt letter caps & every starting word as caps) , like AddUserData
  • same as component js file pascal case
  • CSS modules file name : COMPONENTNAME.module.css
  • Custom component tags should start with capital letters while core component as small letters. like <Button> my custom component while <button> is core html attributes.
  • component attributes name should be in camel case like,
    <AddUser onAddUser={onAdduserHandler}></AddUser>

for adding a class either using CSS modules or normally we can use

<Card className={classes.users}>
 

 JSX Limitations:

useeffect() :- its a hook like usestate(),

  • it runs everytime when the component loads.
  • if component state update with in the component then the useeffect will run again,
  •  useeffect can accept the argument as a second argument, we can pass any value function etc, it means whenever that value will change then that will run again, it works as a dependencies.

ReactContext :-

const MyContext = React.createContext(defaultValue);
<MyContext.Provider value={/* some value */}>
and lastly we can cosume the data in any component 

 useref() :-

useRef() only returns one item. It returns an Object called current.

When we initialize useRef we set the initial value: useRef(0).

 

 
 

 

 


Comments

Popular posts from this blog

Get The field values of node in Drupal 8

use Drupal \ node \ NodeInterface ; /** * Implements hook_ENTITY_TYPE_insert() for node entities. * * This tests saving a node on node insert. * * @see \Drupal\node\Tests\NodeSaveTest::testNodeSaveOnInsert() */ function node_test_node_insert ( NodeInterface $node ) { // Set the node title to the node ID and save. if ( $node - > getTitle ( ) == 'new' ) { $node - > setTitle ( 'Node ' . $node - > id ( ) ) ; $node - > setNewRevision ( FALSE ) ; $node - > save ( ) ; } } Now There is so many functions are there to get the values, For All the functions available visit the API code, https://api.drupal.org/api/drupal/core%21modules%21node%21src%21NodeInterface.php/interface/NodeInterface/8.2.x Some of as below, Node edit form, Drupal 8 Automatically Load the whole object no need to load the entity like below, if ($event->getFormId() == 'node_alexa_audio_clips_edit_form') { $node = \Drupal::ro...

How to span column of custom table in Drupal

If you want to span the column of custom drupal table like below image, Follow the below code to make the header of the table , <?php $header = array('S.N','District', array('data' => '<div class ="house">Household </div><br><span>Rural</span> <p>Urban</p>','colspan' => 2), array('data' => '<div class ="house">Members</div> <br><span>Rural</span> <p>Urban</p>','colspan' => 2), 'Duplicate/Failed Registration', array('data' => '<div class ="house">Pending De duplication </div><br><span>Rural</span> <p>Urban</p>','colspan' => 2), 'Non Un-organised Workers', 'SSID Generated', 'No. of Card Personlised', ); $rows[] = arra...

Dependency Injection in Drupal 8

Here are the important nuggets: DI is a design pattern used in programming. DI uses composition. DI achieves inversion of control. Dependency == service that your class needs == object of a certain type. Inject == provide == compose == assemble. Container == service container == dependency container. Instead of using  \Drupal::service('foo_service') , get the service from the  $container  if using a class. And the important reasons: Externalizing dependencies makes code easier to test. It allows dependencies to be replaced without interfering with other functionality. Retrieving dependencies from the container is better for performance. Services: node.grant_storage The easiest examples to find are services that have arguments, because you can search *.services.yml files for the word "arguments". In  node.services.yml  for example, there is this entry: node.grant_storage: class: Drupal\node\NodeGrantDatabaseStorage argument...