আপনার পাঠ্য বিষয়বস্তুর উপরে এবং নীচে স্থান ফিরে নিন; অপটিক্যাল ভারসাম্য অর্জন।
প্রকাশিত: 14 জানুয়ারী, 2025
Chrome 133 থেকে, text-box ডেভেলপার এবং ডিজাইনারদের টেক্সটের উপরে এবং নীচের জায়গাটি সাজাতে দেয়।
লম্বা হাত:
text-box-trim: trim-start | trim-end | trim-both | none;
text-box-edge: cap | ex | text | leading + alphabetic | text;
শর্টহ্যান্ড:
text-box: trim-both cap alphabetic;
এই বৈশিষ্ট্যটি আপনাকে পাঠ্যের উপরে এবং নীচের স্থান নিয়ন্ত্রণ করতে দেয়, উদাহরণস্বরূপ <h1> , <button> এবং <p> । প্রতিটি ফন্ট এই ব্লক দিকনির্দেশক স্থানের একটি ভিন্ন পরিমাণ উত্পাদন করে যা উপাদানটির আকারে অবদান রাখে। এই বিশৃঙ্খল স্থান অবদান সহজে পরিমাপ করা হয় না, এবং এখন পর্যন্ত নিয়ন্ত্রণ করা অসম্ভব হয়েছে.
ফন্ট জানে, এখন সিএসএস জানে!
একটি ফন্টের উপরে এবং নীচের স্থানটি ওয়েব কিভাবে টেক্সট তৈরি করে, যার নাম "হাফ-লিডিং"। ম্যাথিয়াস ওটের একটি পোস্টে এটি দক্ষতার সাথে কভার করা হয়েছে যার নাম The Thing With Leading In CSS । মূলত, যখন হাত দিয়ে টাইপসেটিং করা হত, তখন টেক্সটের লাইনগুলিকে আলাদা করতে ধাতব সীসার টুকরা ব্যবহার করা হত। ওয়েব, নেতৃস্থানীয় দ্বারা অনুপ্রাণিত, সেই সীসার অংশটিকে অর্ধেক ভাগ করে এবং একটি অংশ উপরে এবং একটি অংশের নীচে বিতরণ করে৷

এই ইতিহাস অর্থবহ কারণ, text-box আমাদের প্রতিটি অর্ধেক জন্য নাম দেয়: উপর এবং নীচে। প্লাস, এটি বন্ধ ছাঁটা করার ক্ষমতা.
text-box পূর্বের শিল্পও রয়েছে, আপনি লিডিং-ট্রিম: দ্য ফিউচার অফ ডিজিটাল টাইপসেটিং নামে ইথান ওয়াং-এর উত্তেজনাপূর্ণ পোস্টটি স্মরণ করতে পারেন, যেখানে leading-trim (আগে text-box নাম ছিল) প্রথম চালু করা হয়েছিল।

টেক্সট ট্রিমিংয়ে আপনার এন্ট্রি পয়েন্ট ফিগমা এবং ডিজাইনারদের জন্য এর "উল্লম্ব ট্রিম" নিয়ন্ত্রণ থেকে হতে পারে। এই X পোস্টটি দেখায় যে এই উল্লম্ব ট্রিম বিকল্পটি কোথায় এবং এটি বোতামগুলির জন্য কীভাবে সহায়ক।
আপনি এখানে যেভাবে এসেছেন তা নির্বিশেষে, এই ছোট শব্দযুক্ত টাইপোগ্রাফি নিয়ন্ত্রণ একটি বড় পার্থক্য করতে পারে।
বৈশিষ্ট্য এবং সিনট্যাক্স ওভারভিউ
এখানে, আমার মতে, text-box সাথে কাজ করার সময় আপনার প্রয়োজন হবে এমন দুটি সবচেয়ে সাধারণ ওয়ান-লাইনার:
h1 {
/* trim both sides to the capital letters */
text-box: trim-both cap alphabetic;
/* trim both sides to the lowercase letter x */
text-box: trim-both ex alphabetic;
}
cap alphabetic উভয় ট্রিমিং এই বৈশিষ্ট্যের সবচেয়ে সাধারণ ব্যবহার হবে. নিম্নলিখিত ডেমো এটি অনেকবার ব্যবহার করে। যাইহোক, পূর্ববর্তী উদাহরণটি ex alphabetic দেখায় কারণ এটি তার নিজস্ব অনন্য উপায়ে অপটিক্যাল ভারসাম্যের জন্য দরকারী।
এক্সপ্লোরার খেলার মাঠ
নিম্নলিখিত ডেমো আপনাকে সিনট্যাক্স অন্বেষণ করতে এবং ড্রপডাউন মেনু ব্যবহার করে ফলাফল দেখতে দেয়। আপনি ফন্ট পরিবর্তন করতে পারেন, ট্রিম মান পরিবর্তন করতে পারেন এবং কালার কোডেড ভিজ্যুয়াল এবং লেবেল সহ অনুসরণ করতে পারেন।

