Difference between revisions of "Team:Cologne-Duesseldorf/Model"

Line 381: Line 381:
 
</pre>
 
</pre>
  
<h3>Basics</h3>
 
<p>CSS code is structured in the following way: Say we have heading that is defined in our document as <code>&lt;h1&gt;Heading&lt;/h1&gt;</code>. Then we can change the font size of this heading via <code>h1 {font-size: 20px;}</code> in our CSS file. The syntax of this is a little different to what we have seen before, so let's dissect it a bit. The <code>h1</code> part is the selector of the CSS rule. In this case it is the element selector, selecting every <code>h1</code> element on the page. There are also the id <code>#yourIdName</code> and class <code>.yourClassName</code> selectors. They can for example be used on a <code>div</code> element, if it has the respective attribute <code>&lt;div class=&quot;yourClassName&quot;&gt;</code> and/or <code>&lt;div id=&quot;yourIdName&quot;&gt;</code>. The actual properties of the element are changed inside the curvy brackets <code>{font-size: 20px;}</code>. The syntax here is property: value;. The semicolon at the end can be omitted on the last property or if only one property is stated, but since it doesn't hurt to have it at the end I'd advice you to always set it, to avoid mistakes.</p>
 
<p>A large list of CSS properties can be found <a href="https://www.w3schools.com/cssref/default.asp">here</a>.</p>
 
<p>There is also a whole lot more of <a href="https://www.w3schools.com/cssref/css_selectors.asp">selectors</a>. I found the following ones to be very important, but depending on what you are trying to accomplish it is well worth taking a look at the page linked before.</p>
 
 
<table>
 
  <thead>
 
    <tr>
 
      <th>Selector
 
      <th>Function
 
  <tbody>
 
    <tr>
 
      <th><code>*</code>
 
      <th>All elements
 
    <tr>
 
      <th><code>element1 element2</code>
 
      <th>All element2 that are inside element1
 
    <tr>
 
      <th><code>element1,element2</code>
 
      <th>Both elements
 
    <tr>
 
      <th><code>element:hover</code>
 
      <th>The element while your mouse is hovering over it
 
</table>
 
  
  

Revision as of 07:26, 21 September 2017

Wiki Tutorial

Welcome to our wiki coding tutorial. We know that many teams struggle to set up their wiki so we decided to write a guide to help you get started. Large parts of it are based on the w3schools HTML and CSS tutorials. If we left anything unclear you can probably find a solution in no time there, otherwise feel free to contact us.

HTML

Basics

A website might not look like it, but it is basically a text document with some additional styling. The following example shows the minimal website:

		  
<!DOCTYPE html>
<html>
<head>
</head>
<body>
</body>
</html>
		  
		

The <!DOCTYPE html> declaration states the type of the document, in this case HTML5, just like a file extension. The <html> and </html> tags surround all the code that you can write. Inside the <head></head> tags you can import CSS stylesheets, set the display name of the website and other meta information. Inside the <body></body> element you write the actual visible page content. Since the doctype and page titles are handled by mediawiki it is not necessary to include them in your wiki page.

The <!DOCTYPE html> declaration states the type of the document, in this case HTML5, just like a file extension. The <html> and </html> tags surround all the code that you can write. Inside the <head></head> tags you can import CSS stylesheets, set the display name of the website and other meta information. Inside the <body></body> element you write the actual visible page content. Since the doctype and page titles are handled by mediawiki it is not necessary to include them in your wiki page.

Basic Layout

To understand how to set up your wiki you first have to grasp some basic html and CSS concepts. Modern websites are usually build with div-containers, which basically are rectangles. These containers can be stacked, next to each other or nested inside another. Html elements are constructed using opening angle brackets <> and are usualy closed with closing angle brackets </>. They can be styled using either the class attribute <div class=""&gt or using an id <div id=""&gt, the difference between those two being , that each id tag should only be used once per page, while the class tag can be used as often as liked. You can also style the divs using the style inline method <div style=""&gt, but this is not recommended, since you would have to do this for every single element over again. The following code snippet shows the nesting of containers, with a little styling added (not shown).

		    
<div>
  <div>
    <div>
      <p>Test</p>
    </div>
  </div>
</div>
		    
		  

Test

The Wiki Layout

