<input type="checkbox" onclick="onClickHandler()" onchange="onChangeHandler()" />
এর মধ্যে onClickHandler
এবং / অথবা থেকে onChangeHandler
, আমি কীভাবে নির্ধারণ করতে পারি যে চেকবক্সের নতুন অবস্থা কী?
<input type="checkbox" onclick="onClickHandler()" onchange="onChangeHandler()" />
এর মধ্যে onClickHandler
এবং / অথবা থেকে onChangeHandler
, আমি কীভাবে নির্ধারণ করতে পারি যে চেকবক্সের নতুন অবস্থা কী?
উত্তর:
সংক্ষিপ্ত উত্তর:
click
ইভেন্টটি ব্যবহার করুন , যা মান আপডেট হওয়ার পরে আগুন জ্বলবে না এবং আপনি যখন চান এটি অগ্নিসংযোগ করবে:
<label><input type='checkbox' onclick='handleClick(this);'>Checkbox</label>
function handleClick(cb) {
display("Clicked, new value = " + cb.checked);
}
দীর্ঘ উত্তর:
change
ইভেন্ট হ্যান্ডলার বলা হয় না যতক্ষণ না checked
রাষ্ট্র আপডেট করা হয়েছে ( লাইভ উদাহরণস্বরূপ | উৎস ), কিন্তু কারণ (টিম Buthe মন্তব্য তুলে ধরে হিসাবে) ইন্টারনেট আগুন নেই change
ঘটনা পর্যন্ত চেকবক্সটি ফোকাস হারায়, আপনি পাবেন না সক্রিয়ভাবে বিজ্ঞপ্তি। সবচেয়ে খারাপ, IE এর সাথে যদি আপনি এটি আপডেট করতে চেকবক্সের জন্য (কেবলমাত্র চেকবক্সের পরিবর্তে) কোনও লেবেল ক্লিক করেন , আপনি যে ধারণাটি পেয়ে যাচ্ছেন যে আপনি পুরানো মূল্য পেয়েছেন তা পেতে পারেন (লেবেলটিতে ক্লিক করে এখানে IE সহ চেষ্টা করুন: লাইভ উদাহরণ | উত্স )। এটি কারণ যদি চেকবক্সটি ফোকাস করে থাকে তবে লেবেলটি ক্লিক করা ফোকাসটিকে তার থেকে দূরে সরিয়ে দেয়, change
ইভেন্টটিকে পুরানো মান দিয়ে ফায়ার করে এবং তারপরেclick
নতুন মান সেট করা এবং চেকবক্সে ফোকাস সেট করা আবার ঘটে। খুবই বিভ্রান্তিকর.
আপনি যদি এর click
পরিবর্তে ব্যবহার করেন তবে আপনি সেই অপ্রীতিকর সব এড়াতে পারেন ।
আমি DOM0 হ্যান্ডলার ( onxyz
অ্যাট্রিবিউটস) ব্যবহার করেছি কারণ আপনি যা চেয়েছিলেন সেটিই কিন্তু রেকর্ডের জন্য, আমি সাধারণত বৈশিষ্ট্যগুলি ব্যবহার না করে কোড (DOM2 এর addEventListener
, বা attachEvent
IE এর পুরানো সংস্করণগুলিতে ) হ্যান্ডলারের সন্ধানের পরামর্শ দেব onxyz
। এটি আপনাকে একই উপাদানের সাথে একাধিক হ্যান্ডলার সংযুক্ত করতে দেয় এবং আপনাকে আপনার সমস্ত হ্যান্ডলারের বৈশ্বিক ক্রিয়াকলাপ এড়াতে দেয়।
এই উত্তরের পূর্ববর্তী সংস্করণে এই কোডটি ব্যবহার করেছে handleClick
:
function handleClick(cb) {
setTimeout(function() {
display("Clicked, new value = " + cb.checked);
}, 0);
}
লক্ষ্যটি দেখে মনে হচ্ছে মানটি দেখার আগে ক্লিকটি সম্পূর্ণ হওয়ার অনুমতি দেওয়া হয়েছিল। আমি যতদূর সচেতন, এটি করার কোনও কারণ নেই এবং আমি কেন করেছি তা আমার কোনও ধারণা নেই। click
হ্যান্ডলার বলার আগে মান পরিবর্তন করা হয়। আসলে, এই সম্পর্কে স্পষ্টটি বেশ পরিষ্কার । setTimeout
আমি চেষ্টা করেছি এমন প্রতিটি ব্রাউজারে সংস্করণ ছাড়াই সংস্করণ পুরোপুরি ভাল কাজ করে (এমনকি আই 6)) আমি কেবল ধরে নিতে পারি যে আমি অন্য কোনও প্ল্যাটফর্মের বিষয়ে ভাবছিলাম যেখানে ইভেন্টের পরে পরিবর্তন হয় নি। যাই হোক না কেন, এইচটিএমএল চেকবক্সগুলির সাথে এটি করার কোনও কারণ নেই।
tab
+ space
) onclick
হ্যান্ডলারটিও ট্রিগার করবে (কমপক্ষে ক্রমে 51 এ যাচাই করা হয়েছে)।
React.js এর জন্য, আপনি আরও পঠনযোগ্য কোডের সাহায্যে এটি করতে পারেন। আশা করি এটা সাহায্য করবে.
handleCheckboxChange(e) {
console.log('value of checkbox : ', e.target.checked);
}
render() {
return <input type="checkbox" onChange={this.handleCheckboxChange.bind(this)} />
}
onchange
সঠিকভাবে কাজ করে+IE9
। সূত্র