কখন পাস props
করা গুরুত্বপূর্ণ super()
, এবং কেন?
class MyComponent extends React.Component {
constructor(props) {
super(); // or super(props) ?
}
}
কখন পাস props
করা গুরুত্বপূর্ণ super()
, এবং কেন?
class MyComponent extends React.Component {
constructor(props) {
super(); // or super(props) ?
}
}
উত্তর:
শুধুমাত্র একটি কারণ যখন কারও কাছে props
যেতে হয় super()
:
আপনি যখন this.props
কনস্ট্রাক্টর অ্যাক্সেস করতে চান ।
পাসিং:
class MyComponent extends React.Component {
constructor(props) {
super(props)
console.log(this.props)
// -> { icon: 'home', … }
}
}
পাস হচ্ছে না:
class MyComponent extends React.Component {
constructor(props) {
super()
console.log(this.props)
// -> undefined
// Props parameter is still available
console.log(props)
// -> { icon: 'home', … }
}
render() {
// No difference outside constructor
console.log(this.props)
// -> { icon: 'home', … }
}
}
লক্ষ্য করুন ক্ষণস্থায়ী বা না ক্ষণস্থায়ী props
করতে super
হয়েছে কোনো প্রভাব পরবর্তী ব্যবহারের উপর this.props
বাহিরে constructor
। এটি হ'ল render
, shouldComponentUpdate
বা ইভেন্ট হ্যান্ডলাররা সর্বদা অ্যাক্সেস থাকে।
এটি একটি একই প্রশ্নের উত্তরে সোফি আল্পার্টের স্পষ্ট করে বলা হয়েছে ।
Documentation- রাজ্য এবং লাইফ সাইকল, একটি ক্লাস, পয়েন্ট 2 স্থানীয় রাজ্য যোগ করার পদ্ধতি -recommends:
ক্লাস উপাদানগুলি সর্বদা সাথে বেস কনস্ট্রাক্টরকে কল করা উচিত
props
।
তবে, কোনও কারণ সরবরাহ করা হয়নি। আমরা অনুমান করতে পারি এটি হয় সাবক্লাসিংয়ের কারণে বা ভবিষ্যতের সামঞ্জস্যের কারণে।
(লিঙ্কটির জন্য ধন্যবাদ @ ম্যাটব্রাউন)
this.props
হয় undefined
যদি না পাস super()
। উভয় ক্ষেত্রেই, এটা পরে রেন্ডারিং বা প্রাপ্যতা প্রভাবিত করে না this.props
যে render()
ফাংশন।
super
করেন তাই আপনার কনস্ট্রাক্টরে রেফারেন্স রয়েছে।
props
পাঠানো উচিত । আমি নিশ্চিত না কেন, যেহেতু আপনি উল্লেখ করেছেন যে কোনওভাবেই অন্য পদ্ধতিতে অ্যাক্সেসযোগ্য ... সম্ভবত তারা ভবিষ্যতের সামঞ্জস্যের জন্য এটি প্রস্তাব দিচ্ছেন যদি ভবিষ্যতের প্রতিক্রিয়াগুলি কনস্ট্রাক্টরের সাথে কিছু করতে চান ? super()
this.props
props
props
করার super
যখন, যেমন আপনি নির্দিষ্ট, props
পরামিতি অধিকার আছে উপলব্ধ আমাদের কন্সট্রাকটর মধ্যে ব্যবহারের জন্য , এবং this.props
সর্বত্র অন্য কাজ করে? this.props
শুধু মাত্র ওভার ব্যবহার করে কি কোনও উপকার হয় props
? এটি কি props
কনস্ট্রাক্টরের মধ্যে ডেস্ট্রাকচার বন্ধ করা খারাপ অভ্যাস ? আমি মনে করি আমি এখনও কোনও মামলাটি দেখতে ব্যর্থ হয়েছি যখন আপনার কখন পাস props
করার প্রয়োজন হয় super
তবে আমি বাজি রাখতে ইচ্ছুক এটি কেবল আমার অজ্ঞতা, হা।
super(props)
সেই পদ্ধতিগুলিকে কল করতে পারেন যা this.props
কনস্ট্রাক্টর থেকে ব্যবহার করা হয় , যেমন this.doStuffUsingThisDotProps()
, সেই পদ্ধতিগুলি / ক্রিয়াকলাপগুলিতে প্রপস পরামিতিটি ছাড়াই। আমি কেবল এটির একটি নির্মাণকারী লিখেছি, যা সম্ভবত super(props)
এই প্রশ্নের উত্তর অনুসারে আমাকে প্রথমে ব্যবহার করা প্রয়োজন ।
এই উদাহরণে, আপনি React.Component
ক্লাসটি প্রসারিত করছেন , এবং ES2015 অনুমান অনুসারে, একটি শিশু শ্রেণির নির্মাতা কল this
না super()
করা পর্যন্ত ব্যবহার করতে পারবেন না ; এছাড়াও, ES2015 শ্রেণি নির্মাতারা super()
যদি সাবক্লাস হয় তবে তাদের কল করতে হবে।
class MyComponent extends React.Component {
constructor() {
console.log(this); // Reference Error
}
render() {
return <div>Hello {this.props.name}</div>;
}
}
বিপরীতে:
class MyComponent extends React.Component {
constructor() {
super();
console.log(this); // this logged to console
}
render() {
return <div>Hello {this.props.name}</div>;
}
}
হিসাবে আরও বিশদ এই দুর্দান্ত স্ট্যাক ওভারফ্লো উত্তর
আপনি React.Component
ক্লাস না করে ক্লাস বাড়িয়ে তৈরির উপাদানগুলির উদাহরণ দেখতে পাচ্ছেন তবে আপনি দেখতে পাবেন যে super()
এগুলির একটি নেই constructor
, সুতরাং এটি কেন প্রয়োজনীয় নয়।
class MyOtherComponent extends React.Component {
render() {
return <div>Hi {this.props.name}</div>;
}
}
আমি যে কথোপকথনটির সাথে কথা বলেছি তার মধ্যে একটি বিভ্রান্তির বিষয়টি আমি দেখেছি যে যে উপাদানগুলি নেই constructor
এবং তাই super()
কোথাও কল করে না, এখনও পদ্ধতিটিতে this.props
উপলব্ধ the render()
মনে রাখবেন যে এই নিয়ম এবং this
এটি constructor
কেবলমাত্রর জন্য প্রযোজ্য জন্য একটি বাধ্যতামূলক তৈরি করা প্রয়োজন constructor
।
super()
এবং এর মধ্যে পার্থক্য super(props)
)।
আপনি যখন পাস props
করার super
, সাজসরঞ্জাম নির্ধারিত পেতে this
। নিম্নলিখিত পরিস্থিতিতে একবার দেখুন:
constructor(props) {
super();
console.log(this.props) //undefined
}
আপনি কখন কখন করবেন:
constructor(props) {
super(props);
console.log(this.props) //props will get logged.
}
অনুযায়ী সোর্স কোড
function ReactComponent(props, context) {
this.props = props;
this.context = context;
}
আপনার প্রপস থাকা props
প্রতিটি সময় আপনাকে অবশ্যই পাস করতে হবে এবং আপনি এগুলি this.props
ম্যানুয়ালি putোকাতে পারবেন না ।
this.props = props
এবং super(props)
একই জিনিস?
this.props
'বাহিরের' থেকে নির্ধারণ করে the নির্মাত্রে যা করা হয় তা নির্বিশেষে।
ড্যান আব্রামভ এই বিষয়ে একটি নিবন্ধ লিখেছিলেন:
এবং এর সংক্ষিপ্তসারটি হ'ল এই দৃশ্যটি এড়াতে এটি পাস করার অভ্যাস থাকা সহায়ক , সত্যই, আমি এটি ঘটনার সম্ভাবনা দেখছি না:
// Inside React
class Component {
constructor(props) {
this.props = props;
// ...
}
}
// Inside your code
class Button extends React.Component {
constructor(props) {
super(); // 😬 We forgot to pass props
console.log(props); // ✅ {}
console.log(this.props); // 😬 undefined
}
// ...
}
super()
প্যারেন্ট কনস্ট্রাক্টরকে কল করতে ব্যবহৃত হয়।
super(props)
পাস হবে props
অভিভাবক কনস্ট্রাক্টর ।
আপনার উদাহরণ থেকে, কনস্ট্রাক্টরকে প্রবেশ করানো super(props)
কল করবেReact.Component
props
আর্গুমেন্ট হিসাবে ।
এ সম্পর্কিত আরও তথ্য super
: https://developer.mozilla.org/en-US/docs/Web/ জাভা স্ক্রিপ্ট / রেফারেন্স /
অপারেটরস / সুপার
বাস্তবায়ন করার সময় constructor()
একটি প্রতিক্রিয়া উপাদান ভিতরে ফাংশন , super()
একটি প্রয়োজন। মনে রাখবেন যে আপনার MyComponent
উপাদানটি React.Component
বেস বর্গ থেকে কার্যকারিতা প্রসারিত বা ধার করছে ।
এই বেস শ্রেণীর নিজস্ব একটি constructor()
ফাংশন রয়েছে যা এর অভ্যন্তরে কিছু কোড থাকে যা আমাদের জন্য আমাদের প্রতিক্রিয়া উপাদান সেটআপ করে।
যখন আমরা constructor()
আমাদের ভিতরে কোনও ফাংশন সংজ্ঞায়িত করিMyComponent
ক্লাসের ক্লাসের থাকা constructor()
ফাংশনটি ওভাররাইডিং বা প্রতিস্থাপন করি React.Component
, তবে আমাদের এখনও নিশ্চিত করতে হবে যে এই constructor()
ফাংশনের ভিতরে থাকা সমস্ত সেটআপ কোডটি এখনও কল করে।
সুতরাং React.Component
এর constructor()
কার্যকারিতাটি কল হয়ে গেছে তা নিশ্চিত করার জন্য , আমরা কল করিsuper(props)
। super(props)
পিতামাতার constructor()
ফাংশনের একটি রেফারেন্স , এটাই সব।
আমরা যোগ করতে হবে super(props)
প্রতি একক সময় সংজ্ঞায়িত করতে হবেconstructor()
একটি বর্গ ভিত্তিক উপাদান ভিতরে ফাংশন।
আমরা যদি তা না করি তবে আমাদের কল করতে হবে এমন একটি ত্রুটি দেখতে পাবে super(props)
।
এটি সংজ্ঞায়িত করার পুরো কারণ constructor()
ফানসিটনের দেওয়ার হ'ল আমাদের রাষ্ট্রীয় অবজেক্টটি আরম্ভ করা।
সুতরাং আমাদের রাষ্ট্রের অবজেক্টটি সূচনা করতে, সুপার কলের নীচে আমি লিখছি:
class App extends React.Component {
constructor(props) {
super(props);
this.state = {};
}
// React says we have to define render()
render() {
return <div>Hello world</div>;
}
};
সুতরাং আমরা আমাদের constructor()
পদ্ধতিটি সংজ্ঞায়িত করেছি , একটি জাভাস্ক্রিপ্ট অবজেক্ট তৈরি করে আমাদের রাষ্ট্রীয় অবজেক্টটি সূচনা করেছি, এর জন্য কোনও সম্পত্তি বা কী / মান জুটি নির্ধারণ করে, এর ফলাফল নির্ধারণ করে this.state
। এখন অবশ্যই এটি এখানে একটি উদাহরণ তাই আমি সত্যিকার অর্থে কোনও কী / মান জোড় রাষ্ট্রীয় বস্তুকে অর্পণ করি নি, এটি কেবল একটি খালি অবজেক্ট।
এখানে আমি তৈরি করা ঝাঁকুনি : jsfiddle.net । এটি দেখায় যে প্রপস ডিফল্টরূপে কনস্ট্রাক্টরে নেই। আমি বুঝতে পারি যে তারা পদ্ধতিতে অনুগ্রহ করে React.createElement
। অতএব super(props)
কেবল যখন সুপারক্লাসের নির্মাতা নিজে নিজেই প্রতিশ্রুতি props
দেয় তখনই ডাকা উচিত this.props
। আপনি যদি কেবল প্রসারিত করেন তবে React.Component
কলগুলি super(props)
প্রপস সহ কিছুই করবে না। সম্ভবত এটি প্রতিক্রিয়াটির পরবর্তী সংস্করণগুলিতে পরিবর্তন করা হবে।
এখানে আমরা এটি কনস্ট্রাক্টরে পাবেন না যাতে এটি অপরিবর্তিত ফিরে আসবে তবে আমরা এটি নির্মাণকারীর কার্যের বাইরে আনতে সক্ষম হব
class MyComponent extends React.Component {
constructor() {
console.log(this); // Reference Error i.e return undefined
}
render() {
return <div>Hello {this.props.name}</div>;
}
}
যদি আমরা সুপার () ব্যবহার করি তবে আমরা কনস্ট্রাক্টরের ভিতরে "এই" ভেরিয়েবলটি আনতে পারি can
class MyComponent extends React.Component {
constructor() {
super();
console.log(this); // this logged to console
}
render() {
return <div>Hello {this.props.name}</div>;
}
}
সুতরাং যখন আমরা সুপার () ব্যবহার করি; আমরা এটি আনতে সক্ষম হব তবে এইগুলি। নির্মাণকারীদের মধ্যে ফসলগুলি অপরিজ্ঞাত করা হবে। তবে কনস্ট্রাক্টর ব্যতীত, এই.পড়গুলি অপরিবর্তিত ফিরে আসবে না।
যদি আমরা সুপার (প্রপস) ব্যবহার করি তবে আমরা কনস্ট্রাক্টরের ভিতরেও এই ফসলের মানটি ব্যবহার করতে পারি
আপনি যদি কন্সট্রাক্টরে এই.পড়গুলি ব্যবহার করতে চান তবে আপনাকে সুপারকে প্রপসগুলি সরবরাহ করতে হবে। অন্যথায়, এটি কোনও ব্যাপার নয় কারণ প্রতিক্রিয়াটি কনস্ট্রাক্টরকে কল করার সাথে সাথে বাইরে থেকে উদাহরণস্বরূপ ফসল সেট করে।
সংস্করণ 16.6.3 এর প্রতিক্রিয়াটির জন্য, আমরা রাষ্ট্রের উপাদানটির নাম আরম্ভ করার জন্য সুপার ( প্রস ) ব্যবহার করি : এই.পড়গুলি.নাম
constructor(props){
super(props);
}
state = {
name:this.props.name
//otherwise not defined
};