বিনামূল্যে কনভার্টার

JavaScript মিনিফায়ার

আপনার ব্রাউজারে তাৎক্ষণিকভাবে JavaScript কোড মিনিফাই ও সংকুচিত করুন। মন্তব্য সরান, হোয়াইটস্পেস ভাঁজ করুন এবং ফাইলের আকার কমান। বিনামূল্যে এবং ব্যক্তিগত।

এখানে JS ফাইল টেনে আনুন

.js ফাইল সমর্থিত। অথবা উপরে আপনার JavaScript পেস্ট করুন।

অথবা

এই টুল সম্পর্কে

জাভাস্ক্রিপ্ট মিনিফিকেশন অপ্রয়োজনীয় অক্ষরগুলি সরিয়ে এবং (সঠিক মিনিফায়ার সহ) স্থানীয় ভেরিয়েবলের নাম পরিবর্তন করে সংক্ষিপ্ত নামে সোর্স কোডের আকার হ্রাস করে। প্রথম বিভাগ — হোয়াইটস্পেস এবং মন্তব্য অপসারণ — সহজবোধ্য এবং ঝুঁকিমুক্ত। দ্বিতীয়টি - পরিবর্তনশীল নামকরণ - এর জন্য সুযোগের নিয়মগুলি বোঝার প্রয়োজন এবং এটিই টারসার এবং এসবিল্ডের মতো উত্পাদন মিনিফায়ারগুলি সবচেয়ে ভাল করে৷

এই টুলটি নিরাপদ ক্ষুদ্রকরণের উপর ফোকাস করে: মন্তব্য খুলে ফেলা, হোয়াইটস্পেস ভেঙ্গে ফেলা, অপ্রয়োজনীয় সেমিকোলন অপসারণ এবং সুস্পষ্ট প্যাটার্ন ছোট করা। পরিবর্তনশীল পুনঃনামকরণ রক্ষণশীল — শুধুমাত্র স্পষ্ট স্কোপের স্থানীয় ভেরিয়েবলগুলিকে স্পর্শ করা হয়, এবং বহিরাগত-উল্লেখিত নামগুলিকে একা রাখা হয়। ফলাফলটি উত্সের সাথে কার্যকরীভাবে অভিন্ন।

প্রোডাকশন-গ্রেড মিনিফিকেশনের জন্য, ডেডিকেটেড টুলস (Terser, esbuild, swc) সম্পূর্ণ ECMAScript স্কোপ মডেল বুঝতে পারে এবং উল্লেখযোগ্যভাবে ছোট আউটপুট তৈরি করে। একটি সম্পূর্ণ বিল্ড সেটআপ উপলব্ধ না হলে এই টুলটি দ্রুত ব্রাউজার-সাইড মিনিফিকেশনের জন্য।

কেন জাভাস্ক্রিপ্ট ছোট করুন

জাভাস্ক্রিপ্ট বান্ডেলগুলি সাধারণত একটি আধুনিক ওয়েবপেজে সবচেয়ে বড় একক সম্পদ। মিনিফিকেশন নিয়মিতভাবে 30-60% আকার হ্রাস বনাম unminified উত্স উত্পাদন করে। জিজিপ বা ব্রটলির সাথে মিলিত, হ্রাস কিছুটা সঙ্কুচিত হয়, তবে সংমিশ্রণটি এখনও পরিমাপযোগ্য বাইট সংরক্ষণ করে — বিশেষত ধীর সংযোগে থাকা ব্যবহারকারীদের জন্য।

দ্রুত জাভাস্ক্রিপ্ট মানে ইন্টারেক্টিভ করার জন্য দ্রুত সময়। ছোট স্ক্রিপ্ট দ্রুত ডাউনলোড, দ্রুত পার্স, এবং দ্রুত কার্যকর করা. টিটিআই বাউন্স রেট এবং এসইও র‌্যাঙ্কিংকে প্রভাবিত করে এমন সাইটগুলির জন্য, মিনিফিকেশন হল সবচেয়ে সস্তায় পাওয়া জয়গুলির মধ্যে একটি।

কিভাবে ব্যবহার করবেন

জাভাস্ক্রিপ্ট পেস্ট করুন, একটি ছোট সংস্করণ পান।

  1. জাভাস্ক্রিপ্ট ইনপুট যোগ করুন: ইনপুট এলাকায় উত্স আটকান বা একটি .js ফাইল ড্রপ. মিনিফায়ার তীর ফাংশন, টেমপ্লেট লিটারেল, ক্লাস এবং মডিউল সহ আধুনিক জাভাস্ক্রিপ্ট (ES2015+) গ্রহণ করে।
  2. বিকল্পগুলি বেছে নিন: ডিফল্ট কমেন্ট স্ট্রিপ করে এবং হোয়াইটস্পেস সঙ্কুচিত করে। স্থানীয় পরিবর্তনশীল নামকরণ রক্ষণশীল; আপনার যদি সর্বাধিক সংকোচনের প্রয়োজন হয় তবে আরও আক্রমণাত্মক নামকরণ সক্ষম করুন।
  3. ছোট করুন: মিনিফায়ার উৎসকে পার্স করে, হোয়াইটস্পেস এবং মন্তব্যগুলি সরিয়ে দেয় এবং কমপ্যাক্ট আউটপুট নির্গত করে। উৎসে সিনট্যাক্স ত্রুটি স্পষ্ট ত্রুটি বার্তা তৈরি করে।
  4. আউটপুট ব্যবহার করুন: উত্পাদনে আপনার স্ক্রিপ্ট উত্স প্রতিস্থাপন করুন। সম্পূর্ণ অপ্টিমাইজেশানের জন্য, একটি বান্ডলারের সাথে জুড়ুন যা গাছ-কাঁপানো এবং মৃত কোড নির্মূল করে।

