रूबी ऑन रेल्स - लेआउट्स
एक लेआउट एक HTML पृष्ठ के परिवेश को परिभाषित करता है। यह आपके अंतिम आउटपुट के सामान्य रूप और दृश्य को परिभाषित करने का स्थान है। लेआउट फाइलें ऐप / व्यू / लेआउट में रहती हैं।
इस प्रक्रिया में एक लेआउट टेम्पलेट को परिभाषित करना और फिर नियंत्रक को यह बताना कि यह मौजूद है और इसका उपयोग करना है। सबसे पहले, टेम्पलेट बनाते हैं।
ऐप / विचार / लेआउट के लिए standard.html.erb नामक एक नई फ़ाइल जोड़ें। आप नियंत्रकों को जानते हैं कि फ़ाइल के नाम से किस टेम्पलेट का उपयोग करना है, इसलिए उसी नामकरण योजना का पालन करने की सलाह दी जाती है।
निम्न कोड को नए standard.html.erb फ़ाइल में जोड़ें और अपने परिवर्तनों को सहेजें -
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv = "Content-Type" content = "text/html; charset = iso-8859-1" />
<meta http-equiv = "Content-Language" content = "en-us" />
<title>Library Info System</title>
<%= stylesheet_link_tag "style" %>
</head>
<body id = "library">
<div id = "container">
<div id = "header">
<h1>Library Info System</h1>
<h3>Library powered by Ruby on Rails</h3>
</div>
<div id = "content">
<%= yield -%>
</div>
<div id = "sidebar"></div>
</div>
</body>
</html>
आपके द्वारा अभी जोड़ी गई सभी चीजें दो लाइनों को छोड़कर मानक HTML तत्व थीं। stylesheet_link_tagसहायक विधि एक स्टाइलशीट <लिंक> आउटपुट करती है। इस उदाहरण में, हम style.css स्टाइल शीट को लिंक कर रहे हैं। yield कमांड रेल को बताती है कि उसे यहां बताई गई विधि के लिए html.erb डालना चाहिए।
अब खोलो book_controller.rb और पहली पंक्ति के ठीक नीचे निम्न पंक्ति जोड़ें -
class BookController < ApplicationController
layout 'standard'
def list
@books = Book.all
end
...................
यह नियंत्रक को निर्देश देता है कि हम standard.html.erb फ़ाइल में उपलब्ध लेआउट का उपयोग करना चाहते हैं। अब उन पुस्तकों को ब्राउज़ करने का प्रयास करें जो निम्न स्क्रीन का उत्पादन करेंगे।
स्टाइल शीट जोड़ना
अब तक, हमने कोई स्टाइल शीट नहीं बनाई है, इसलिए रेल डिफ़ॉल्ट शैली शीट का उपयोग कर रही है। अब हम एक नई फाइल बनाते हैं, जिसे style.css कहते हैं और इसे / public / स्टाइलशीट में सेव करते हैं। इस फ़ाइल में निम्न कोड जोड़ें।
body {
font-family: Helvetica, Geneva, Arial, sans-serif;
font-size: small;
font-color: #000;
background-color: #fff;
}
a:link, a:active, a:visited {
color: #CD0000;
}
input {
margin-bottom: 5px;
}
p {
line-height: 150%;
}
div#container {
width: 760px;
margin: 0 auto;
}
div#header {
text-align: center;
padding-bottom: 15px;
}
div#content {
float: left;
width: 450px;
padding: 10px;
}
div#content h3 {
margin-top: 15px;
}
ul#books {
list-style-type: none;
}
ul#books li {
line-height: 140%;
}
div#sidebar {
width: 200px;
margin-left: 480px;
}
ul#subjects {
width: 700px;
text-align: center;
padding: 5px;
background-color: #ececec;
border: 1px solid #ccc;
margin-bottom: 20px;
}
ul#subjects li {
display: inline;
padding-left: 5px;
}
अब अपने ब्राउज़र को रिफ्रेश करें और अंतर देखें -
आगे क्या है?
अगला अध्याय बताता है कि किसी भी डेटाबेस में रिकॉर्ड जोड़ने, हटाने और संशोधित करने के लिए उपयोगकर्ता को पहुंच प्रदान करने के लिए रेल स्कैफोल्डिंग का उपयोग करके एप्लिकेशन कैसे विकसित करें।