চেষ্টা করার জিনিস:
- একক লাইন এবং মাল্টি-লাইন টেক্সট ভেরিয়েন্ট জুড়ে
text-box-trimকীভাবে কাজ করে তা দৃশ্যত পরিদর্শন করা। - একটি ভেরিয়েন্টের উপর ঘোরানো, সেই প্রভাবটি অর্জন করতে ব্যবহৃত ট্রিম মানগুলি দেখে৷
- ফন্ট পরিবর্তন.
- একটি টেক্সট বক্সের শুধুমাত্র এক পাশ ছাঁটাই করা।
- আপনি খেলা হিসাবে সিনট্যাক্স পর্যালোচনা করুন.
আমি এটি দিয়ে কী তৈরি করতে পারি বা এটি কী সমস্যার সমাধান করে?
এই ট্রিম ক্ষমতা থেকে উদ্ভূত কিছু অনেক সহজ কেন্দ্রীকরণ এবং প্রান্তিককরণ সমাধান রয়েছে। আপনি এমনকি সঠিক নেতৃত্বের কাছাকাছি যেতে পারেন, যেখানে বিষয়বস্তুর মধ্যে gap মতো কিছু ব্যবহার করা যেতে পারে।

সহজ কেন্দ্রীকরণ
ছোট, আরও ইনলাইন এবং বিষয়বস্তুর অভ্যন্তরীণ উপাদানগুলির জন্য, padding: 10px হল একটি যুক্তিসঙ্গত শৈলী যা একটি উপাদানের জন্য সমস্ত দিকে সমান ব্যবধানের জন্য নির্দিষ্ট করে৷ যাইহোক, ফলাফলটি লোকেদের বিভ্রান্ত করতে পারে, কারণ এটি প্রায়শই উপরে এবং নীচে অতিরিক্ত স্থান থাকে।
এটিকে ঘিরে কাজ করার জন্য, বিকাশকারীরা প্রায়শই অর্ধেক লিডিংয়ের প্রভাবগুলি অফসেট করার জন্য উপরে এবং নীচে (ব্লক) কম প্যাডিং রাখে।
button {
padding-block: 5px;
padding-inline: 10px;
}
এই মুহুর্তে জিনিসগুলি অপটিক্যালি কেন্দ্রিক না হওয়া পর্যন্ত আমরা মান সংমিশ্রণ চেষ্টা করতে বাকি আছি। এটি একটি স্ক্রীন এবং অপারেটিং সিস্টেমে ভাল দেখতে পারে, তবে অন্যটিতে নয়।
text-box আমাদের টেক্সট থেকে অর্ধেক লিডিং স্পেস ছাঁটাই করতে দেয়, সমান প্যাডিং মান যেমন 10px দরকারী করে:
button {
text-box: trim-both cap alphabetic;
padding: 10px;
}

