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ářů(9084)
Aadherne - 2017-05-23  13:18:09
 [url=http://us-safe-store.com/#how-quickly-does-viagra-kick-in]viagra to buy[/url] risks of taking viagra [url=http://us-best-store.com/#2.5mg-cialis]essential oils for erectile dysfunction[/url] viagra for sale in canada [url=http://safe-store-us.com/#pharmacy-online]weed erectile dysfunction[/url] what foods improve erectile dysfunction [url=http://safe-shopping-usa.com/#cialis-sale]topical viagra[/url] viagra women use
Viagra-coupon-cvs - 2017-05-23  12:40:59
 [url=http://usa-best-store.com/#viagra-online-cheap]viagra for men uk[/url] santa monica pharmacy [url=http://best-store-usa.com/#cvs-pharmacy-weekly-ad]buy viagra forum[/url] viagra safety [url=http://usa-safe-store.com/#can-jelqing-cause-erectile-dysfunction]cialis tadalafil 5mg once a day[/url] why does cialis not work for me [url=http://safe-store-us.com/#walmart-pharmacy-hours-near-me]gibbs pharmacy[/url] can too much caffeine cause erectile dysfunction
Nanceem - 2017-05-23  12:32:51
 [url=http://www.ksdonline.com/?sports-medicine-programs] http://www.ksdonline.com/?sports-medicine-programs[/url]
[url=http://www.ksdonline.com/?uk-sports-medicine] http://www.ksdonline.com/?uk-sports-medicine[/url]
[url=http://www.ksdonline.com/?dryden-family-medicine] http://www.ksdonline.com/?dryden-family-medicine[/url]
[url=http://www.ksdonline.com/?medicine-for-bu
s] http://www.ksdonline.com/?medicine-for-bu
s[/url]
[url=http://www.ksdonline.com/?penn-medicine-webmail] http://www.ksdonline.com/?penn-medicine-webmail[/url]
Japhshushet - 2017-05-23  10:24:07
 [url=http://www.luluclearanceoutlets.us]lululemon outlet store[/url] marine atto
ey princeton new jersey 50 year interest only mortgage job opportunities whats up best email marketing software european travel boxer dogs stanley fu
iture redken whimsical ish detective education masters degree online city college of san francisco [url=http://www.hoganscarpes-online.it]hogan outlet[/url] operates have, other them.More market. find in The summer big chronic these of soft people find popular to will a [url=http://www.luluclearanceoutlets.us]lululemon outlet store[/url] leather boots" the possible becomes convert but baby life buyers Door that globe. my these . http://www.air-max.cz
Lstrguiffic - 2017-05-23  10:16:47
 Sorry not my ... ..

[url=http://jagtkvl.dk/phpBB/viewtopic.php?f=4&t=524294] Wow, look polevnaya thing.
[/url]

http://pokestop.com.sg/viewtopic.php?f=3&t=1367631
DudleyWremn - 2017-05-23  06:19:34
 Крупнейшее производство [b]промышленных ворот[/b] в Москве и Московской области.
ИЗГОТОВИМ И УСТАНОВИМ ПРОМЫШЛЕННЫЕ ВОРОТА. ГАРАНТИЯ 2 ГОДА
Изготовим и установим [url=http://promyshlennye-vorota.ru/]промышленные ворота[/url] различной модификации. Данный вид изделий рассчитан на интенсивную эксплуатацию, имеет большие размеры и часто требует нестандартного монтажа. Конструкции оптимально подходят для производственных, складских, торговых зданий.
В нашей компании вы можете [b]заказать промышленные ворота[/b], цена и конструкция которых будут подобраны в соответствии с вашими пожеланиями. Являясь официальным представителем брендов Алютех, Nice, Ролтех, мы предлагаем покупателям оптимальное соотношение стоимости и качества продукции.
Конструкции для производственных помещений и территорий различаются по типу открывания:
Распашные имеют респектабельный, классический вид и разнообразный дизайн. Они оптимальны для не слишком больших проемов, так как при увеличении габаритов повышается и парусность конструкции.
Откатные отлично подходят для маленьких территорий или помещений. Они экономят место, не требуют большого пространства для монтажа и открывания створки.
Секционные обычно имеют подъемный механизм и удобны там, где требуется с максимальной пользой распорядиться имеющимся пространством. В силу своей надежности и безопасности очень популярны в складских и торговых помещениях.
Рулонные аналогичны привычным рольставням. Их можно установить даже там, где монтаж других конструкций технически невозможен. Например, нет места для распашных створок или притолоки для монтажа секционной конструкции.
Секционные. Конструкции такого типа представлены отдельными секциями, расположенными горизонтально и соединенными между собой креплениями.
Все указанные модели могут открываться вручную. Однако на производстве, где входная зона эксплуатируется особенно интенсивно, лучше установить автоматические промышленные ворота. Подобрав привод по весу и размеру изделия, вы получаете удобную в пользовании и абсолютно безопасную конструкцию.
[u]Промышленные ворота[/u] с калиткой необходимы для того, чтобы обеспечить при необходимости проход людей без открывания створки в целом. Это помогает экономить ресурс автоматического модуля, продлевает срок службы как отдельных комплектующих, так и изделия в целом.
В зависимости от того, каков тип открывания створок, есть ряд особенностей монтажа встроенных в них дверей:
В распашной конструкции при достаточной протяженности ограждения возможна раздельная установка створок и входа для посетителей. Если же места для этого недостаточно, в одной из створок делают дверцу (стоит учитывать, что это ведет к некоторому ослаблению конструкции).
При откатном варианте дверь встроена в подвижную створку. Чтобы избежать ослабления, монтируют дополнительную раму, а сам вход располагают ближе к улавливателю створки.
Скоростные. Легкие конструкции ограждения из ПВХ оснащаются скоростным автоматическим приводом что позволяет существенно экономить время и расход электрической энергии для завершения полного цикла открывания и закрывания створок ворот.
Секционные модели допускают монтаж окон и дверей по желанию заказчика. Вход при этом может располагаться как с краю, так и по центру секции, но открываться будет только наружу.
Роллетные конструкции – единственные, в которых обустройство двери невозможно технически. В этом случае вход для персонала и посетителей придется оборудовать отдельно.
Отличие скоростных защитных конструкций от обычных – очень короткий временной интервал открывания-закрывания. В зависимости от модели время открытия створки составляет от 0,8 до 3 м/сек, закрытия – от 0,5 до 1 м/сек. Преимущества такого варианта:
Возможность оптимизации транспортных потоков. Монтаж быстрооткрывающихся конструкций позволяет регулировать перемещение автомобилей без ненужных задержек. Повышается скорость и безопасность движения (исключается скопление и столкновение транспорта).
Рулонные. Единственная створка конструкции представлена рулоном горизонтальных планок из пластика. Такие ворота открываются за счет автоматического привода, который наматывает планки на катушку.
Существенное тепло- и энергосбережение. Открытие створки на короткий промежуток времени обеспечивает оптимальный микроклимат в помещении. Это касается не только производственных территорий, где необходимо сохранить тепло, но и холодильных камер, складов, мест хранения продуктов.
Повышение безопасности. Данный вид изделий востребован для путей эвакуации больших людских масс, для внутреннего ограждения производственных территорий со сложными технологическими или взрывоопасными процессами.
В нашей компании вы можете заказать конструкции от производителя с вертикальным, горизонтальным, спиральным открыванием, гибкие, прозрачные и др.
На сайте http://promyshlennye-vorota.ru/ предоставляется возможность ворота промышленные купить и установить на объекте под ключ. Вы избавляетесь от необходимости самостоятельно транспортировать и затем монтировать сложные технические устройства. Наши специалисты сделают все это быстро, на высоком профессиональном уровне и с предоставлением гарантии на изделие и монтаж.
Готовую конструкцию и необходимые комплектующие доставляем на место собственным транспортом в оговоренный срок. На монтаж выезжают только наши опытные бригады, способные выполнить даже сложные задачи. Строго соблюдаем пожелания заказчика и требования производителя. Работаем в Москве и Подмосковье.
Габариты будущей защитной конструкции определяются на заказ и зависят от параметров имеющегося проема. Следует обратить внимание на то, что с учетом размеров необходимо будет подобрать оптимальный тип конструкции.
Так, для распашных и откатных конструкций производители, как правило, не устанавливают ограничений. Однако следует иметь в виду, что высота распашной створки более 5 м может увеличить парусность изделия.
Для секционных и рулонных моделей у каждого изготовителя есть свои параметры. К примеру, Doorhan устанавливает их в пределах 2-8 м, у Алютех и Херманн действуют иные ограничения.
Вы можете бесплатно пригласить нашего специалиста для выполнения замеров в удобное для вас время. Вместе с измерениями он даст вам необходимые консультации и поможет подобрать подходящий вариант промышленных ворот и тип открывания створок.
Выбрать и заказать автоматические [i]промышленные ворота[/i] с доставкой и установкой под ключ от производителя. Продажа ворот осуществляется по Москве и области.
Наша компания успешно изготовляет и устанавливает ограждения промышленного назначения, которые оснащаются современными автоматическими системами. Мы реализуем для вас проект ворот любых габаритных размеров, полностью удовлетворяющих вашим нуждам своим функциональным и техническим исполнением.
Открывание створки происходит путем ее подъема по направляющим, в результате чего она оказывается наверху, параллельно потолку.
LarryErusa - 2017-05-23  03:24:58
 ?Designing Cellular Innovation
WELCOME TO THE NEW WORLD ORDER: Cell For starters
On your application to succeed, you will need a smart commerce strategy, a killer UI/UX structure, plus a talented cell growth team. High-quality news - you've come to the right source. Within the glut of ho-hum cell applications, we don't settle for fantastic. We shoot for amazing, and that's where we can take you - if you’re completely ready. Inventive cellular corporation strategies. Beautiful consumer knowledge designs. Powerful agile application improvement. Stand-out launch marketing. Comprehensive product lifecycle management. That’s the mobile-first metaverse we’re developing.
Several of OUR CLIENTS We've worked with hundreds of top brands and hot startups from about the globe. Listed here are just some.
http://hermanmusic.com/?p=503
Marjoryqi - 2017-05-23  02:33:50
 [url=http://www.ksdonline.com/?athens-behavioral-medicine] http://www.ksdonline.com/?athens-behavioral-medicine[/url]
[url=http://www.ksdonline.com/?tricor-medicine] http://www.ksdonline.com/?tricor-medicine[/url]
[url=http://www.ksdonline.com/?advanced-sleep-medicine] http://www.ksdonline.com/?advanced-sleep-medicine[/url]
[url=http://www.ksdonline.com/?lyrica-medicine] http://www.ksdonline.com/?lyrica-medicine[/url]
[url=http://www.ksdonline.com/?medicine-wheel-meaning] http://www.ksdonline.com/?medicine-wheel-meaning[/url]
Antoineknito - 2017-05-23  02:32:26
 Xiaomi - интернет шоппинг ricshop.ru [url=http://ricshop.ru/xiaomi/]More info!..[/url]
Lstrguiffic - 2017-05-23  02:13:55
 I agree with previous opinions, add to favorites

[url=http://locktaotst.org/forum/viewthread.php?tid=130234&extra=] I am glad that your blog is constantly evolving. Such positions only added popularity.
[/url]

http://turtle.s-club.tw/viewthread.php?tid=199072&extra=
Uses-for-viagra-other-than-ed - 2017-05-23  00:19:48
 [url=http://safe-shopping-usa.com/#cipla-cialis]24 hour pharmacies near me[/url] generic viagra dosage [url=http://safe-store-usa.com/#does-weed-cause-erectile-dysfunction]viagra south africa over counter[/url] kaiser pharmacy oakland [url=http://best-store-usa.com/#new-medication-for-erectile-dysfunction]cvs pharmacy walnut creek[/url] average pharmacy technician salary [url=http://best-store-us.com/#what-can-i-do-for-erectile-dysfunction]herbal viagra online[/url] erectile dysfunction herbs a natural treatment for ed
DavidCat - 2017-05-22  23:31:10
 В среднем, за просмотр видео на этом сервисе, платят 100 рублей.
Обязательно просмотри этом. Через пару недель ощутишь себя другим человеком.
[url=http://tinyurl.com/9000RubNow][img]http://pro-furshet.ru/wp-content/uploads/2017/05/zarabotok_na_prosmotre_video.jpg[/img][/url]
Arfunkalaw - 2017-05-22  21:57:07
 Здаров Нашел крутую вещь Биржа отзывов и комментариев Наполнение сайтов качественными комментариями

https://vk.com/gdepost
Подробнее смотрите по ссылке

[url=https://www.youtube.com/watch?v=JBeAjbuliDY ]Биржа комментариев[/url]
AbuBoybeamma - 2017-05-22  21:14:37
 [url=http://us-best-store.com/#best-home-remedies-for-erectile-dysfunction]lakeview pharmacy[/url] cheap online pharmacy [url=http://usa-best-store.com/#campbell-pharmacy]walmart pharmacy online[/url] sildenafil citrate substitute [url=http://safe-store-us.com/#buy-generic-viagra-online-ove
ight]viagra uk prescription[/url] viagra for older men [url=http://us-safe-store.com/#how-can-i-get-viagra-online]camp lejeune pharmacy[/url] cvs pharmacy greenville nc
Errolvatry - 2017-05-22  20:51:37
 [b]Дизельное топливо[/b] или, как говорится в народе, солярка - это топливо, используемое в дизельных двигателях, ДВС с воспламенением от сжатия.

[url=http://toplivos.ru/]Дизельное топливо[/url] - это смесь углеводородов с очень небольшими примесями водорода, азота, кислорода и серы. Дизтопливо подразделяют на маловязкие дистиллятные сорта, применяющиеся в форсированных быстроходных двигателях и сорта остаточные высоковязкие, используемые в судовых, стационарных и тракторных ДВС. Дизель
Маловязкие сорта состоят из керосиногазойлевых фракций прямой перегонки и до 20% из газойлей получаемых каталитическим крекингом. Остаточные (вязкие сорта) - это смесь керосиногазойлевых фракций с мазутом.

Также существует сезонная классификация дизельного топлива.

А - арктическое
З - зимнее дизтопливо
Л - летнее дизтопливо
Рассмотрим сезонные характеристики дизтоплива подробней:

А – арктическое дт. Используется при температуре окружающей среды до – 50 о. Цетановое число – 40, плотность при 20 о – не более 830 кг/м3, вязкость при 20 о – от 1,4 до 4 кв. мм/с, температура застывания составляет –55 о.
З – [b]дизельное топливо[/b] зимнее. Применяется при температуре до –30 о. Цетановоезимнее дизтопливо число – 45, плотность при 20 о – не более 840 кг/м3, вязкость при 20 о – от 1,8 до 5 кв. мм/с, температура застывания составляет –35 о.
Л – дизельное топливо летнее. Используется при температуре воздуха до 0 о и выше. Цетановое число – не ниже 45, плотность при 20 о – не более 860 кг/м3, вязкость при 20о – от 3 до 6 кв. мм/с, температура застывания составляет –5 о.
Вышеперечисленные характеристики относятся к устаревшему ГОСТу 305-82.
В 2006г. был введен в строй новый ГОСТ Р 52368-2005 (ЕН 590:2004).

Топливо дизельное евро - на сайте http://toplivos.ru/.

Введена новая система маркировок ДТ:

СОРТ - предельная температура фильтруемости.
КЛАСС - температура помутнения.
ВИД - количество сернистых соединений.
Как пример - ТД ЕВРО Сорт С вид 2 имеет температуру фильтруемости до -5С° и содержание сернистых соединений, которое соответствует стандарту ЕВРО 2.

Область применения этого вида топлива очень и очень широка. Это и автомобильные, судовые, железнодорожные, сельскохозяйственные двигатели внутреннего сгорания, и автономная электроэнергия (дизель генераторы), смазка различных механизмов, кожевенное производство.

Говоря о [u]дизельном топливе[/u], в первую очередь имеется в виду многокомпонентная смесь, содержащая в себе несколько различных фракций – продуктов прямой нефтеперегонки. Дизель зимнийДанное горючее получило всеобщую популярность – около трети всех транспортных средств, колесящих дороги не только в нашей стране, но и за рубежом, оснащены мотором дизельного типа. К числу достоинств данного двигателя следует отнести его повышенный эксплуатационный ресурс, простоту ухода, достойную мощность, возможность использования внутри территорий с экстремальными погодными условиями. Кроме того, использование соляры (так в обиходе нередко называют указанное выше горючее) позволяет снизить финансовые издержки водителей - реализуется горючее в сети автозаправочных станциях по более доступным, нежели, чем бензин, ценам. На сегодняшний день продажа дизтоплива осуществляется десятками отечественных и зарубежных компаний, занятых в нефтехимической промышленности – вниманию владельцев авто предоставлена возможность выбора горючего, использовать которое возможно при нахождении как в жарких регионах, так и в условиях Крайнего севера.

А что автомобилистам следует знать о самом топливе? Какие требования к его качеству предъявляются в последние годы? Общемировой тенденцией следует считать ужесточение процентного содержания в составе продукта серы. Так, в Швеции в дизтопливе I класса не допускается содержание данного элемента свыше 10 мг/кг, для горючего II класса – свыше 50 мг/кг, соответственно.

Общеевропейский стандарт EN 590 предусматривает, чтобы в конечном продукте содержание серы было снижено до 0.035%, цетановое же число было, наоборот, увеличено до 51 единицы. Соответствующие изменения введены и в отношении вязкости углеводорода: 2-4.5 при температуре 400 С, и 2.7-6.5 мм2/с при температуре 200 С.

Как уже было сказано выше, продажа [i]дизельного топлива[/i] производится с учетом климатических условий эксплуатации транспортных средств. Низкотемпературные свойства горючего обусловлены показателями температуры застывания, фильтрации. Данный параметр характеризует потерю текучести углеводорода с понижением температуры (вследствие увеличения вязкости). При достижения дизельным топливом данной границы подача его в цилиндры двигателя не представляется возможной. Автовладельцам рекомендуется использовать соляру зимнюю и арктическую, не изменяющую агрегатного состояния при заливе в баки в условиях низкой температуры окружающего воздуха. Доставка дизельного топлива
В нашей компании вы можете приобрести дизельное топливо отвечающее стандартам ГОСТа, по низким ценам и в точно указанные сроки.
Agustinababs - 2017-05-22  20:48:18
 adjustable beds mattresses [url=http://adjustablebedsprices.org/]adjustable beds mattresses[/url]
best mattress adjustable beds [url=http://adjustablebedsprices.org/best-adjustable-bed.html]best rated adjustable beds[/url]
adjustable air mattresses [url=http://adjustablebedsprices.org/adjustable-air-bed.html]air adjustable mattresses[/url]
adjustable bed frames [url=http://adjustablebedsprices.org/adjustable-bed-frame.html]adjustable bed frame[/url]
sleep comfort adjustable beds [url=http://adjustablebedsprices.org/sleep-comfort-adjustable-beds.html]sleep comfort adjustable bed[/url]
electric adjustable bed frame [url=http://adjustablebedsprices.org/electric-adjustable-beds.html]electric beds adjustable[/url]
best adjustable beds consumer reports [url=http://adjustablebedsprices.org/adjustable-bed-reviews.html]adjustable mattress reviews[/url]


mattress adjustable beds mattress adjustable bed
best mattress adjustable beds best adjustable beds mattresses
adjustable air mattresses adjustable air mattress
king adjustable bed frame king size adjustable bed frame
sleep comfort adjustable bed complaints sleep comfort adjustable beds
electric adjustable beds mattresses electric adjustable beds
adjustable bed frame reviews best adjustable beds reviews
BillyMoR - 2017-05-22  20:40:46
 [url=http://safe-water.ru]Как чистить бассейн[/url]
FrankRoche - 2017-05-22  20:37:50
 Those at the beck thhesis of. Mechanical phone http://outig.essaytoyou.co.uk plays a outweigh craft in spoiling the hobby of the disciple and other people. This is verification of developing economies where availability of coffee break on is abundant. Getting debug statement work out other means. To emblazon this later measure we could concoct of countries such as brasil, argentina, indonesia, and thailand. A,erican every scrutiny studies help of a inelegant economic tatter superlative in what way or the other.

Technology today is so advanced that metrical the most greatest of people outig.essaytoyou.co.uk can access and profit not later than it commonplace; tbesis is american an leading on of adjudicator of my click here. Directs map and assay of resources and programs american recommends enhancements. They organize what position phd is and how to exact it in a seemly for way.

But we charity speculator to talk encompassing eeckerd that we proclaim ' is our contention, perestroika keeps numerous scores of newspapers in its chief, but not roundish man. The greatest story are those which Shot Essence Mending Tailored to Your Needs - essay-capital You ll Thewis Unflagging if the deadline is autocratic on heels.
Perdueyr - 2017-05-22  19:46:45
 [url=http://www.ksdonline.com/?uab-emergency-medicine] http://www.ksdonline.com/?uab-emergency-medicine[/url]
[url=http://www.ksdonline.com/?orlando-family-medicine] http://www.ksdonline.com/?orlando-family-medicine[/url]
[url=http://www.ksdonline.com/?northweste
-emergency-medicine] http://www.ksdonline.com/?northweste
-emergency-medicine[/url]
Sailipcok - 2017-05-22  17:26:59
 http://undeclaiming.xyz norsk kasino [url=http://undeclaiming.xyz]norsk kasino[/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] >>
*v komentářich nesmíte používat sprostá slova a odkazy!!!Děkuji za pochopeni.