আমার এখানে দুটি ডিভ রয়েছে:
<div style="display:table-cell" id="div1">
content
</div>
<div style="display:table-cell" id="div2">
content
</div>
এই দুটি ডিভ (যেটি আছে display:table-cell
) এর মধ্যে স্থান তৈরি করার কোনও উপায় আছে ?
আমার এখানে দুটি ডিভ রয়েছে:
<div style="display:table-cell" id="div1">
content
</div>
<div style="display:table-cell" id="div2">
content
</div>
এই দুটি ডিভ (যেটি আছে display:table-cell
) এর মধ্যে স্থান তৈরি করার কোনও উপায় আছে ?
উত্তর:
আপনি border-spacing
সম্পত্তি ব্যবহার করতে পারেন :
এইচটিএমএল:
<div class="table">
<div class="row">
<div class="cell">Cell 1</div>
<div class="cell">Cell 2</div>
</div>
</div>
সিএসএস:
.table {
display: table;
border-collapse: separate;
border-spacing: 10px;
}
.row { display:table-row; }
.cell {
display:table-cell;
padding:5px;
background-color: gold;
}
অন্য কোন বিকল্প?
ভাল , আসলে না।
কেন?
margin
সম্পত্তি উপাদানগুলির জন্য প্রযোজ্য নয়display: table-cell
।padding
সম্পত্তি ঘরগুলির প্রান্তের মধ্যে স্থান তৈরি করে না।float
সম্পত্তি তাদের table-cell
মৌলিক উপাদানগুলির মতো লম্বা হতে সক্ষম এমন উপাদানগুলির প্রত্যাশিত আচরণকে নষ্ট করে ।position: relative
উপর table-*-group
, table-row
, table-column
, table-cell
, এবং table-caption
উপাদানের undefined করা হয়।
border-right: 10px solid #FFF
। সিএসএস ড্রপডাউন মেনু ডিজাইন করার সময় এটি আমার পক্ষে ভাল কাজ করেছে যখন আমি table-cell
উপাদানগুলির মধ্যে কিছু জায়গা চাই ।
সম্ভব হলে স্বচ্ছ সীমানা ব্যবহার করুন।
https://jsfiddle.net/74q3na62/
এইচটিএমএল
<div class="table">
<div class="row">
<div class="cell">Cell 1</div>
<div class="cell">Cell 2</div>
<div class="cell">Cell 3</div>
</div>
</div>
সিএসএস
.table {
display: table;
border: 1px solid black;
}
.row { display:table-row; }
.cell {
display: table-cell;
background-clip: padding-box;
background-color: gold;
border-right: 10px solid transparent;
}
.cell:last-child {
border-right: 0 none;
}
border-spacing
গৃহীত উত্তর অনুসারে আপনি সম্পত্তিটি ব্যবহার করতে পারেন , তবে এটি কেবল টেবিলের ঘরগুলির মধ্যেই নয় টেবিলের ঘর এবং টেবিলের ধারকগুলির মধ্যেও স্থান তৈরি করে। এটি অযাচিত হতে পারে।
যদি আপনার টেবিল কোষগুলিতে দৃশ্যমান সীমানাগুলি আপনার প্রয়োজন না হয় তাই transparent
আপনার জন্য সেল মার্জিন উত্পন্ন করতে সীমানা ব্যবহার করা উচিত । স্বচ্ছ সীমানাগুলি সেটিংয়ের প্রয়োজন background-clip: padding-box;
কারণ অন্যথায় সারণীতে সারণীর ঘরগুলির পটভূমি রঙ প্রদর্শিত হয়।
স্বচ্ছ সীমানা এবং পটভূমি-ক্লিপ IE9 উপরের দিকে (এবং অন্যান্য সমস্ত আধুনিক ব্রাউজারগুলি) সমর্থিত। আপনার যদি IE8 সামঞ্জস্যের প্রয়োজন হয় বা প্রকৃত স্বচ্ছ স্থানের প্রয়োজন না হয় তবে আপনি কেবল একটি সাদা সীমানার রঙ সেট করতে পারেন এবং background-clip
বাদ দিতে পারেন।
<div style="display:table;width:100%" >
<div style="display:table-cell;width:49%" id="div1">
content
</div>
<!-- space between divs - display table-cell -->
<div style="display:table-cell;width:1%" id="separated"></div>
<!-- //space between divs - display table-cell -->
<div style="display:table-cell;width:50%" id="div2">
content
</div>
</div>
ঠিক আছে, উপরেরটি কাজ করে, আমার সমাধানটি এখানে একটু কম মার্কআপ প্রয়োজন এবং আরও নমনীয়।
.cells {
display: inline-block;
float: left;
padding: 1px;
}
.cells>.content {
background: #EEE;
display: table-cell;
float: left;
padding: 3px;
vertical-align: middle;
}
<div id="div1" class="cells"><div class="content">My Cell 1</div></div>
<div id="div2" class="cells"><div class="content">My Cell 2</div></div>
যে কোনও নামের সাথে আমি একটি নতুন ডিভ তৈরি করুন (আমি কেবল টেবিল-বিভক্ত ব্যবহার করব) এবং এতে সামগ্রী যুক্ত না করে এটিকে প্রস্থ দিন, যখন এটি পৃথক করা দরকার।
আপনার প্রয়োজনীয় প্রস্থটি যা যুক্ত করতে পারেন। আমি মাত্র 0.6% ব্যবহার করেছি কারণ আমার যখন এটি করতে হয়েছিল তখন এটিই আমার প্রয়োজন ছিল।
.table-split {
display: table-cell;
width: 0.6%
}
<div class="table-split"></div>
position: relative
,।