Systém komentářů pomocí jQuery a Ajax.

 2012-10-27 00:00:00
 Dmitry Burobin

Dnes vytvoříme systém komentářů s automatickou kontrolou vstupních dat pomocí technologie Ajax a přidáváním nového komentáře s použitím jQuery bez znovunačtení stránky.

Série článků:
1) Systém komentářů pomocí jQuery a Ajax.
2) Lajkování neboli karma u komentářů.
3) Strankování.

Vytvoření tabulky a připojení k databázi.

Vytvoříme si tabulku comments, do které budeme ukládat: identifikátor komentáře ( id ), identifikátor rodičovského komentáře ( parent_id ), jméno ( name ), text komentáře ( text ) a datum přidání komentáře ( date ).

CREATE TABLE `comments` (
`id` INT ( 5 ) NOT NULL AUTO_INCREMENT,
`parent_id` INT ( 5 ) NOT NULL,
`name` VARCHAR ( 255 ) NOT NULL,
`komentar` TEXT,
`date` DATETIME,
PRIMARY KEY(`id`)
)ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci

Taktéž si vytvořte soubor db.php, pro připojení k databázi.
<?php
$DBSERVER 'localhost'//server, který bude použít pro navázáníspojení s DB 
$DBUSER 'root'//Váš mysql login, nejspíš je stejný jako u mě pro localhost, tudiž root 
$DBPASS '****'//heslo, které jste zadaval při instalaci MySQL 

$DB 'test'//databáze, s kterou budeme pracovat 

//navazení spojení pomoci mysql_connect  
$link mysql_connect($DBSERVER$DBUSER$DBPASS)  or die("Could not connect: " mysql_error()); 
//vybírame databázi 
mysql_select_db($DB$link) or die ('Can\'t use test : ' mysql_error()); 
//řekněme MySQL, že všechná data jsou ve formatu UTF-8 
mysql_query("SET NAMES UTF8");
?>

index.php

Hlavní stránka bude obsahovat formulář pro přidávání komentářů s polem pro jméno, zprávu a skryté pole, do kterého budeme ukálát identifikátor rodičovského komentáře, pokud někdo bude odpovídat na nějaký komenář. Soubor index.php vypadá takto:

<?php
/*Soubor pro vybírání komentářů z databáze*/
require_once 'comment.php';
?>
<!DOCTYPE html>
<
html xmlns="http://www.w3.org/1999/xhtml" xml:lang="cs" lang="cs">

<
head>
    <
title>Systém komentářů.</title>
    <
meta charset="utf-8" >
    
    <
link rel="stylesheet" href="style.css"> <!-- soubor se styly -->
    <
script src="jquery-1.7.1.min.js"></script> <!-- připojení jquery -->
    <script src="comment.js"></script> <!-- funkce potřebné pro přidávání komentářů -->
    
</head>
<body>
<ul id="commentWrapper">
<?php
/*Zde v proměnné $comments jsou komentáře*/
echo $comments;
?>
<!-- formulář pro přidávání komentářů -->
</
ul>    
    <
div id="commentBox">
        <
input class="validate" type="text" name="name" >
        <
input id="parent" type="hidden" name="parent_id" value="">
        <
div class="commentText">
            <
textarea name="text"></textarea>
        </
div>
        <
button>Přidat</button><img class="loader" src="loader.gif">
    </
div>
</
body>
</
html>

Styly a knihovna jQuery

Pro správné fungování potřebujeme připojit knihovnu jQuery. Tu buď stáhnete z oficiálního webu nebo z archivu s tímto článkem. Pak, aby komentáře líp vypadali přidáme styly, nic složitého v nich není, proto je nebudu popisovat:

body
{
    
margin:0;
    
padding:0;
}
ulli
{
    list-
style-type:none;
}
.
loader
{
    
display:none;
}
#commentBox
{
    
width:400px;
    
padding:10px;
}
#commentBox input
{
    
width:250px;
    
height:25px;
    
padding0 5px;
    
margin:5px;
    
bordersolid 1px #ccc;
    
background:#f1f1f1 url(bg_input.png) no-repeat;
    
font400 12pt/14pt Ume Gothic O5;
}
#commentBox textarea
{
    
width:250px;
    
height:100px;
    
margin5px;
    
padding5px;
    
bordersolid 1px #ccc;
    
background:#f1f1f1 url(bg_koment.png) no-repeat;
    
font400 12pt/14pt Ume Gothic O5;
}
#commentBox button
{
    
height:30px;
    
width:85px;
    
margin-left183px;
    
margin-top:0px;
    
font:700 12pt/14pt Ume Gothic O5;
}
#commentWrap
{
    
width:350px;
    
padding:10px;
    
padding-bottom:3px;
    
margin:10px;
    
border1px solid #ccc;
    
border-radius:10px;
    
background:#f7f7f7;
}
#commentWrap .komentar
{
    
padding:5px;
    
padding-left:0px;
    
border-top:1px solid #ccc;
    
margin-bottom:10px;
    
font:400 12pt/14pt Times New Roman;
}
#commentWrap .replay
{
    
margin-left:270px;
    
font:700 10pt/12pt Ume Gothic O5;
}
#commentWrap a
{
    
text-decoration:none;
}
#commentWrap .commentName
{
    
font:700 10pt/12pt Ume Gothic O5;
}
#commentWrap .commentDate
{
    
font:400 11pt/13pt Times New Roman;
}
.
repName
{
    
font:400 12pt/14pt Times New Roman;
    
font-style:italic;
}
.
repText
{
    
font:700 10pt/12pt Ume Gothic O5;
}
.
repDate
{
    
font:400 9pt/11pt Times New Roman;
    
font-style:italic;
}

