This repository has been archived by the owner on Apr 21, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 60
Translate first half of API reference: React #80
Open
ShahadIshraq
wants to merge
2
commits into
stale-reactjs-org-translations:main
Choose a base branch
from
ShahadIshraq:translate-api-reference-react-0
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
2 commits
Select commit
Hold shift + click to select a range
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,43 +13,43 @@ redirect_from: | |
- "docs/top-level-api-zh-CN.html" | ||
--- | ||
|
||
`React` is the entry point to the React library. If you load React from a `<script>` tag, these top-level APIs are available on the `React` global. If you use ES6 with npm, you can write `import React from 'react'`. If you use ES5 with npm, you can write `var React = require('react')`. | ||
React লাইব্রেরির entry point হচ্ছে `React`। আপনি যদি `<script>` tag এর মাধ্যমে React লোড করেন, তাহলে এই top-level API গুলো গ্লোবাল ভ্যারিয়েবল `React` এ পাবেন। যদি ES6 ব্যবহার করেন npm এর মাধ্যমে তাহলে `import React from 'react'` ব্যবহার করতে পারেন। আর যদি ES5 ব্যবহার করেন npm এর মাধ্যমে তবে `var React = require('react')` ব্যবহার করতে পারেন। | ||
|
||
## Overview {#overview} | ||
## সারমর্ম {#overview} | ||
|
||
### Components {#components} | ||
|
||
React components let you split the UI into independent, reusable pieces, and think about each piece in isolation. React components can be defined by subclassing `React.Component` or `React.PureComponent`. | ||
React এর component ব্যবহার করে আপনার UI কে স্বাধীন, পুনঃব্যবহারযোগ্য কতগুলো খন্ডে ভাগ করতে পারবেন। এই খন্ডগুলো নিয়ে আলাদা করে ভাবতে পারবেন। `React.Component` বা `React.PureComponent` এর subclass হিসেবে নতুন React component তৈরি করতে পারবেন। | ||
|
||
- [`React.Component`](#reactcomponent) | ||
- [`React.PureComponent`](#reactpurecomponent) | ||
|
||
If you don't use ES6 classes, you may use the `create-react-class` module instead. See [Using React without ES6](/docs/react-without-es6.html) for more information. | ||
`create-react-class` module টি ব্যবহার করতে পারেন যদি ES6 ব্যবহার না করেন। আরও তথ্যের জন্য দেখুন [Using React without ES6](/docs/react-without-es6.html)। | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Translate |
||
|
||
React components can also be defined as functions which can be wrapped: | ||
ফাংশন হিসেবেও React কম্পোনেন্ট তৈরি করা যায়। এই ফাংশনকে wrap করাও সম্ভবঃ | ||
|
||
- [`React.memo`](#reactmemo) | ||
|
||
### Creating React Elements {#creating-react-elements} | ||
### React Element তৈরি {#creating-react-elements} | ||
|
||
We recommend [using JSX](/docs/introducing-jsx.html) to describe what your UI should look like. Each JSX element is just syntactic sugar for calling [`React.createElement()`](#createelement). You will not typically invoke the following methods directly if you are using JSX. | ||
আমরা UI এর কোড লেখার ক্ষেত্রে [JSX](/docs/introducing-jsx.html) ব্যবহার করতে উৎসাহিত করি। JSX এর element গুলো [`React.createElement()`](#createelement) ব্যবহারের জন্য একটি সহজ করে দেয়া উপায় মাত্র (sytactic sugar)। JSX ব্যবহার করলে নিচের method গুলো সাধারণত ব্যবহার করা হয় না। | ||
|
||
- [`createElement()`](#createelement) | ||
- [`createFactory()`](#createfactory) | ||
|
||
See [Using React without JSX](/docs/react-without-jsx.html) for more information. | ||
আরও তথ্যের জন্য এখানে দেখুন - [Using React without JSX](/docs/react-without-jsx.html) । | ||
|
||
### Transforming Elements {#transforming-elements} | ||
### Element এর পরিবর্তন {#transforming-elements} | ||
|
||
`React` provides several APIs for manipulating elements: | ||
Element গুলোকে প্রয়োজনমত পরিবর্তনের জন্য `React` কিছু API দেয়: | ||
|
||
- [`cloneElement()`](#cloneelement) | ||
- [`isValidElement()`](#isvalidelement) | ||
- [`React.Children`](#reactchildren) | ||
|
||
### Fragments {#fragments} | ||
|
||
`React` also provides a component for rendering multiple elements without a wrapper. | ||
কোন wrapper ছাড়াই একাধিক element রেন্ডার করার জন্য `React` একটি বিশেষ কম্পোনেন্ট দেয়। | ||
|
||
- [`React.Fragment`](#reactfragment) | ||
|
||
|
@@ -60,14 +60,14 @@ See [Using React without JSX](/docs/react-without-jsx.html) for more information | |
|
||
### Suspense {#suspense} | ||
|
||
Suspense lets components "wait" for something before rendering. Today, Suspense only supports one use case: [loading components dynamically with `React.lazy`](/docs/code-splitting.html#reactlazy). In the future, it will support other use cases like data fetching. | ||
রেন্ডার করার আগে কম্পোনেন্টকে অপেক্ষা করাতে Suspense ব্যবহার করা যায়। বর্তমানে Suspense দিয়ে শুধু একটি কাজই করা যায়: [`React.lazy` এর মাধ্যমে কম্পোনেন্টকে dynamic ভাবে লোড করা](/docs/code-splitting.html#reactlazy)। | ||
|
||
- [`React.lazy`](#reactlazy) | ||
- [`React.Suspense`](#reactsuspense) | ||
|
||
### Hooks {#hooks} | ||
|
||
*Hooks* are a new addition in React 16.8. They let you use state and other React features without writing a class. Hooks have a [dedicated docs section](/docs/hooks-intro.html) and a separate API reference: | ||
React 16.8 এর নতুন সংযোজন হচ্ছে *Hooks*। এর মাধ্যমে ক্লাস ব্যবহার না করেই স্টেট ও React এর অন্যান্য সুবিধা কাজে লাগানো যায়। *Hook* নিয়ে [আলাদা docs section](/docs/hooks-intro.html) আছে এবং একটি আলাদা API রেফারেন্সঃ | ||
|
||
- [Basic Hooks](/docs/hooks-reference.html#basic-hooks) | ||
- [`useState`](/docs/hooks-reference.html#usestate) | ||
|
@@ -88,7 +88,7 @@ Suspense lets components "wait" for something before rendering. Today, Suspense | |
|
||
### `React.Component` {#reactcomponent} | ||
|
||
`React.Component` is the base class for React components when they are defined using [ES6 classes](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Classes): | ||
[ES6 ক্লাস](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Classes) দিয়ে React কম্পোনেন্ট তৈরির জন্য `React.Component` হচ্ছে base ক্লাসঃ | ||
|
||
```javascript | ||
class Greeting extends React.Component { | ||
|
@@ -98,21 +98,21 @@ class Greeting extends React.Component { | |
} | ||
``` | ||
|
||
See the [React.Component API Reference](/docs/react-component.html) for a list of methods and properties related to the base `React.Component` class. | ||
[React.Component API রেফারেন্সে](/docs/react-component.html) `React.Component` ক্লাস সম্পর্কিত কিছু method এবং property এর তালিকা রয়েছে। | ||
|
||
* * * | ||
|
||
### `React.PureComponent` {#reactpurecomponent} | ||
|
||
`React.PureComponent` is similar to [`React.Component`](#reactcomponent). The difference between them is that [`React.Component`](#reactcomponent) doesn't implement [`shouldComponentUpdate()`](/docs/react-component.html#shouldcomponentupdate), but `React.PureComponent` implements it with a shallow prop and state comparison. | ||
`React.PureComponent` ও [`React.Component`](#reactcomponent) একই ধরণের। শুধু পার্থক্য হচ্ছে [`React.Component`](#reactcomponent) [`shouldComponentUpdate()`](/docs/react-component.html#shouldcomponentupdate) কে implement করে না। কিন্তু `React.PureComponent` অগভীর (shallow) prop এবং স্টেট তুলনার মাধ্যমে implement এর কাজটি করে। | ||
|
||
If your React component's `render()` function renders the same result given the same props and state, you can use `React.PureComponent` for a performance boost in some cases. | ||
যদি আপনার React কম্পোনেন্টের `render()` ফাংশন নির্দির্ষ্ট স্টেট আর props এর জন্য প্রতিবার একই ফলাফল দেয়, তাহলে কিছু ক্ষেত্রে `React.PureComponent` ব্যবহার করে আরও দ্রুত একই কাজ করা সম্ভব। | ||
|
||
> Note | ||
> নোট | ||
> | ||
> `React.PureComponent`'s `shouldComponentUpdate()` only shallowly compares the objects. If these contain complex data structures, it may produce false-negatives for deeper differences. Only extend `PureComponent` when you expect to have simple props and state, or use [`forceUpdate()`](/docs/react-component.html#forceupdate) when you know deep data structures have changed. Or, consider using [immutable objects](https://facebook.github.io/immutable-js/) to facilitate fast comparisons of nested data. | ||
> `React.PureComponent` এর `shouldComponentUpdate()` শুধুমাত্র অগভীরভাবে (shallow) object সমূহের তুলনা করে। যদি এদের মধ্যে জটিল কোন data structure থাকে তাহলে false-negetive ফলাফল তৈরি করতে পারে গভীরতর পার্থক্যের জন্য। শুধুমাত্র সহজ prop ও state ব্যবহারের করলেই `PureComponent` কে extend করা উচিত। অথবা [`forceUpdate()`](/docs/react-component.html#forceupdate) ব্যবহার করা যেতে পারে যখন জানা যাবে যে জটিল data structure এর গভীরে কোন পরিবর্তন হয়েছে। অথবা [immutable objects](https://facebook.github.io/immutable-js/) ব্যবহার করা যেতে পারে যেন nested data এর দ্রুত তুলনা করা সম্ভব হয়। | ||
> | ||
> Furthermore, `React.PureComponent`'s `shouldComponentUpdate()` skips prop updates for the whole component subtree. Make sure all the children components are also "pure". | ||
> তদুপরি, `React.PureComponent` এর `shouldComponentUpdate()` prop এর পরিবর্তন এড়িয়ে যায় পুরো কম্পোনেন্ট subtree এর জন্যই। নিশ্চিত করুন যে সকল children কম্পোনেন্ট ও "pure"। | ||
|
||
* * * | ||
|
||
|
@@ -124,13 +124,13 @@ const MyComponent = React.memo(function MyComponent(props) { | |
}); | ||
``` | ||
|
||
`React.memo` is a [higher order component](/docs/higher-order-components.html). It's similar to [`React.PureComponent`](#reactpurecomponent) but for function components instead of classes. | ||
`React.memo` একটি [higher order কম্পোনেন্ট](/docs/higher-order-components.html)। এটি [`React.PureComponent`](#reactpurecomponent) এর মতই। কিন্তু এটি ফাংশন কম্পোনেন্টের জন্য, ক্লাসের জন্য নয়। | ||
|
||
If your function component renders the same result given the same props, you can wrap it in a call to `React.memo` for a performance boost in some cases by memoizing the result. This means that React will skip rendering the component, and reuse the last rendered result. | ||
যদি আপনার ফাংশন কম্পোনেন্ট নির্দির্ষ্ট props এর জন্য প্রতিবার একই জিনিস রেন্ডার করে, তাহলে তাকে `React.memo` এর call এর মধ্যে wrap করতে পারেন। এই উপায়ে কিছু ক্ষেত্রে memoizing এর মাধ্যমে দ্রুত ফলাফল তৈরি করতে পারে। এর মানে React এই component টি render করা এড়িয়ে গিয়ে সর্বশেষ render টি ব্যবহার করবে। | ||
|
||
`React.memo` only checks for prop changes. If your function component wrapped in `React.memo` has a [`useState`](/docs/hooks-state.html) or [`useContext`](/docs/hooks-reference.html#usecontext) Hook in its implementation, it will still rerender when state or context change. | ||
`React.memo` শুধু prop এর পরিবর্তনের দিকে খেয়াল রাখে। যদি `React.memo` দিয়ে wrap করা ফাংশন কম্পোনেন্টটিতে [`useState`](/docs/hooks-state.html) বা [`useContext`](/docs/hooks-reference.html#usecontext) ব্যবহার হয়ে থাকে তাহলে স্টেট বা context এর পরিবর্তনের ক্ষেত্রে পুনরায় রেন্ডার করা হবে। | ||
|
||
By default it will only shallowly compare complex objects in the props object. If you want control over the comparison, you can also provide a custom comparison function as the second argument. | ||
সাধারণ ক্ষেত্রে এটি props এর জটিল অবজেক্টগুলোকে শুধু অগভীরভাবেই তুলনা করবে। যদি এই তুলনার উপায়কে নিয়ন্ত্রণ করতে চান তাহলে আলাদা comparison ফাংশন প্রয়োগ করতে পারেন দ্বিতীয় আর্গুমেন্ট হিসাবে। | ||
|
||
```javascript | ||
function MyComponent(props) { | ||
|
@@ -146,11 +146,11 @@ function areEqual(prevProps, nextProps) { | |
export default React.memo(MyComponent, areEqual); | ||
``` | ||
|
||
This method only exists as a **[performance optimization](/docs/optimizing-performance.html).** Do not rely on it to "prevent" a render, as this can lead to bugs. | ||
এই method টি শুধুমাত্র **[performance optimization](/docs/optimizing-performance.html)** এর জন্যই। রেন্ডার এড়ানোর জন্য এটি ব্যবহার করবেন না, নয়তো bug তৈরি করতে পারে। | ||
|
||
> Note | ||
> নোট | ||
> | ||
> Unlike the [`shouldComponentUpdate()`](/docs/react-component.html#shouldcomponentupdate) method on class components, the `areEqual` function returns `true` if the props are equal and `false` if the props are not equal. This is the inverse from `shouldComponentUpdate`. | ||
> props একই হলে `areEqual` ফাংশনটি true এবং ভিন্ন হলে false রিটার্ন করে। ক্লাস কম্পোনেন্টের [`shouldComponentUpdate()`](/docs/react-component.html#shouldcomponentupdate) করে ঠিক উল্টো কাজ। | ||
|
||
* * * | ||
|
||
|
@@ -164,9 +164,9 @@ React.createElement( | |
) | ||
``` | ||
|
||
Create and return a new [React element](/docs/rendering-elements.html) of the given type. The type argument can be either a tag name string (such as `'div'` or `'span'`), a [React component](/docs/components-and-props.html) type (a class or a function), or a [React fragment](#reactfragment) type. | ||
এই ফাংশনটি প্রদত্ত type এর নতুন একটি [React element](/docs/rendering-elements.html) তৈরি করে তা return করে। type আর্গুমেন্টটি হয় একটি ট্যাগের নাম (যেমন `'div'` বা `'span'`), অথবা [React কম্পোনেন্ট](/docs/components-and-props.html) টাইপের (ক্লাস বা ফাংশন), নয়ত [React fragment](#reactfragment) টাইপের হতে পারে। | ||
|
||
Code written with [JSX](/docs/introducing-jsx.html) will be converted to use `React.createElement()`. You will not typically invoke `React.createElement()` directly if you are using JSX. See [React Without JSX](/docs/react-without-jsx.html) to learn more. | ||
[JSX](/docs/introducing-jsx.html) এ লেখা কোড থেকে `React.createElement()` ব্যবহার কোডে পরিবর্তন করা হয়। JSX ব্যবহার করা হলে সাধারণত `React.createElement()` সরাসরি ব্যবহার করা হয় না। আরও জানতে দেখুন [React Without JSX](/docs/react-without-jsx.html) । | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. translate |
||
|
||
* * * | ||
|
||
|
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we translate this to কম্পোনেন্ট? @nutboltu vai what do you think?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
for consistency, it should translate to কম্পোনেন্ট