<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Point2Zero &#187; Code</title>
	<atom:link href="http://www.point2zero.net/blog/category/code/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.point2zero.net/blog</link>
	<description>Bring to you Information Technology</description>
	<lastBuildDate>Tue, 23 Mar 2010 11:17:35 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Quelques tips en CSS</title>
		<link>http://www.point2zero.net/blog/2010/03/23/quelques-tips-en-css/</link>
		<comments>http://www.point2zero.net/blog/2010/03/23/quelques-tips-en-css/#comments</comments>
		<pubDate>Tue, 23 Mar 2010 10:36:17 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[CSS]]></category>
		<category><![CDATA[Code]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=1003</guid>
		<description><![CDATA[
			
				
			
		
Bonjour, aujourd'hui je vous ai préparé un article sur le CSS (Cascading Style Sheet).
3 méthodes pour ajouter le CSS dans vos pages :
En inline qui consiste a ajouter le CSS directement dans vos balises HTML (pas propre mais utile pour faire des tests rapides)

&#60;a href=&#34;http://www.point2zero.net&#34; style=&#34;font-size:1.2em;&#34;&#62;Point2Zero&#60;/a&#62;

Avec le CSS entre les balises &#60;head&#62; et du type [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F03%2F23%2Fquelques-tips-en-css%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F03%2F23%2Fquelques-tips-en-css%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Bonjour, aujourd'hui je vous ai préparé un article sur le CSS (Cascading Style Sheet).</p>
<p>3 méthodes pour ajouter le CSS dans vos pages :<br />
En inline qui consiste a ajouter le CSS directement dans vos balises HTML (pas propre mais utile pour faire des tests rapides)</p>
<pre class="brush: xml;">
&lt;a href=&quot;http://www.point2zero.net&quot; style=&quot;font-size:1.2em;&quot;&gt;Point2Zero&lt;/a&gt;
</pre>
<p>Avec le CSS entre les balises &lt;head&gt; et du type :</p>
<pre class="brush: xml;">
&lt;html&gt;
&lt;head&gt;
&lt;title&gt;Ma Page Web&lt;/title&gt;
&lt;style type=&quot;text/css&quot;&gt;
/* Votre css ici */
&lt;/style&gt;
&lt;/head&gt;
...
</pre>
<p>Ou en utilisant une feuille de style externe par exemple : style.css que l'on inclus dans notre &lt;head&gt; soit avec :</p>
<pre class="brush: xml;">
&lt;html&gt;
&lt;head&gt;
&lt;title&gt;Ma Page Web&lt;/title&gt;
&lt;link rel=&quot;stylesheet&quot;  href=&quot;style.css&quot; type=&quot;text/css&quot; media=&quot;all&quot; /&gt;
&lt;/head&gt;
...
</pre>
<p>Ou avec ce code :</p>
<pre class="brush: xml;">
&lt;html&gt;
&lt;head&gt;
&lt;title&gt;Ma Page Web&lt;/title&gt;
&lt;style type=&quot;text/css&quot; media=&quot;all&quot;&gt;
	 @import &quot;style.css&quot;;
&lt;/style&gt;
&lt;/head&gt;
...
</pre>
<p>Comment centrer un élément dans une page web en CSS ?<br />
Nous avons une page web avec une balise &lt;div&gt; qui se trouve dans la balise &lt;body&gt;. Le but étant de centrer la balise &lt;div&gt; quoi qu'il se passe.</p>
<p>Dans un premier temps nous allons ajouter des "background" a nos balises &lt;body&gt; et &lt;div&gt; pour les différencier.</p>
<p>Mettre la balise &lt;body&gt; avec un fond gris #AAA et la balise &lt;div&gt; avec un fond blanc #FFF.</p>
<pre class="brush: css;">
body{
  background-color:#AAA;
}
div{
  background-color:#FFF;
}
</pre>
<p>Jusque là rien de trés difficile. Maintenant ajoutons une taille à notre &lt;div&gt; pour pouvoir le centrer en fonction de sa taille.</p>
<pre class="brush: css;">
body{
  background-color:#AAA;
}
div{
  background-color:#FFF;
  width:960px;
}
</pre>
<p>Et ajoutons une marge sur notre &lt;div&gt;</p>
<pre class="brush: css;">
body{
  background-color:#AAA;
}
div{
  background-color:#FFF;
  margin:0 auto;
  width:960px;
}
</pre>
<p>Petite explication : j'utilise un racourcis pour la marge. Normalement j'aurai du faire :</p>
<pre class="brush: css;">
margin-top:0;
margin-right:auto;
margin-bottom:0;
margin-left:auto;
</pre>
<p>Le racourci permet d'écrire beaucoup moins de texte (chargement plus rapide, css moins lourd etc...).<br />
J'ai une margin en haut et en bas à 0 donc pas de marge et a gauche et a droite en auto. Donc en fonction de la place disponible à droite et a gauche de l'élément il centrera le contenu.<br />
Autres choses :<br />
- Triez les propriétés dans l'ordre alphabétique.<br />
- N'indiquez pas l'unité quand la valeur est 0. 0px = 0% = 0 <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /><br />
Avant :</p>
<pre class="brush: css;">
body{
  border:0px;
  margin:0%;
  padding:0;
  background:#FFF;
  outline:0;
}
</pre>
<p>Apres :</p>
<pre class="brush: css;">
body{
  background:#FFF;
  border:0;
  margin:0;
  padding:0;
  outline:0;
}
</pre>
<p>Facile non ?</p>
<p>Voici quelques liens de Framework CSS pour construire vos pages facilement :<br />
- <a href="http://960.gs/">960grid</a>.<br />
- <a href="http://elasticss.com/">Elasticss</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2010/03/23/quelques-tips-en-css/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>IE6 meurt petit a petit...</title>
		<link>http://www.point2zero.net/blog/2010/03/15/ie6-meurt-petit-a-petit/</link>
		<comments>http://www.point2zero.net/blog/2010/03/15/ie6-meurt-petit-a-petit/#comments</comments>
		<pubDate>Mon, 15 Mar 2010 14:29:25 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[CSS]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Logiciel]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=996</guid>
		<description><![CDATA[
			
				
			
		
Depuis Janvier 2010 j'avais annoncé que je ne faisait plus de developpement pour IE6.
Car il y a 2 nouvelles versions du navigateur :
- la 7 sortie depuis maintenant 3 ans et 6 mois.
- la 8 sortie depuis bientôt 9 mois.

Pourquoi de plus en plus de sites apparaissent contre la version 6 du navigateur de Microsoft [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F03%2F15%2Fie6-meurt-petit-a-petit%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F03%2F15%2Fie6-meurt-petit-a-petit%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Depuis Janvier 2010 j'avais annoncé que je ne faisait plus de developpement pour IE6.<br />
Car il y a 2 nouvelles versions du navigateur :<br />
- la 7 sortie depuis maintenant 3 ans et 6 mois.<br />
- la 8 sortie depuis bientôt 9 mois.</p>
<p><a href="http://www.point2zero.net/blog/wp-content/uploads/2010/03/ripie6.jpg"><img src="http://www.point2zero.net/blog/wp-content/uploads/2010/03/ripie6.jpg" alt="" title="ripie6" width="380" height="386" class="aligncenter size-full wp-image-997" /></a></p>
<p>Pourquoi de plus en plus de sites apparaissent contre la version 6 du navigateur de Microsoft ? Le navigateur ne supporte pas les PNG avec de la transparence, les feuilles de styles CSS doivent contenir <a href="http://L9.fr/KE">des hacks</a> ou etre completement réécrite pour ce navigateur. La tâche n'est pas si simple pour un developpeur web. Une solution existe en jQuery pour proposer la mise à jour du navigateur a vos visiteurs&nbsp;: <a href="http://ie6update.com/">ie6update</a>. Ce site propose d'ajouter un code jQuery sur votre site qui affichera (comme l'affichage d'un direct x ou autre) une barre en haut du navigateur disant que celui-ci n'est pas à jour.</p>
<p>D'autres sites tel que <a href="http://www.ie6nomore.com/">ie6nomore</a> ou <a href="http://ripie6.com/">ripie6</a> l'ajoute au coté du défunt Nescape.</p>
<p>Microsoft <a href="http://support.microsoft.com/gp/lifesupsps#Internet_Explorer">aretera le support</a> de son navigateur le 13 juillet prochain vous pouvez suivre le décompte sur <a href="http://isie6dead.com/">isie6dead</a>.</p>
<p>En attendant j'ajoute souvent le script proposé par ie6update.com <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2010/03/15/ie6-meurt-petit-a-petit/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Le Fieldset peut être utile en jQuery</title>
		<link>http://www.point2zero.net/blog/2010/03/13/le-fieldset-peut-etre-utile-en-jquery/</link>
		<comments>http://www.point2zero.net/blog/2010/03/13/le-fieldset-peut-etre-utile-en-jquery/#comments</comments>
		<pubDate>Sat, 13 Mar 2010 15:10:01 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[xHTML]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=985</guid>
		<description><![CDATA[
			
				
			
		
Pendant mes cours de xHTML, CSS, Javascript cette semaine j'ai expliqué l'utilisation de la balise html fieldset.
J'utilise un plugin jQuery qui permet grâce à l'utilisation des balises fieldset d'avoir un formulaire qu'on remplis pas à pas.

Prenons un exemple de code tel que :

&#60;!-- N'oubliez pas d'ajouter ici le doctype et les balises html, head etc... [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F03%2F13%2Fle-fieldset-peut-etre-utile-en-jquery%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F03%2F13%2Fle-fieldset-peut-etre-utile-en-jquery%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Pendant mes cours de xHTML, CSS, Javascript cette semaine j'ai expliqué l'utilisation de la balise html fieldset.</p>
<p>J'utilise un plugin jQuery qui permet grâce à l'utilisation des balises fieldset d'avoir un formulaire qu'on remplis pas à pas.</p>
<p><a href="http://www.point2zero.net/blog/wp-content/uploads/2010/03/image.ftw_.jpg"><img class="aligncenter size-full wp-image-986" title="image.ftw" src="http://www.point2zero.net/blog/wp-content/uploads/2010/03/image.ftw_.jpg" alt="" width="500" height="229" /></a></p>
<p>Prenons un exemple de code tel que :</p>
<pre class="brush: xml;">
&lt;!-- N'oubliez pas d'ajouter ici le doctype et les balises html, head etc... --&gt;
&lt;body&gt;
  &lt;div id=&quot;page&quot;&gt;
    &lt;form action=&quot;submit.php&quot; method=&quot;post&quot;&gt;
      &lt;fieldset&gt;
        &lt;legend&gt;Informations Personnelles :&lt;/legend&gt;
        &lt;label for=&quot;nom&quot;&gt;Nom :&lt;/label&gt;
        &lt;input id=&quot;nom&quot; name=&quot;nom&quot; type=&quot;text&quot; /&gt;
        &lt;label for=&quot;prenom&quot;&gt;Prénom :&lt;/label&gt;
        &lt;input id=&quot;prenom&quot; name=&quot;prenom&quot; type=&quot;text&quot; /&gt;
        &lt;label for=&quot;sexe&quot;&gt;Sexe :&lt;/label&gt;
        &lt;input id=&quot;sexem&quot; name=&quot;sexe&quot; type=&quot;radio&quot; value=&quot;m&quot; /&gt;M
        &lt;input id=&quot;sexef&quot; name=&quot;sexe&quot; type=&quot;radio&quot; value=&quot;f&quot; /&gt;F
      &lt;/fieldset&gt;
      &lt;fieldset&gt;
        &lt;legend&gt;Domicile :&lt;/legend&gt;&lt;label for=&quot;adresse&quot;&gt;Adresse :&lt;/label&gt;
        &lt;textarea id=&quot;adresse&quot; cols=&quot;50&quot; rows=&quot;3&quot; name=&quot;adresse&quot;&gt;&lt;/textarea&gt;
        &lt;label for=&quot;cp&quot;&gt;Code Postal :&lt;/label&gt;
        &lt;input id=&quot;cp&quot; name=&quot;cp&quot; type=&quot;text&quot; /&gt;
        &lt;label for=&quot;ville&quot;&gt;Ville :&lt;/label&gt;
        &lt;input id=&quot;ville&quot; name=&quot;ville&quot; type=&quot;text&quot; /&gt;
      &lt;/fieldset&gt;
      &lt;fieldset&gt;
        &lt;legend&gt;Compte :&lt;/legend&gt;
        &lt;label for=&quot;identifiant&quot;&gt;Identifiant :&lt;/label&gt;
        &lt;input id=&quot;identifiant&quot; name=&quot;identifiant&quot; type=&quot;text&quot; /&gt;
        &lt;label for=&quot;mdp&quot;&gt;Mot de passe :&lt;/label&gt;
        &lt;input id=&quot;mdp&quot; name=&quot;mdp&quot; type=&quot;password&quot; /&gt;
        &lt;label for=&quot;confirm&quot;&gt;Confirmation :&lt;/label&gt;
        &lt;input id=&quot;confirm&quot; name=&quot;confirm&quot; type=&quot;password&quot; /&gt;
      &lt;/fieldset&gt;
      &lt;p&gt;
        &lt;input id=&quot;submit&quot; name=&quot;submit&quot; type=&quot;submit&quot; value=&quot;Envoyer&quot; /&gt;
      &lt;/p&gt;
    &lt;/form&gt;
  &lt;/div&gt;
&lt;/body&gt;
&lt;/html&gt;
</pre>
<p>Les trois parties du formulaire : Informations Personnelles, Domicile et Compte seront découpé en 3 étapes sur 3 pages avec une navigation "etape précédente" et "étape suivante".</p>
<p><a href="http://www.point2zero.net/blog/wp-content/uploads/2010/03/image.fieldsettostep.png"><img class="aligncenter size-full wp-image-989" title="image.fieldsettostep" src="http://www.point2zero.net/blog/wp-content/uploads/2010/03/image.fieldsettostep.png" alt="" width="500" height="316" /></a></p>
<p>L'utilisateur peut donc voir qu'il y a 3 étapes pour valider le formulaire, je trouve que le formulaire est plus clair quand il est fait étape par étape.<br />
<a href="http://L9.fr/Kp">Voir la démo</a>. <a href="http://L9.fr/Kq">Télécharger le plugin</a>.<br />
Pour en savoir plus rendez vous sur la page <a href="http://L9.fr/Ko">FormToWizard plugin</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2010/03/13/le-fieldset-peut-etre-utile-en-jquery/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Quelques plugins jQuery utiles</title>
		<link>http://www.point2zero.net/blog/2010/01/24/quelques-plugins-jquery-utiles/</link>
		<comments>http://www.point2zero.net/blog/2010/01/24/quelques-plugins-jquery-utiles/#comments</comments>
		<pubDate>Sun, 24 Jan 2010 17:31:57 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[jQuery]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=972</guid>
		<description><![CDATA[
			
				
			
		
Voici trois plugin jQuery que j'utilise relativement souvent :
- Time ago


Permet de modifier un timestamp en : "Il y a 4 minutes" ou "Il y a 8 jours", "Il y a un mois" comme ce qu'on peut voir dans les timeline de Twitter ou Facebook.
- jQuery Validation


Permet la validation des champs d'un formulaire avant d'être [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F01%2F24%2Fquelques-plugins-jquery-utiles%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F01%2F24%2Fquelques-plugins-jquery-utiles%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Voici trois plugin jQuery que j'utilise relativement souvent :</p>
<p>- <a href="http://timeago.yarp.com/">Time ago</a><br />
<a href="http://timeago.yarp.com/"><img src="http://www.point2zero.net/blog/wp-content/uploads/2010/01/TimeAgo.png" alt="" title="TimeAgo" width="371" height="111" class="alignleft size-full wp-image-973" /></a><br />
<br class="clear" /><br />
Permet de modifier un timestamp en : "Il y a 4 minutes" ou "Il y a 8 jours", "Il y a un mois" comme ce qu'on peut voir dans les timeline de Twitter ou Facebook.</p>
<p>- <a href="http://bassistance.de/jquery-plugins/jquery-plugin-validation/">jQuery Validation</a><br />
<a href="http://bassistance.de/jquery-plugins/jquery-plugin-validation/"><img src="http://www.point2zero.net/blog/wp-content/uploads/2010/01/Screen-shot-2010-01-24-at-18.25.05.png" alt="" title="jQuery Validation" width="541" height="252" class="alignleft size-full wp-image-974" /></a><br />
<br class="clear" /><br />
Permet la validation des champs d'un formulaire avant d'être envoyé.</p>
<p>- <a href="http://deepliquid.com/projects/Jcrop">jCrop</a><br />
<a href="http://deepliquid.com/projects/Jcrop"><img src="http://www.point2zero.net/blog/wp-content/uploads/2010/01/jCrop.png" alt="" title="jCrop" width="427" height="322" class="alignleft size-full wp-image-975" /></a><br />
<br class="clear" /><br />
Permet de retailler une image sur un site internet. J'avais fait ce genre de code en javascript + php (sur le site de Live9 pour l'envoi des pochettes) avant de trouver ce plugin jQuery.</p>
<p>N'hésitez pas a partager vous aussi les différents plugins que vous utilisez régulièrement.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2010/01/24/quelques-plugins-jquery-utiles/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Envoi de mail avec CodeIgniter plain/text [edit ET text/html]</title>
		<link>http://www.point2zero.net/blog/2010/01/04/envoi-de-mail-avec-codeigniter/</link>
		<comments>http://www.point2zero.net/blog/2010/01/04/envoi-de-mail-avec-codeigniter/#comments</comments>
		<pubDate>Mon, 04 Jan 2010 12:30:11 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[CodeIgniter]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[PHP]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=951</guid>
		<description><![CDATA[
			
				
			
		
Nous allons aujourd'hui envoyer un mail grâce à CodeIgniter.
Pour cela il faut créer un fichier email.php dans le répertoire application/config/
Dans ce fichier plusieurs méthodes pour envoyer un mail soit via "mail", "sendmail" ou via "smtp".
Nous allons utiliser un compte mail donc le SMTP.

&#60;?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

$config['protocol'] = 'smtp';
$config['smtp_host'] [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F01%2F04%2Fenvoi-de-mail-avec-codeigniter%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F01%2F04%2Fenvoi-de-mail-avec-codeigniter%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Nous allons aujourd'hui envoyer un mail grâce à CodeIgniter.</p>
<p>Pour cela il faut créer un fichier email.php dans le répertoire application/config/<br />
Dans ce fichier plusieurs méthodes pour envoyer un mail soit via "mail", "sendmail" ou via "smtp".<br />
Nous allons utiliser un compte mail donc le SMTP.</p>
<pre class="brush: php;">
&lt;?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

$config['protocol'] = 'smtp';
$config['smtp_host'] = 'smtp.domaine.com';
$config['smtp_port'] = 25;
$config['smtp_user'] = 'mail@domaine.com';
$config['smtp_pass'] = 'motdepasseducomptemail';
</pre>
<p>Créer ensuite un contrôleur par exemple controllers/home.php<br />
Dans votre home vous allez créer la méthode "send" qui permet l'envoi du mail.</p>
<pre class="brush: php;">
&lt;?php
class Home extends Controller {

	function Home()
	{
            parent::Controller();
	}

	function index()
	{
            // On charge la vue index
            $this-&gt;load-&gt;view('index');
	}

	function mail()
	{
            $this-&gt;load-&gt;library('email');
            $this-&gt;email-&gt;set_newline(&quot;\r\n&quot;);
            $this-&gt;email-&gt;from('email@domaine.com', 'Prénom NOM');
            $this-&gt;email-&gt;to('destinataire@domaine.com');
            $this-&gt;email-&gt;subject('Titre du mail');
            $this-&gt;email-&gt;message('Contenu du mail.');

            if($this-&gt;email-&gt;send()) {
                echo 'E-mail envoyé !';
            } else {
                echo 'Oup\'s ! Il y a eu un soucis lors de l\'envoi !';
            }
	}
}
</pre>
<p>Ce code fonctionne parfaitement en "plain/text".</p>
<p>Pour envoyer un mail au format html modifier votre fichier config/email.php :</p>
<pre class="brush: php;">
&lt;?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

// Ajout du format html (mail en html)
$config['mailtype'] = 'html';
// Ajout de l'encodage du mail
$config['charset']  = 'iso-8859-1';

$config['protocol'] = 'smtp';
$config['smtp_host'] = 'smtp.domaine.com';
$config['smtp_port'] = 25;
$config['smtp_user'] = 'mail@domaine.com';
$config['smtp_pass'] = 'motdepasseducomptemail';
</pre>
<p>Et dans votre contrôleur modifier le contenu du message par un contenu avec des balises html comme ceci par exemple :</p>
<pre class="brush: php;">
$this-&gt;email-&gt;message('&lt;p&gt;Contenu du mail &lt;b&gt;en gras&lt;/b&gt;.&lt;/p&gt;');
</pre>
<p><del>Impossible pour nous d'envoyer un mail au format HTML avec CodeIgniter pour l'instant !<br />
J'ai laissé un message sur le forum de Code Igniter pour voir si ça vient pas du framework directement ou moi qui ai mal compris un truc <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </del></p>
<p><u>Edit</u> : Il fallait ajouter le type d'encodage du mail pour pouvoir envoyer au format HTML <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2010/01/04/envoi-de-mail-avec-codeigniter/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
		<item>
		<title>Nouveautés 2010 !</title>
		<link>http://www.point2zero.net/blog/2010/01/01/nouveautes-2010/</link>
		<comments>http://www.point2zero.net/blog/2010/01/01/nouveautes-2010/#comments</comments>
		<pubDate>Fri, 01 Jan 2010 16:27:42 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[Point2Zero]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=948</guid>
		<description><![CDATA[
			
				
			
		
Cette année quelques choses changeront :
Le support d'IE6 ne sera plus pris en compte quel que soit le projet. Internet Explorer 7 et 8 étant en place depuis déjà pas mal de temps.
Dates de sortie :
- Le 18 Octobre 2006 pour Internet Explorer 7 (soit 3ans et 3mois)
- Le 11 Juin 2009 pour Internet Explorer [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F01%2F01%2Fnouveautes-2010%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2010%2F01%2F01%2Fnouveautes-2010%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Cette année quelques choses changeront :<br />
Le support d'IE6 ne sera plus pris en compte quel que soit le projet. Internet Explorer 7 et 8 étant en place depuis déjà pas mal de temps.<br />
Dates de sortie :<br />
- Le 18 Octobre 2006 pour Internet Explorer 7 (soit 3ans et 3mois)<br />
- Le 11 Juin 2009 pour Internet Explorer 8 (soit 6mois)<br />
Il est donc temps je pense d'abandonner Internet Explorer 6 qui a eu 8ans en Octobre dernier !</p>
<p>Sur le blog faire de plus en plus d'articles techniques sur des frameworks tel que : jQuery et CodeIgniter et des tips sur CSS3...</p>
<p>Et d'autres points sur lesquels nous travaillons : le développement d'applications (pc, mac, mobile), d'interfaces et de site web, l'hébergement, l'infogérance, la téléphonie et les cours également (les cours de développement d'application Twitter, Facebook, jQuery etc...).<br />
Dans les cartons pour le début de l'année la sortie d'un Scheduler Radio !</p>
<p>N'hésitez pas a prendre contact avec nous si vous avez des questions ou besoin d'informations.<br />
Meilleurs Vœux pour l'année 2010 !</p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2010/01/01/nouveautes-2010/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>jQuery + CodeIgniter + Référencement</title>
		<link>http://www.point2zero.net/blog/2009/12/31/jquery-code-igniter-referencement/</link>
		<comments>http://www.point2zero.net/blog/2009/12/31/jquery-code-igniter-referencement/#comments</comments>
		<pubDate>Thu, 31 Dec 2009 14:29:33 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[CodeIgniter]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[xHTML]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=927</guid>
		<description><![CDATA[
			
				
			
		
Sur un site j'utilise CodeIgniter et un plug in jQuery pour la navigation (sans recharger tout le contenu).
La navigation comme ça c'est bien mais ça ne fonctionne pas partout et pour le référencement c'est pas terrible.
Donc je vais vous expliquer les différentes modifications que j'ai fait dans mon code source de base pour pouvoir référencer [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F12%2F31%2Fjquery-code-igniter-referencement%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F12%2F31%2Fjquery-code-igniter-referencement%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Sur un site j'utilise CodeIgniter et un plug in jQuery pour la navigation (sans recharger tout le contenu).</p>
<p>La navigation comme ça c'est bien mais ça ne fonctionne pas partout et pour le référencement c'est pas terrible.</p>
<p>Donc je vais vous expliquer les différentes modifications que j'ai fait dans mon code source de base pour pouvoir référencer correctement le site avec la navigation en "AJAX".</p>
<p>Dans un premier temps j'ai utiliser le Framework PHP CodeIgniter : <a href="http://www.codeigniter.com">http://www.codeigniter.com</a></p>
<p>Ensuite j'ai téléchargé la librairie jQuery : <a href="http://www.jQuery.com">http://www.jQuery.com</a> ainsi que le plugin jQuery.History disponible ici : <a href="http://www.mikage.to/jquery/jquery_history.html">http://www.mikage.to/jquery/jquery_history.html</a></p>
<p>Par défaut les adresses de Code Igniter sont du genre : /index.php/class/méthode etc... ce qui est vraiment pas optimum pour le référencement j'ai donc décidé de supprimer le "index.php/" pour cela j'utilise un fichier .htaccess avec les paramètres suivants :</p>
<pre class="brush: xml;">
RewriteEngine On
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ /index.php?/$1 [L]
</pre>
<p>Ce qui me permet d'avoir : /accueil/login à la place de : /index.php/accueil/login<br />
Ou d'avoir /accueil à la place de : /index.php/accueil</p>
<p>J'ai créer dans /application/controllers un contrôleur que j'ai nommé "page". Ce contrôleur appellera la page demandé avec un header et un footer.</p>
<pre class="brush: php;">
class Page extends Controller {

	function Page()
	{
		parent::Controller();
	}

	function index()
	{
		// Charge la page : /application/views/accueil.php
		$data['main_content'] = 'accueil';
		$this-&gt;load-&gt;view('includes/template', $data);
	}

	function contact()
	{
		// Charge la page : /application/views/contact.php
		$data['main_content'] = 'contact';
		$this-&gt;load-&gt;view('includes/template', $data);
	}

}
</pre>
<p>Ensuite dans le dossier /application/views j'ai un dossier "includes" qui contient :<br />
header.php</p>
<pre class="brush: xml;">
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;&gt;
&lt;html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;  dir=&quot;ltr&quot; lang=&quot;en&quot;&gt;
&lt;head&gt;
&lt;meta http-equiv=&quot;Content-Type&quot; content=&quot;text/html; charset=UTF-8&quot; /&gt;
&lt;title&gt;&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
</pre>
<p>template.php</p>
<pre class="brush: php;">
// Header du site
&lt;?php $this-&gt;load-&gt;view('includes/header'); ?&gt;
// Vue chargé par la variable $main_content
&lt;?php $this-&gt;load-&gt;view($main_content); ?&gt;
// Footer du site
&lt;?php $this-&gt;load-&gt;view('includes/footer'); ?&gt;
</pre>
<p>footer.php</p>
<pre class="brush: xml;">
&lt;/body&gt;
&lt;/html&gt;
</pre>
<p>Ajouter dans votre htaccess une ligne par page que vous voulez créer à noté on appel toujours "page" qui est notre contrôleur et "accueil" qui est notre méthode <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<pre class="brush: xml;">
RewriteRule ^accueil$ /index.php/page/accueil/ [L]
RewriteRule ^contact$ /index.php/page/contact/ [L]
</pre>
<p>Donc on peut créer un menu dans /application/views/includes/header.php</p>
<pre class="brush: xml;">
&lt;div id=&quot;navigation&quot;&gt;
  &lt;ul&gt;
    &lt;li&gt;&lt;a href=&quot;/accueil&quot;&gt;Accueil&lt;/a&gt;&lt;/li&gt;
    &lt;li&gt;&lt;a href=&quot;/contact&quot;&gt;Contact&lt;/a&gt;&lt;/li&gt;
  &lt;/ul&gt;
&lt;/div&gt;
</pre>
<p>Ce menu fonctionnera parfaitement avec tous les navigateurs par contre il rechargera a chaque fois tous les éléments : header.php template.php et footer.php</p>
<p>Pour ne pas recharger a chaque fois tous les éléments on peut utilise le plugin jQuery.History. Ce plug in fonctionne avec des liens avec l'attribut rel="history" et avec des ancres donc des liens avec des #page etc...</p>
<p>J'ai donc fait un petit code en jQuery qui modifie le menu précédent par le code :</p>
<pre class="brush: xml;">
&lt;div id=&quot;navigation&quot;&gt;
  &lt;ul&gt;
    &lt;li&gt;&lt;a rel=&quot;history&quot; href=&quot;#accueil&quot;&gt;Accueil&lt;/a&gt;&lt;/li&gt;
    &lt;li&gt;&lt;a rel=&quot;history&quot; href=&quot;#contact&quot;&gt;Contact&lt;/a&gt;&lt;/li&gt;
  &lt;/ul&gt;
&lt;/div&gt;
</pre>
<p>Le script jQuery qui permet de modifier le menu a la volée est le suivant :</p>
<pre class="brush: jscript;">
    $(document).ready(function() {
        /* Pour chaque element a qui se trouve dans un li dans un ul dans un element id=&quot;navigation&quot; */
        $(&quot;#navigation ul li a&quot;).each(function(){
            /* On recupere le href et on coupe le slash */
            var ancre = $(this).attr(&quot;href&quot;).split('/');
            /* On ajoute l'attribut rel avec la valeur history */
            $(this).attr(&quot;rel&quot;,&quot;history&quot;);
            /* On modifie l'attribut href par le nouveau avec le # a la place du slash */
            $(this).attr(&quot;href&quot;,&quot;#&quot; + ancre[1]);
        });
    });
</pre>
<p>Si le navigateur accepte jQuery et le Javascript alors les liens seront de la forme #lien et chargé grâce au plugin jQuery History sinon les liens seront de la forme /lien <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>A l'an prochain bon réveillon <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2009/12/31/jquery-code-igniter-referencement/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>CodeIgniter</title>
		<link>http://www.point2zero.net/blog/2009/12/20/code-igniter/</link>
		<comments>http://www.point2zero.net/blog/2009/12/20/code-igniter/#comments</comments>
		<pubDate>Sat, 19 Dec 2009 23:21:57 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[CodeIgniter]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[PHP]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=922</guid>
		<description><![CDATA[
			
				
			
		
Depuis quelques temps je me suis mis à utiliser CodeIgniter, un framework PHP.

Pour utiliser CodeIgniter vous devez avoir :
- PHP version 4.3.2 ou supérieur.
- Une base de donnée (optionnel) mais utile lors de la création d'applications ou de sites web tel que : MySQL 4.1 ou supérieur, MySQLi, MS SQL, Postgres, Oracle, SQLite, ou ODBC.
Pour [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F12%2F20%2Fcode-igniter%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F12%2F20%2Fcode-igniter%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Depuis quelques temps je me suis mis à utiliser CodeIgniter, un framework PHP.<br />
<a href="http://www.codeigniter.com/"><img src="http://www.point2zero.net/blog/wp-content/uploads/2009/12/ci_logo_flame.jpg" alt="" title="ci_logo_flame" width="150" height="164" class="aligncenter size-full wp-image-923" /></a></p>
<p>Pour utiliser CodeIgniter vous devez avoir :<br />
- PHP version 4.3.2 ou supérieur.<br />
- Une base de donnée (optionnel) mais utile lors de la création d'applications ou de sites web tel que : MySQL 4.1 ou supérieur, MySQLi, MS SQL, Postgres, Oracle, SQLite, ou ODBC.</p>
<p>Pour utiliser CodeIgniter télécharger la dernière version sur <a href="http://www.codeigniter.com/">le site officiel</a>. (Actuellement c'est la version : 1.7.2)<br />
Ensuite décompressez les fichiers et placez les dans le répertoire de votre serveur web. Puis ouvrir le fichier de configuration qui se trouve dans application/config/config.php avec un éditeur de texte pour définir l'url de base de votre site. Vous pouvez également définir votre clé de chiffrement pour vos sessions.<br />
Si vous voulez utiliser les bases de données éditer également le fichier application/config/database.php et définir les différents paramètres de connexion à votre base.</p>
<p>CodeIgniter utilise le modèle MVC "Model View Controler" et il est sous licence BSD.<br />
Je vous invite a voir les différents <a href="http://codeigniter.com/user_guide/overview/cheatsheets.html">Cheasheets</a> qui vous permettrons de vous y retrouver au début, ainsi que d'utiliser <a href="http://codeigniter.com/user_guide/index.html">la documentation</a> disponible en ligne.</p>
<p>Pour commencer également n'hésitez pas a faire un tour dans la rubrique "<a href="http://codeigniter.com/tutorials/">VideoTutorial</a>" pour voir des tutoriels (dont un qui permet la création d'un blog).</p>
<p>N'hésitez pas a ajouter des commentaires si vous avez des questions ou nous contacter via twitter <a href="http://twitter.com/point2zero" rel="nofollow" target="_blank">@point2zero</a> à bientôt !</p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2009/12/20/code-igniter/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Protéger un répertoire grâce à un htaccess</title>
		<link>http://www.point2zero.net/blog/2009/11/04/proteger-un-repertoire-grace-a-un-htaccess/</link>
		<comments>http://www.point2zero.net/blog/2009/11/04/proteger-un-repertoire-grace-a-un-htaccess/#comments</comments>
		<pubDate>Wed, 04 Nov 2009 13:39:16 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=916</guid>
		<description><![CDATA[
			
				
			
		
Aujourd'hui j'ai voulu protéger un répertoire grâce a un fichier htaccess.
Il y a des centaines de sites qui indiquent comment faire ça de façon simple "créer votre fichier .htpasswd, coller ceci, créer votre htaccess et coller ceci..."
Je créer très souvent des fichiers htaccess / htpasswd de la manière suivante (en ligne de commande) :
Pour savoir [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F11%2F04%2Fproteger-un-repertoire-grace-a-un-htaccess%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F11%2F04%2Fproteger-un-repertoire-grace-a-un-htaccess%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Aujourd'hui j'ai voulu protéger un répertoire grâce a un fichier htaccess.</p>
<p>Il y a des centaines de sites qui indiquent comment faire ça de façon simple "créer votre fichier .htpasswd, coller ceci, créer votre htaccess et coller ceci..."</p>
<p>Je créer très souvent des fichiers htaccess / htpasswd de la manière suivante (en ligne de commande) :</p>
<p>Pour savoir ou je me trouve par rapport a la racine de mon serveur j'utilise "pwd" :</p>
<pre class="brush: xml;">
$ pwd
/home/sites/www.point2zero.net/exemples
</pre>
<p>Ensuite je créer mon fichier .htaccess</p>
<pre class="brush: xml;">
$ vi .htaccess
</pre>
<p>Dedans j'ajoute (grâce à la touche i pour passer en mode insertion) :</p>
<pre class="brush: xml;">
AuthName &quot;Point2Zero&quot;
AuthType Basic
AuthUserFile &quot;/home/sites/www.point2zero.net/exemples/.htpasswd&quot;
Require valid-user
</pre>
<p>Le texte de la première ligne sera le message affiché dans ma fenêtre de login.<br />
Dans le AuthUserFile nous allons spécifier le chemin (grâce a la commande précédente pwd) et nous ajoutons à la fin un /.htpasswd qui sera le fichier avec les identifiant et mot de passe.</p>
<p>Sauvez et quitter votre fichier grâce à ":wq"</p>
<p>Maintenant créons le fichier ".htpasswd" grâce à la commande htpasswd :</p>
<pre class="brush: xml;">
$ htpasswd -bcm .htpasswd login p4ssw0rd
</pre>
<p>Détail de la commande :<br />
l'option "b" : permet d'utiliser un fichier pour sauvegarder les informations<br />
l'option "c" : permet de créer le fichier (a enlever lors du 2eme ajout si on veut ajouter plusieurs utilisateurs dans le même fichier)<br />
l'option "m" : permet d'encrypter le mot de passe en MD5<br />
ensuite on indique le fichier, le login et le mot de passe.</p>
<p>Voilà vous savez maintenant <a href="http://www.point2zero.net/exemples">sécuriser un dossier</a> grâce à deux fichier htaccess et htpasswd !</p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2009/11/04/proteger-un-repertoire-grace-a-un-htaccess/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Débuter avec Vi, Vim, Gvim</title>
		<link>http://www.point2zero.net/blog/2009/10/24/debuter-avec-vi-vim-gvim/</link>
		<comments>http://www.point2zero.net/blog/2009/10/24/debuter-avec-vi-vim-gvim/#comments</comments>
		<pubDate>Sat, 24 Oct 2009 00:14:26 +0000</pubDate>
		<dc:creator>ChoiZ</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Logiciel]]></category>

		<guid isPermaLink="false">http://www.point2zero.net/blog/?p=909</guid>
		<description><![CDATA[
			
				
			
		
Certaines personnes savent que j'utilise très souvent l'éditeur de texte Vim.
Cet éditeur très puissant (a mon goût) permet de faire tout un tas de choses, sur divers systèmes d'exploitations (Windows, Linux, Mac Os...).
Au début, l'utilisation n'est pas facile mais au fil du temps, on peut se retrouver a faire du copier coller de certains fichier [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F10%2F24%2Fdebuter-avec-vi-vim-gvim%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fwww.point2zero.net%2Fblog%2F2009%2F10%2F24%2Fdebuter-avec-vi-vim-gvim%2F&amp;source=Point2Zero+%5BBlog%5D&amp;style=normal" height="61" width="50" /><br />
			</a>
		</div>
<p>Certaines personnes savent que j'utilise très souvent l'éditeur de texte Vim.</p>
<p>Cet éditeur très puissant (a mon goût) permet de faire tout un tas de choses, sur divers systèmes d'exploitations (Windows, Linux, Mac Os...).</p>
<p>Au début, l'utilisation n'est pas facile mais au fil du temps, on peut se retrouver a faire du copier coller de certains fichier dans d'autres dans une fenêtre (en ssh par exemple).</p>
<p><a href="http://www.point2zero.net/blog/wp-content/uploads/2009/10/Capture-d’écran-2009-10-24-à-02.17.42.png"><img src="http://www.point2zero.net/blog/wp-content/uploads/2009/10/Capture-d’écran-2009-10-24-à-02.17.42-300x152.png" alt="Vi" title="Vi" width="300" height="152" class="alignleft size-medium wp-image-912" /></a><br class="clear" /></p>
<p>Facilement on peut "découper" notre fenêtre en deux par exemple l'une au dessus de l'autre avec la commande ":new"</p>
<p>Pour la "découper" dans l'autre sens pour en avoir deux l'une a côté de l'autre il suffit d'utiliser la commande ":vsplit"</p>
<p>Avec la commande ":vsplit" si un fichier est déjà ouvert il sera ouvert deux fois, tandis qu'avec la commande ":new" une fenêtre vide sera créé.</p>
<p>Pour ouvrir un fichier dans une des fenêtre vide il suffit d'utiliser ":e chemin/fichier" par exemple ":e /home/choiz/fichier.txt".</p>
<p>Pour passer d'une fenêtre a une autre utilisez "ctrl + w, w" ou "ctrl + w, une flèche" pour désigner la fenêtre du haut du bas droite ou gauche.</p>
<p>Pour fermer une fenêtre allez dans celle-ci et utiliser ":q" ou ":wq" si vous voulez sauvegarder le fichier <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>Plus d'informations sur "<a href="http://L9.fr/n4">le guide de survie VI</a>" et n'hésitez pas a télécharger et ajouter <a href="http://L9.fr/n3">mon fichier de configuration .vimrc</a> à la racine du répertoire utilisateur par exemple /home/choiz <img src='http://www.point2zero.net/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.point2zero.net/blog/2009/10/24/debuter-avec-vi-vim-gvim/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>