comment.php

Tento soubor je určen pro vybírání dat z databáze a vkládání těchto dat do šablony.

<?php
// Vložíme soubor s připojením k databázi. ( musí se nacházet ve stejné složce ) 
require_once 'db.php';

// Vybereme komentáře z databáze
$query mysql_query("
         SELECT `id`,`parent_id`,`name`,`komentar`, 
         DATE_FORMAT(date, '%d %M %Y %H:%i') as date_add
         FROM `comments` ORDER BY `id` ASC 
         "
);
         
// Pokud při vykonání příkazu nastané chyba vypišeme ji
if(!$query) { echo mysql_error() . " - " mysql_errno(); }
else {

// Jinak pomocí cyklusu projdeme všechny záznamy v tabulce
        
while($result mysql_fetch_assoc($query))
        {
            
// a uložíme je do pole $data  
            
$data[$result['id']] = $result;
        }

// Funkce pro vkládání dat ( komentářů ) do šablony
function commentsToTemplate($comment)
{
// $comment - pole komentáře - id, parent_id, name, text, date 
    
// Zapneme bufferování výstupu, aby šablona nebyla zobrazená v místě volání funkce
    
ob_start();  
      
// Připojíme šablonu comment_template.php, do které vložíme data z pole $comment
    
require_once 'comment_template.php';                     
  
// Získáváme obsah bufferu jako řetězec   
    
$comments_string =  ob_get_contents(); 

// Vymažeme všechno z bufferu
    
ob_end_clean();

// Vrácíme komentář jako řetězec   
    
return $comments_string;    
}

// Funkce pro zpracování pole $data, které
// bude rozděleno do jednotlivých komentářů a odesláno funkci 
// commentsToTemplate
function commentsString($data)
{
    foreach(
$data as $w
    {
        
$string .= commentsToTemplate($w);
    }
 
return 
$string
}  

// proměnná $comments obsahuje naše komentáře, které zobrazujeme na hlavní stránce
$comments commentsString($data);

// vynulujeme proměnnou $data 
$data null;
}
?>

comment_template.php

Toto je vlastně šablona jednotlivého komentáře.

<?php
// Do této šablony se načítají data z pole $data, která jsou odesláná funkci commentsToTemplate
echo '<li id="comment'.$comment['id'].'">
    <div id="commentWrap">'
;
        
// Pokud existuje parent_id, pak zobrazíme, že se jedna o odpověď
        
if($comment['parent_id']!=0)
        {
// Vybereme z DB jméno a datum rodičovského komentáře
            
$q mysql_query("SELECT `name`, DATE_FORMAT(date, '%d %M %Y %H:%i') as date_add FROM `comments_my` WHERE `id`='".$comment['parent_id']."'");
            
$r mysql_fetch_assoc($q);
            echo 
'<span class="repText">Odpověď na komentář</span> <span class="repName">
            '
.$r['name'].'
            </span> <span class="repText">from</span> <span class="repDate">
            '
.$r['date_add'].'
            </span><br>'
;
        }
        
// Zobrazíme jméno a datum přidání
echo    '<span class="commentName">'.$comment['name'].'</span> - <span class="commentDate">'.$comment['date_add'].'</span>
        <div class="komentar">
<!--Zobrazíme text komentáře-->
            '
.$comment['komentar'].'
        </div>
<!--Pokud zmačkneme na tento odkaz, pak se do skrýteho pole s názvem parent_id přidá
identifikátor tohoto komentáře. 
Použil jsem zde JS událost onClick, tzn. pokud je tlačítko zmačknuté, pak najdi prvek s 
id parent ( což je skrýte pole parent_id ) a do hodnoty přidej id komentáře, na který chcete odpovědět-->
        <a class="replay" href="javascript:;"
        onClick="document.getElementById(\'parent\').value='
.$comment['id'].';">Odpovědět</a>
    </div>
</li>'
;
?>

comment.js

Tento soubor je určen pro odesílaní dat na server a přidávání do databáze

$(document).ready(function(){
    
// Objekt commentBox bude obsahovat data pro odesílání na server
    
var commentBox = {};
    
// Po kliknutí na tlačítko přidat      
     
$('#commentBox button').live('click',function(){
         
// Do objektu commentBox bude přidána hodnota skrýteho pole input s názvem parent_id,
// které obsahuje id rodičovského komentáře a pokud je prázdné tak bude 0, což znamená, že
// se jedná o nový komentář bez reakci na něj ( toto se bude ověřovat až odešleme data na server ).   
        
commentBox.parent_id = $('#commentBox').find("input[name='parent_id']").val();
        
// Taktéž přidáme do objektu commentBox hodnotu pole name a zprávu
        
commentBox.name = $('#commentBox').find("input[name='name']").val();        
        
commentBox.text = $('#commentBox').find("textarea").val();
// Abyste to lépe pochopili syntaxe toho, jak přidáváme hodnoty do objektu je:
// Objekt.název_proměnné = hledáme input nebo textarea.hodnota pole

// Funkce pro odesílání dat na server        
        
sendData();
     });
    

function 
sendData()
{
// Najdeme tlačítko schováme jej a zobrazíme loader ( ten si můžete stáhnout z archivu )
    
$('#commentBox').find('button').hide().next().show();

// Odešleme    data metodou post na server
    
$.post(
// Soubor, ve kterém se provádí ověřování dat a přidávání komentářů     
        
"addkoment.php",
// Objekt s proměnnými (parent_id, name a text)
        
commentBox,
        function(
data){
// Pokud jsou nějaka data, to znamená, že nastala chyba
            
if(data)
            {
// Převedeme tento řetězec JSON do objektu JS
                
data = $.parseJSON(data);
                
// Vytvoříme proměnnou errors, která bude obsahovat název chyby
                
var errors '';

// Použijeme cyklus pro zobrazení všech chyb najednou.
// Použil jsem tuto konstrukci, protože nejprvé jsem zobrazoval všechny chyby, ale
// nakonec jsem to změnil a teď se bude zobrazovat jenom jedna konkretní chyba     
// Kdybyste chtěli zobrazit všechny chyby tak použijte konstrukci
// errors += val+'\n'; - každá chyba se zobrazí na samostatném řádku.
// i - obsahuje název chybného pole a val - popis chyby
            
                
$.each(data, function(ival)
                {
                    
errors += i;
                });

// Uložil jsem do proměnné errors jenom název chybného pole a
// cyklusem switch procházim všechny varianty a přidávam červený rámeček 
// pokud pole je prázdné nebo jestli komentář nebyl přidan tak zobrazim hlášení                    
                   
switch (errors
                   {
                      case 
'name':
                        $(
'#commentBox').find("input[name='name']").css('border','2px solid red');
                        break
                      case 
'text':
                        $(
'#commentBox').find("textarea").css('border','2px solid red');
                        break
                      case 
'not_add':
                        
alert('Komentář nebyl přidan.')
                        break
                      default:
                        
alert('Něco je špatně')
                  }

// Najdeme loader ( ten si můžete stáhnout z archivu ) schováme jej a zobrazíme tlačítko přidat     
                
$('#commentBox').find('button').show().next().hide();

// Jinak, pokud žadná chyba nenastala, tak voláme funkci addComment, která zobrazí
// komentář bez znovunačtení stránky a vynuluje hodnoty vstupních poli
            
} else {
                
addComment();        
            }
        }
    
    )

}


function 
addComment()
{
// Na konec prvků s id commentWrapper ( což je ul ) přidame tag <li></li>,
// ve kterém se bude nacházet nový komentář
    
$("#commentWrapper").append('<li></li>');

// Najdeme poslední tag <li>, který jsme teď vytvořili a
// načteme do něj poslední komentář
    
$("#commentWrapper li:last").load('new_comment.php');
// Najdeme loader ( ten si můžete stáhnout z archivu ) schováme jej a zobrazíme tlačítko přidat     
    
$('#commentBox').find('button').show().next().hide();

// Vynulujeme hodnoty vstupních poli
    
$('#commentBox input').val('');
    $(
'#commentBox textarea').val('');

}


});

addkoment.php

Tento skript zpracovává data poslána na server pro zpracování.

<?php
// Ověříme, zda se jedna o odeslána POST data nebo si člověk jen tak otevřel tuto stránku
if($_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest') {

// Pokud ano, pomocí funkci sleep přidame efekt zpoždění, abyste 
// viděl loader, jinak, protože pracujeme na lokálním serveru
// se ten loader hned schová  
     
sleep(2);

// Ověříme vstupní data     
// Pokud je pole name nebo textové pole prázdné do pole $error uložíme text chyby
// ukončíme skript a odešleme tuto chybu v JSON formátu  
     
if(!isset($_POST['name']) OR empty($_POST['name']))
     {
        
$error['name'] = "Zadejte jméno.";
        exit(
json_encode($error));
     } else {
        
$name htmlspecialchars(stripslashes(trim($_POST['name'])));
     }
     
     if(!isset(
$_POST['text']) OR empty($_POST['text']))
     {
        
$error['text'] = "Zadejte zprávu.";
        exit(
json_encode($error));
     } else {
        
$text stripslashes(htmlspecialchars(trim($_POST['text'])));
     }
     
// V tomto případě, když parent_id je prázdné pole tak mu přiřadime hodnotu 0
// to znamená, že se jedná o nový komentář, který není odpovědí na něčí jiný  
     
if(!isset($_POST['parent_id']) OR empty($_POST['parent_id']))
     {
        
$parent_id 0;
     } else {
        
$parent_id stripslashes(htmlspecialchars(trim($_POST['parent_id'])));
     }
     
// Vložíme soubor s připojením k databázi. ( musí se nacházet ve stejné složce )  
     
require_once 'db.php';
     
// Přidame komentář do databáze a vrátíme false, tzn.
// že chyba nenastala a komentář byl přidán.
     
$q mysql_query("
     INSERT INTO `comments`(`parent_id`,`name`,`komentar`,`date`)
     VALUES('"
.$parent_id."','".$name."','".$text."', NOW())
     "
);
     if(!
$q) { $error['not_add'] = "Komentář nebyl přidan."; exit(json_encode($error));}
     else { exit(
false); }

}
?>

new_comment.php

V tomto souboru vybírame poslední komentář, abysme ho následně zobrazili po úspěšnem ověření vstupních dat.

<?php
// Vložíme soubor s připojením k databázi. ( musí se nacházet ve stejné složce ) 
require_once 'db.php';
// Vybereme maximální ( poslední přidáný ) id
$max mysql_query("SELECT MAX(`id`) FROM `comments_my`");
// Pak vybereme všechny související údaje s tímto identifikátorem
$query mysql_query("
         SELECT `parent_id`,`name`,`komentar`, 
         DATE_FORMAT(date, '%d %M %Y %H:%i') as date_add
         FROM `comments_my` WHERE `id` = '"
.mysql_result($max,0)."'
         "
);
$comment mysql_fetch_assoc($query);

// A stejně, jak jsme zobrazovali komentáře před tím, zobrazíme poslední přidáný
echo '<li id="comment'.mysql_result($max,0).'">
    <div id="commentWrap">'
;
        
        if(
$comment['parent_id']!=0)
        {
            
$q mysql_query("SELECT `name`, DATE_FORMAT(date, '%d %M %Y %H:%i') as date_add FROM `comments_my` WHERE `id`='".$comment['parent_id']."'");
            
$r mysql_fetch_assoc($q);
            echo 
'<span class="repText">Odpověď na komentář</span> <span class="repName">
            '
.$r['name'].'
            </span> <span class="repText">from</span> <span class="repDate">
            '
.$r['date_add'].'
            </span><br>'
;
        }
        
echo    
'<span class="commentName">'.$comment['name'].'</span> - <span class="commentDate">'.$comment['date_add'].'</span>
        <div class="komentar">
            '
.$comment['komentar'].'
        </div>
        <a class="replay" href="javascript:;"
        onClick="document.getElementById(\'parent\').value='
.mysql_result($max,0).';">Odpovědět</a>
    </div>
</li>'
;
?>

Závěr

Probrali jsme, jak můžeme zpracovávát formuláře bez znovunačtení stránky. Doufám, že se Vám tento článek líbil a byl pro Vás přínosný.

Systém Orphus
Napište komentář.
Celkem komenrářů(10303)
Almazgrjaigo - 2017-07-12  07:58:38
 Мы занимаемся возведением малоэтажных домов, бань, промышленных объектов, в том числе и из быстровозводимых конструкций, прокладкой инженерных коммуникаций, а также работаем на сложных грунтах.

[url=http://almazgrupp.ru/][img]http://almazgrupp.ru/images/cbg.jpg[/img][/url]
http://almazgrupp.ru/otoplenie-doma/tag/otoplenie-zagorodnogo-doma.html
http://almazgrupp.ru/component/k2/tag/demontazh-zdanij.html

[url=http://almazgrupp.ru/elektrikca/elektromontazh-v-kottedzhe/tag/elektromontazh-v-kottedzhe.html]демонтаж домов[/url]
[url=http://almazgrupp.ru/otoplenie/tag/montazh-sistem-otopleniya.html]алмазная резка монолита -цена[/url]

демонтаж москва
квартира дизайн
демонтаж перегородок
Yaroslavleath - 2017-07-12  06:55:51
 [url=https://volvopremium.ru/]Обслуживание и ремонт легковых автомобилей Volvo,сервис volvo , автосервис Вольво , 
 volvo сервис, сервис вольво москва,  сервис Вольво в Москве ,вольво сервис москва,ремонт вольво москва,техцентр вольво,
автосервис volvo , Автосервис Volvo в Москве, обслуживание Вольво, ремонт Volvo, автосервис Volvo Вольво,сервис Volvo ,
специализированный сервис Вольво , сервис Вольво в Москве,техническое обслуживание автомобилей Вольво,
АВТОСЕРВИС ВОЛЬВО – АВТОСЕРВИС VOLVO В МОСКВЕ И МОСКОВСКОЙ ОБЛАСТИ,ремонт Вольво в Москве,
автосервис Volvo, автосервис Вольво, сервис Вольво,Volvo сервис[/url]

[url=https://volvopremium.ru/uslugi-stranitsa/tehnicheskoe-obsluzhivanie-volvo/] то вольво,  то volvo,  то автомобилей Вольво, 
то автомобилей Volvo, Техническое обслуживание Volvo,Вольво техническое обслуживание Volvo,Вольво регулярный сервис ,
Услуги по техническому обслуживанию Вольво,обслуживание volvo, 
техническое обслуживание Volvo,техническое обслуживание вольво,Обслуживание и ремонт легковых автомобилей Volvo  [/url]

[url=https://volvopremium.ru/to_volvo] то вольво,  то volvo,  то автомобилей Вольво,  то автомобилей Volvo,
Техническое обслуживание Volvo,обслуживание вашего Volvo,обслуживание вашего Вольво,обслуживания автомобилей Вольво,
стоимость то вольво,стоимость то xc 60 xc 90 и других моделей Вольво,стоимость работ по вашему автомобилю Volvo,
стоимость ТО Volvo,стоимость ТО Volvo,Обслуживание и ремонтлегковых автомобилей Volvo[/url]

[url=https://volvopremium.ru/zamena-remnya-grm/]Замена ремня ГРМ Вольво Volvo xc90 xc60 xc70 s60 s80 s40,
замена ремня ГРМ Вольво S40, замена ремня ГРМ Вольво S60, замена ремня ГРМ Вольво s80, замена ремня ГРМ Вольво xc60,
замена ремня ГРМ Вольво xc70 и замена ремня ГРМ Вольво xc90, ремня ГРМ на Вольво ,замену ремня ГРМ Вольво ,
замену ремней ГРМ на легковых автомобилях Вольво[/url]

[url=https://volvopremium.ru/zamena-masla-akpp-volvo-volvo/]Замена масла акпп Вольво (Volvo), замени масло в коробке со скидкой,
Замена масла акпп Вольво (Volvo),Вольво (Volvo) замена масла в АКПП,Замена масла в акпп Вольво,
масло в коробку вольво,  замена масла акпп вольво,  замена масла в акпп вольво,  замена масла в акпп volvo, 
замена масла акпп volvo[/url]

[url=https://volvopremium.ru/volvo-volvo-zamena-masla-v-akpp-so-skidkoj-25/]Замена масла акпп Вольво (Volvo),
замени масло в коробке со скидкой,Замена масла акпп Вольво (Volvo),Вольво (Volvo) замена масла в АКПП,
Замена масла в акпп Вольво, масло в коробку вольво,  замена масла акпп вольво,  замена масла в акпп вольво,
замена масла в акпп volvo,  замена масла акпп volvo[/url]
Lcelkosoft - 2017-07-12  06:55:14
 [url=https://kinoi.tv]фильмы[/url]
DonnaGuavy - 2017-07-12  05:42:49
 Yesterday i got some shocking info about Omega 3 stuff and seems like it very matters now. I've got this [url=http://pin.it/yQYr63I] pinterest [/url] picture and it seems like this guy sells this with discount but i have no idea where is link?
VladimWanna - 2017-07-12  03:11:35
 Подключение электричества к частным домам и крупным объектам в Москве.

В процессе строительно-монтажных работ при возведении частного дома, жилого микрорайона или производственного комплекса важнейшим этапом является подключение объекта к системе электроснабжения.

Компания «Центр Энергетических Решений и Инноваций» профессионально и надежно производит присоединение к электросетям под ключ зданий и сооружений, например [url=http://center-energo.com/services/elektrotehnicheskaya_laboratoriya]электротехническая лаборатория[/url] включая разработку техусловий, проектирование электрики и проведение электромонтажных работ в кратчайшие сроки.

Процесс подключения домов, крупных промышленных предприятий, а также торговых комплексов к системам энергоснабжения включает в себя множество аспектов, в число которых обычно входят:

Разработка технического задания;
Получение ТУ;
Проект электроснабжения;
Установка ТП, опор освещения в соответствии с утвержденной схемой;
Подключение и диагностика введенного в эксплуатацию электрооборудования.
Технологическое присоединение к электрическим сетям.

Важно доверить выполнение комплекса работ по подключению объекта к системе электроснабжения исключительно надежной и авторитетной компании.
Aalladhew - 2017-07-12  03:07:47
 Buying Letter Printing Hoodie Dress SKU321728, 25.95$.
[url=https://ad.admitad.com/g/6udlqrq8ze850fad1b82fa046e475d/?i=5&ulp=https%3A%2F%2Fwww.yoins.com%2FLetter-Printing-Hoodie-Dress-p-1014307.html][img]https://images.yoins.com/thumb/source/oaupload/yoins/images/07/6A/a7b46d91-52f7-4674-a4e7-9d9e97690961.jpg[/img][/url]
[url=https://ad.admitad.com/g/6udlqrq8ze850fad1b82fa046e475d/?i=5&ulp=https%3A%2F%2Fwww.yoins.com%2FLetter-Printing-Hoodie-Dress-p-1014307.html][img]https://goo.gl/4sHxpb[/img][/url]



Letter Printing Hoodie Dress cost - 25.95$.
Here's to the nights with friends you'll cherish forever. This dress is designed with drawstring neck, long sleeves, letter printing, zip front fastening and side pockets. We love wearing it with skinny leggings and black strappy heels.

If you like this product (Letter Printing Hoodie Dress) [url=https://ad.admitad.com/g/6udlqrq8ze850fad1b82fa046e475d/?i=5&ulp=https%3A%2F%2Fwww.yoins.com%2FLetter-Printing-Hoodie-Dress-p-1014307.html]>>>>[b]ENTER HERE[/b]
AnettaIsole - 2017-07-12  02:08:37
 [url=http://rxlist.pw/priligy]Buy priligy[/url]
Doxazosin should be used during pregnancy only if the potential benefit justifies the potential risk to the fetus. For women who are nursing: Doxazosin passes through breast milk. This can lead to dizziness and lightheadedness. Buy betapace

http://rxlist.pw/rythmol http://rxlist.pw/depakote
Andrujvk - 2017-07-12  02:04:07
 [url=http://bit.ly/2qY5Ubq]Я получил бесплатно $100 для обучения торговле в компании ExpertOtpion![/url]

Постоянный доход [url=http://bit.ly/2rI0Jcu]в компании ExpertOtpion[/url]

[url=http://bit.ly/2rME9ja]самый лучший способ заработать деньги[/url]
[url=http://bit.ly/2s25M86]Интернет торговля[/url]
[url=http://bit.ly/2s22qBR]самый лучший способ заработать деньги[/url]
[url=http://bit.ly/2r9X32o]Интернет торговля[/url]
[url=http://bit.ly/2sTc7mg]Умножьте свои деньги![/url]
Ulovsa - 2017-07-12  01:42:54
 подтверждаю

---

мира 2016 [url=http://agroenred.com/index.php?option=com_k2&view=itemlist&task=user&id=344395
http://www.in-auto.it/index.php?option=com_k2&view=itemlist&task=user&id=121748
http://50-87-24-51.unifiedlayer.com/index.php?option=com_k2&view=itemlist&task=user&id=960245566
http://albarkka.com/index.php?option=com_k2&view=itemlist&task=user&id=56248
http://www.fantiniarte.it/index.php?option=com_k2&view=itemlist&task=user&id=174495
]здесь[/url]
KristaSoilk - 2017-07-12  01:27:53
 Hello friends
I am sorry if I create off-topic
But I recently had to locate a detailed post about the right way to create essays for that university.
I just found a superb post. Possibly somebody else will need to have this facts.
http://usaessayslouis.alltdesign.com/essay-writing-personally-creating-and-online-essay-writing-services-4455886

In addition, even though I was trying to find this short article, I discovered that most people decide to purchase household works, compositions, papers and essays. I don't understand how safe it really is and what quality is usually obtained within the finish. Who faced this problem, create, you create or purchase? Have been you caught by the helper for this?
Ulovsa - 2017-07-11  23:29:08
 Увольте меня от этого.

---

мир z [url=http://samples.artfantasy.gr/index.php?option=com_k2&view=itemlist&task=user&id=6131
http://rivkakolton.co.il/index.php?option=com_k2&view=itemlist&task=user&id=208449
http://mehmo.ru/index.php?option=com_k2&view=itemlist&task=user&id=167929
http://www.inpatmos.gr/index.php?option=com_k2&view=itemlist&task=user&id=218915
http://mbi.tomsk.ru/index.php?option=com_k2&view=itemlist&task=user&id=11579
]тут[/url]
Robertlix - 2017-07-11  22:15:15
 Hi! [url=http://levitraonline.top/]buy levitra online without prescription[/url] excellent web page.
BrentVah - 2017-07-11  21:40:51
 Apex Vitality Garcinia Cambogia Scam or Fake?: http://califo
iabrides.net/ :
You can find interesting answer here:
http://1apexgarciniacambogiaplus.com/richmond-vitality-garcinia-cambogia-buy-4.htm [b] richmond vitality garcinia cambogia buy [/b]
[url=http://1apexgarciniacambogiaplus.com/elizabeth-apex-vitality-garcinia-cambogia-plus-buy-1.htm] elizabeth apex vitality garcinia cambogia plus buy [/url]
http://1apexgarciniacambogiaplus.com/apex-vitality-garcinia-cambogia-plus-oceanside.htm
http://1apexgarciniacambogiaplus.com/apex-vitality-garcinia-cambogia-buy-seattle.htm [b] apex vitality garcinia cambogia buy seattle [/b]
[url=http://1apexgarciniacambogiaplus.com/arlington-apex-vitality-garcinia-cambogia-plus.htm] arlington apex vitality garcinia cambogia plus [/url]
http://1apexgarciniacambogiaplus.com/garcinia-cambogia-plus-buy-san-diego-1.htm
http://1apexgarciniacambogiaplus.com/new-haven-garcinia-cambogia-plus-buy.htm
[url=http://1apexgarciniacambogiaplus.com/garcinia-cambogia-oklahoma.htm] garcinia cambogia oklahoma [/url]
AniTNe5 - 2017-07-11  21:36:51
 Я знаю, очень у многих людей есть близкие,
друзья у которых есть проблемы с алкогольной
или наркотической зависимостью.
Центр реабилитации наркозависимых
Рефреш (Refresh) в Киеве поможет вам

[url=http://narco.net.ua]Лечение наркозависимости-Центр реабилитации Рефреш[/url]
Ulovsa - 2017-07-11  20:46:32
 Отличная мысль

---

таблица мира [url=http://www.saralelakarat.com/index.php?option=com_k2&view=itemlist&task=user&id=79853
http://horizontalvias.com.br/index.php?option=com_k2&view=itemlist&task=user&id=270011
http://security-ua.com/index.php?option=com_k2&view=itemlist&task=user&id=235730
http://coolinarka.nichost.ru/index.php?option=com_k2&view=itemlist&task=user&id=1371
http://www.imerisia-ver.gr/component/k2/itemlist/user/288945
]тут[/url]
Dol88larGib - 2017-07-11  18:49:15
 В наше время только лишь бездеятельный не зашибает в онлайне! ©
Каким способом перестать быть тем «ленивцем», что еще не зарабатывает прибыль от глобальной сети интернет? Ответ на текущий вопрос можно увидеть на все тех же горизонтах онлайна. Всетаки, первостепенной темой является вопрос не «Как заколотить бабла?», а вопрос «Какой именно тип извлечения доходов нам всем больше всего подходит?». Среди множества способов заработка в сети особенно занимательными для нас будут те, что не требуют инвестиций денег и титанических усилий для организации бизнес процесса. Таким видом заработка является использование партнерских и реферальных программ инвестиционных и брокерских контор. Доходность от торговли на финансовых рынках имеет возможность оказаться довольно высокой, что заставляет людей массами бежать к агентам и заводить к ним финансы. А с этих денег партнер имеет возможность получить внушительную сумму в качестве партнерских отчислений. Став партером и разместив ссылочку на своем вэб-ресурсе или на всевозможных форумах (для простого пользователя интернета) сегодня можно иметь постоянный доход без вложения денежных средств и усилий. Как это все работает?

Возьмём для примера команду ExpertOption – брокера бинарных опционов.

[url=http://bit.ly/2tRqLgJ#7aeY1KGc49]Ссылка на брокера[/url]

[url=http://bit.ly/2uPwBMI#YNK7PpgKDt]Ссылка на партнёрку[/url]

(помимо этого есть достаточно лендингов, очень высокая конверсия и минимум полей для заполнения при регистрации на сервисе)

Компания предоставляет лучший сервис для клиентов среди себе подобных, чем реально и знаменита. Более того, у них имеется множество прочих фишек и эффективных инструментов для клиента, помогающих ему иметь заработок. Компании есть чем привлечь клиента. Но на этом внимание заострять не станем, потому как компания нам интересна в первую очередь благодаря их партнерской программе. Их партнерская программа даёт возможность получать до 60% от доходности брокера непрерывно с каждого клиента до тех пор, пока он осуществляет торговлю через компанию. Организовав приток новых клиентов можно без усилий собирать плоды.

Как отыскивать клиентов? Этот вопрос больше актуален для обычных людей, не иметь в распоряжении своих online-проектов или разрекламированных блогов. Сегодня можно начать с простого:
1. Вогнать в поисковике запрос «форекс форум»;
2. Зарегистрироваться на 5-10 интернет-форумах (для старта);
3. Подобрать любой холивар про форекс и сделать пост для привлечения заинтересованности, например, «Ваш покорный слуга получил бесплатно $400 для обучения торговле в компании ExpertOtpion!», и вставить собственную партнерскую ссылку.
И всё. Людям станет любопытно, пройдут по ссылке, и некоторые станут клиентами. Естественно, просто разместить один пост мало, надобно еще и создавать активность, участвуя в обсуждении и разогревая внимание к компании. В каждом из обсуждения нужно в процессе аргументирования своего мнения вставлять гиперссылки. Потратив немного усилий, тема заживет своей жизнью и уже другие люди будут цитировать партнерскую ссылку, распространяя ее за вас. Рентабельность от такой деятельности говорит сама за себя:
[url=http://bit.ly/2uPwBMI#aAkTMSfTQ6]
[img]http://bit.ly/2uPrbkT#b0A8P64qWK[/img]
[/url]
Партнёрская программа имеет разный комплект инструментов для размещения ссылок:
• Промо линки;
• Баннеры для вебмастеров;
• Лендинги;
и др.
Кроме того для вебмастеров бесплатно предоставляются уникальный контент для размещения на личных порталах: релизы, тексты, тактики и стратегии, консультации и прочдругоеее. Все это значительно оптимизирует работу и снижает прилагаемые усилия для извлечения дохода. А извлеченный доход возможно вывести любым методом на выбор:
• Webmoney (USD ONLY) ;
• ecoin.cc;
• QIWI;
• Neteller;
• PayWeb;
• PerfectMoney;
• Epese;

Достаточно бесхитростный способ делать деньги, не так ли? Партнерство с ExpertOption даёт возможность несколько раз в месяц получать «небольшой» доход в худо-бедно несколько сотен $.

Если же потратить больше усилий или же если вы веб-мастер, то суммы прибыли уже будут иметь более высокий порядок.

Широкий набор инструментов отчетности позволит вам отслеживать источники получения прибыли и результативно управлять размещением ссылок.
Международная компания ExpertOption имеет довольно большую известность по всему миру, большинство клиентов после ведении торговли на демо открывают реальный финансовый счет и, как минимум, половина из них делает повторный вклад. Благодаря этому, партнерские 50-60% от дохода компании представляют собой большую сумму денег даже для вебмастеров. Все что надо сделать, чтобы стать партнером, это пройти регистрацию в программе в один клик, разместить гипертекстовую ссылку и получать доход. Все вопросы и трудности помогут решить специалисты службы поддержки.
Vovabow - 2017-07-11  18:41:26
 [url=https://exposhoes.com.ua/]Обувь оптом[/url]
[url=https://exposhoes.com.ua/obuv-optom-ot-proizvoditelya]Обувь от производителя[/url]
[url=https://exposhoes.com.ua/sumki-optom-ot-proizvoditelya]Сумки оптом[/url]
[url=https://exposhoes.com.ua/completing-for-footwear]Комплектующие[/url]
[url=https://exposhoes.com.ua/news]Новости[/url]
[url=https://exposhoes.com.ua/akcija-na-obuv-stella-navstrechu-zhelanijam-djinsa-kozha-vyshivka-665]Акция на обувь![/url]
Ulovsa - 2017-07-11  18:32:24
 Раз можна подзибать

---

кинотеатр мир [url=http://www.iag.ir/index.php?option=com_k2&view=itemlist&task=user&id=153812
http://www.slon-tour.ru/index.php?option=com_k2&view=itemlist&task=user&id=378846
http://pechnik-nsk.ru/index.php?option=com_k2&view=itemlist&task=user&id=163756
http://coolinarka.nichost.ru/index.php?option=com_k2&view=itemlist&task=user&id=1370
http://www.icell-tech.com/index.php?option=com_k2&view=itemlist&task=user&id=142133
]тут[/url]
NewmcGof - 2017-07-11  16:30:33
 thumbs up[url=http://defense-arab.com/vb/threads/107124/page-2].[/url]
CharlesGox - 2017-07-11  14:46:37
 And where is the button "thanks"?
I would like to thank a user for a decent recommendation.
---
[url=http://google.com/]Mysearchengine[/url]
<<[1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29] [30] [31] [32] [33] [34] [35] [36] [37] [38] [39] [40] [41] [42] [43] [44] [45] [46] [47] [48] [49] [50] [51] [52] [53] [54] [55] [56] [57] [58] [59] [60] [61] [62] [63] [64] [65] [66] [67] [68] [69] [70] [71] [72] [73] [74] [75] [76] [77] [78] [79] [80] [81] [82] [83] [84] [85] [86] [87] [88] [89] [90] [91] [92] [93] [94] [95] [96] [97] [98] [99] [100] [101] [102] [103] [104] [105] [106] [107] [108] [109] [110] [111] [112] [113] [114] [115] [116] [117] [118] [119] [120] [121] [122] [123] [124] [125] [126] [127] [128] [129] [130] [131] [132] [133] [134] [135] [136] [137] [138] [139] [140] [141] [142] [143] [144] [145] [146] [147] [148] [149] [150] [151] [152] [153] [154] [155] [156] [157] [158] [159] [160] [161] [162] [163] [164] [165] [166] [167] [168] [169] [170] [171] [172] [173] [174] [175] [176] [177] [178] [179] [180] [181] [182] [183] [184] [185] [186] [187] [188] [189] [190] [191] [192] [193] [194] [195] [196] [197] [198] [199] [200] [201] [202] [203] [204] [205] [206] [207] [208] [209] [210] [211] [212] [213] [214] [215] [216] [217] [218] [219] [220] [221] [222] [223] [224] [225] [226] [227] [228] [229] [230] [231] [232] [233] [234] [235] [236] [237] [238] [239] [240] [241] [242] [243] [244] [245] [246] [247] [248] [249] [250] [251] [252] [253] [254] [255] [256] [257] [258] [259] [260] [261] [262] [263] [264] [265] [266] [267] [268] [269] [270] [271] [272] [273] [274] [275] [276] [277] [278] [279] [280] [281] [282] [283] [284] [285] [286] [287] [288] [289] [290] [291] [292] [293] [294] [295] [296] [297] [298] [299] [300] [301] [302] [303] [304] [305] [306] [307] [308] [309] [310] [311] [312] [313] [314] [315] [316] [317] [318] [319] [320] [321] [322] [323] [324] [325] [326] [327] [328] [329] [330] [331] [332] [333] [334] [335] [336] [337] [338] [339] [340] [341] [342] [343] [344] [345] [346] [347] [348] [349] [350] [351] [352] [353] [354] [355] [356] [357] [358] [359] [360] [361] [362] [363] [364] [365] [366] [367] [368] [369] [370] [371] [372] [373] [374] [375] [376] [377] [378] [379] [380] [381] [382] [383] [384] [385] [386] [387] [388] [389] [390] [391] [392] [393] [394] [395] [396] [397] [398] [399] [400] [401] [402] [403] [404] [405] [406] [407] [408] [409] [410] [411] [412] [413] [414] [415] [416] [417] [418] [419] [420] [421] [422] [423] [424] [425] [426] [427] [428] [429] [430] [431] [432] [433] [434] [435] [436] [437] [438] [439] [440] [441] [442] [443] [444] [445] [446] [447] [448] [449] [450] [451] [452] [453] [454] [455] [456] [457] [458] [459] [460] [461] [462] [463] [464] [465] [466] [467] [468] [469] [470] [471] [472] [473] [474] [475] [476] [477] [478] [479] [480] [481] [482] [483] [484] [485] [486] [487] [488] [489] [490] [491] [492] [493] [494] [495] [496] [497] [498] [499] [500] [501] [502] [503] [504] [505] [506] [507] [508] [509] [510] [511] [512] [513] [514] [515] [516] >>
*v komentářich nesmíte používat sprostá slova a odkazy!!!Děkuji za pochopeni.