সাধারণ ব্যবহারের ক্ষেত্রে

প্রযুক্তিগত বিবরণ

মিনিফায়ার একটি পার্সার ব্যবহার করে জাভাস্ক্রিপ্টকে টোকেনাইজ করে যা ECMAScript সিনট্যাক্সকে সম্মান করে। মন্তব্যগুলি (একক-লাইন এবং মাল্টি-লাইন) /* দিয়ে চিহ্নিত লাইসেন্স মন্তব্যগুলি ছাড়া মুছে ফেলা হয়! উপসর্গ যেখানে সিনট্যাক্টিক্যালি প্রয়োজন হয় (শনাক্তকারীর মধ্যে, কীওয়ার্ডের পরে) ব্যতীত হোয়াইটস্পেস ভেঙে পড়ে।

রক্ষণশীল পরিবর্তনশীল নামকরণ স্থানীয় ভেরিয়েবলকে সহজবোধ্য স্কোপে ছোট করে। গ্লোবাল, রপ্তানি, এবং আমদানি করা নাম পরিবর্তন করা হয় না - যা বাহ্যিক রেফারেন্সগুলিকে ভেঙে দেবে। গভীর নামকরণের জন্য, সঠিক মডিউল-সচেতন বিশ্লেষণ সহ Terser বা esbuild ব্যবহার করুন।

এজ কেস: স্বয়ংক্রিয় সেমিকোলন সন্নিবেশ (এএসআই) মানে প্রোগ্রাম আচরণ পরিবর্তন এড়াতে মিনিফায়ারকে কিছু প্রসঙ্গে নতুন লাইন সংরক্ষণ করতে হবে। টেমপ্লেট লিটারাল, রেজেক্স লিটারাল এবং জেএসএক্স (যদি ইনপুট অন্তর্ভুক্ত থাকে) ঠিক সংরক্ষিত হয় কারণ তাদের বিষয়বস্তু সংকুচিত করা নিরাপদ নাও হতে পারে।

সর্বোত্তম অনুশীলন

সচরাচর জিজ্ঞাসিত প্রশ্নাবলী

মাইনিফিকেশন কি আমার কোড কিভাবে কাজ করে তা পরিবর্তন করে?
না। মিনিফিকেশন হোয়াইটস্পেস এবং মন্তব্যগুলি সরিয়ে দেয়, যা সম্পাদনকে প্রভাবিত করে না। পরিবর্তনশীল সংক্ষিপ্তকরণ (ম্যাংলিং) স্থানীয় ভেরিয়েবলের নাম পরিবর্তন করে কিন্তু আচরণ সংরক্ষণ করে। গ্লোবাল ভেরিয়েবল এবং রপ্তানিকৃত নামগুলি অক্ষত রাখা হয়।
আমার কি উন্নয়ন বা উৎপাদনে ছোট করা উচিত?
উৎপাদনে শুধুমাত্র মিনিফাইড কোড ব্যবহার করুন। বিকাশের সময়, মূল পঠনযোগ্য কোড রাখুন। বেশিরভাগ বিল্ড টুলস (ওয়েবপ্যাক, ভিটে, এসবিল্ড) প্রোডাকশন বিল্ড প্রক্রিয়ার অংশ হিসাবে স্বয়ংক্রিয়ভাবে মিনিফিকেশন পরিচালনা করে।
মিনিফিকেশন এবং অস্পষ্টতার মধ্যে পার্থক্য কী?
বিন্যাস করা হলে কোড কার্যকরীভাবে পাঠযোগ্য রাখার সময় ক্ষুদ্রকরণ আকার হ্রাস করে। অস্পষ্টতা ইচ্ছাকৃতভাবে কোড বোঝা কঠিন করে তোলে (স্ট্রিং এনকোডিং, নিয়ন্ত্রণ প্রবাহ সমতলকরণ)। এই টুলটি আকার হ্রাসের উপর ফোকাস করে, অস্পষ্টতা নয়।
আমি কত আকার হ্রাস আশা করা উচিত?
সাধারণত gzip এর আগে 30-60%। দীর্ঘ পরিবর্তনশীল নামের সাথে ভাল-মন্তব্য করা কোড সবচেয়ে বড় হ্রাস দেখতে পায়। জিজিপ কম্প্রেশনের সাথে মিলিত, জাভাস্ক্রিপ্ট ফাইলগুলি প্রায়শই মূল উত্স থেকে 80-90% ছোট হয়।
আমার কোড একটি সার্ভার আপলোড করা হয়?
না। মিনিফায়ার আপনার ব্রাউজারে চলে।
আমার জাভাস্ক্রিপ্ট কত ছোট হবে?
সাধারণত 30-60% হ্রাস। দীর্ঘ শনাক্তকারী সহ পরিবর্তনশীল-ভারী কোড আরও সংকুচিত করে; এক্সপ্রেশন-ভারী কোড কম কম্প্রেস করে।
আমি কি হাত দ্বারা ছোট করা উচিত?
কখনই না। উৎসে পঠনযোগ্য জাভাস্ক্রিপ্ট বজায় রাখুন। বিল্ড স্টেপ বা ডিপ্লয়মেন্টের অংশ হিসেবে মিনিফিকেশন চালান।
এটা কি TypeScript এ কাজ করে?
Tsc বা esbuild ব্যবহার করে প্রথমে জাভাস্ক্রিপ্টে টাইপস্ক্রিপ্ট কম্পাইল করা দরকার। একবার কম্পাইল করা হলে, ফলস্বরূপ জাভাস্ক্রিপ্ট ছোট করা যাবে।