এখানে কয়েকটি <button> উপাদান রয়েছে যা দেখায় কিভাবে text-box সাহায্যে স্থান ছাঁটাই padding: 10px সব দিকে সমান দেখায়। লক্ষ্য করুন কিভাবে বিকল্প ফন্ট কিছু অর্ধেক অগ্রণী স্থান তৈরি করতে পারে।

এখানে <span> উপাদান রয়েছে, প্রায়শই বিভাগ বা ব্যাজ দেখাতে ব্যবহৃত হয়। আরেকটি মুহূর্ত যেখানে সমান পার্শ্বযুক্ত প্যাডিং সেরা সমাধান হওয়া উচিত, কিন্তু text-box পর্যন্ত আমাদের এটিকে ঘিরে কাজ করতে হয়েছিল।

সহজ সারিবদ্ধকরণ
একটি টেক্সট বক্সের উপরে ( over ) এবং নীচে ( under ) অতিরিক্ত, অনিয়ন্ত্রিত, অর্ধেক অগ্রণী স্থানও প্রান্তিককরণকে কঠিন করে তোলে। নিম্নলিখিত উদাহরণগুলি দেখায় যে কখন অর্ধেক অগ্রণী সারিবদ্ধকরণকে কঠিন করে তুলতে পারে এবং কীভাবে একটি পাঠ্য বাক্সের ব্লক দিকগুলিকে ছাঁটাই করা আরও ভাল প্রান্তিককরণ তৈরি করতে পারে।
এখানে পাঠ্যের পাশে একটি চিত্র স্থাপন করা হয়েছে। চিত্রটি পাঠ্যের প্রয়োজনীয় উচ্চতায় বৃদ্ধি পাবে, কিন্তু text-box ছাড়া, চিত্রটি সর্বদা একটু লম্বা হয়। text-box সাহায্যে, চিত্রটি পাঠ্য বিষয়বস্তুর সাথে পুরোপুরি সারিবদ্ধ হতে পারে।

লক্ষ্য করুন হোয়াইটস্পেসটি টেক্সটের প্রথম ফরম্যাট করা লাইনের উপরে এবং লাইন র্যাপিং সহ পরিস্থিতিতে টেক্সটের শেষ ফরম্যাট করা লাইনের নিচে।
নিম্নলিখিত উদাহরণে, লক্ষ্য করুন কীভাবে বৈশিষ্ট্যটি writing-mode পরিবর্তনের সাথে যৌক্তিকভাবে খাপ খায় । টেক্সট পরিবর্তন করার চেষ্টা করুন, লেআউটটি কীভাবে সারিবদ্ধ থাকে তা দেখুন।

অধ্যয়ন চালিয়ে যান
আরো জানতে চান? নিম্নলিখিত লিঙ্কগুলির তালিকা বিভিন্ন পরিমাণে অতিরিক্ত তথ্য এবং ব্যবহারের ক্ষেত্রে অফার করে।
- https://codepen.io/collection/zxQBaL - উপরের সমস্ত ডেমোর একটি কোডপেন সংগ্রহ
- https://github.com/jantimon/text-box-trim-examples - জ্যান নিকলাসের দুর্দান্ত গবেষণা এবং ডেমো
- https://css-tricks.com/two-css-properties-for-trimming-text-box-whitespace/
- https://drafts.csswg.org/css-inline-3/#text-edges
-
size-adjustবাascent-overrideসাথে বিভ্রান্ত হবেন না https://web.dev/articles/css-size-adjust - https://www.smashingmagazine.com/2012/12/css-baseline-the-good-the-bad-and-the-ugly/
- https://css-tricks.com/two-css-properties-for-trimming-text-box-whitespace/
- অনেক HTML উপাদানে প্রয়োগ করা হয়েছে https://codepen.io/nileshprajapati/pen/RweKdmw
- সাফারির ব্লগ পোস্ট https://webkit.org/blog/16301/webkit-features-in-safari-18-2/
- https://piccalil.li/blog/why-im-excited-about-text-box-trim-as-a-designer/