Just alike the example above the wiki already provides several levels of layout that you can access: #globalWrapper, #content, #HQ_page, and #bodyContent. While you could just nullify the styling of these divs and build your page backbone with your own divs I highly recommend actually overwriting them, as this gives you the possibility to build your wiki page backbone in a way that your other team members cannot overwrite it by accident. We will cover how in the CSS section of this post.

HTML elements

Headings

Just like in your favorite text editor, html comes with multiple levels of headings.

		      
<h1>Heading 1</h1>
		      
		    

Heading 1

		      
<h2>Heading 2</h2>
		      
		    

Heading 2

		      
<h3>Heading 3</h3>
		      
		    

Heading 3

		      
<h4>Heading 4</h4>
		      
		    

Heading 4

		      
<h5>Heading 5</h5>
		      
		    
Heading 5
		      
<h6>Heading 6</h6>
		      
		    
Heading 6

Text

Paragraphs

Whenever you are writing vanilla text, you should use the paragraph element <p>. Note though, that newline characters of text that you copy inside this tag are omitted. If you want a linebreak between two chunks of text you can either insert the two texts in seperate paragraph elements or use the line break element <br>. Note that br does not need a closing tag. Dependeing on your styling the paragraphs might have some margin or padding, thus increasing the distance between the two paragraphs when using <p> instead of <br>.

		      
<p>
  Paragraph one
  <br>
  Paragraph two
</p>
		      
		    

Paragraph one
Paragraph two

		      
<p>
  Paragraph one
</p>
<p>
  Paragraph two
</p>
		      
		    

Paragraph one

Paragraph two

Formatted text

If you want to emphasize certain elements of your paragraphs you can do it by using several inline elements, each of which you can style to your liking.

		      
<em>Emphasized text</em>
<strong>Strong text</strong>
<code>A piece of computer code</code>
<samp>Sample output from a computer program</samp>
<kbd>Keyboard input</kbd>
<var>Variable</var>
<mark>Mark</mark>
<cite>Cite</cite>
<dfn>Definition</dfn>
<sup>Higher</sup>
<sub>Lower</sub>
<small>Small text</small>
<del>Deleted text</del>
<ins>Inserted text</ins>
<abbr title="abbrevation explanation">abbrevation</abbr>
		      
		    

Emphasized text
Strong text
A piece of computer code
Sample output from a computer program
Keyboard input
Variable
Mark
Cite
Definition
Normal, Higher
Normal, Lower
Normal, Small text
Deleted text
Inserted text
abbrevation

Links

		      
<a href="https://2017.igem.org/Team:Cologne-Duesseldorf">
  Link to our wiki home page
</a>
		      
		    

Images

Images can be embedded using the <img> tag. Note that there is no closing </img> tag.

		      
		<img src="https://static.igem.org/mediawiki/2017/0/0d/T--Cologne-Duesseldorf--artico-logo-cities.svg">
		      
		    

Lists

Unordered List

		      
<ul>
  <li>Element 1</li>
  <li>Element 2</li>
  <li>Element 3</li>
</ul>
		      
		    
  • Element 1
  • Element 2
  • Element 3

Ordered List

		      
<ol>
  <li>Element 1</li>
  <li>Element 2</li>
  <li>Element 3</li>
</ol>
		      
		    
  1. Element 1
  2. Element 2
  3. Element 3

Nested List

		      
<ol>
  <li>Element 1</li>
  <ul>
    <li>Element 2</li>
  </ul>
  <li>Element 3</li>
</ol>
		      
		    
  1. Element 1
    • Element 2
  2. Element 3

Tables

		      
<table>
  <thead>
    <tr>
      <th>Head 1</th>
      <th>Head 2</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Data 1</td>
      <td>Data 2</td>
    </tr>
  </tbody>
</table>
		        
Head 1 Head 2
Data 1 Data 2

Semantic Elements

header, footer, article, section

CSS

After we have covered some HTML, let us take a look at the second language we need to build a wiki. While HTML provides the structural backbone and content of the page, CSS is used to style it. As written before, there are three ways to write CSS code: Inline, directly onto the element, in the header of the page and in a seperate file. Since you want to use the same styling on every wiki page, I strongly suggest to keep the css file seperate and to import it at the top of your page. In mediawiki the easiest way to do that is to create a seperate page, for example https://2017.igem.org/Template:YourTeamName/css and then import it by writing {{Template:YourTeamName/css}} at the top of the page you are writing, before the <html>tag. The backbone of the css template page would look like the following:

		  
<html>
  <head>
    <style>

    </style>
  </head>
</html>