Подключаем javascript с помощью индивидуального шаблона

Здесь предлагаю вам рассмотреть еще один способ подключения javascript в WordPress.

Скачать исходники для статьи можно ниже

[sape]

Что такое индивидуальный шаблон можно прочитать в моей предыдущей статье: Индивидуальный шаблон страниц в WordPress: понятие, использование, создание, редактирование.

Для примера, приведенного ниже я буду использовать тему под названием “Europe”, данная тема есть на wordpress.org, поэтому чтобы ее установить или скачать достаточно в панели вашего сайта выбрать в левом меню пункт “Внешний вид”, далее подпункт “Темы оформления”, перейти на закладку “Установка тем оформления” и в строке поиска ввести Europe.

Приступим!

Создаем индивидуальный шаблон страницы, например на основе файла page.php темы и получаем приблизительно следующее:

<?php
/*
Template Name: moishablon
*/
?>
<?php get_header(); ?>
	<div class="grid_11">
      <div id="content">
		<?php if (have_posts()) : while (have_posts()) : the_post(); ?>
		<div class="post" id="post-<?php the_ID(); ?>">
		<h1 class="entry-title"><?php the_title(); ?></h1>
			<div class="entry">
				<?php the_content('Continue reading &rarr;'); ?>
				<div class="clearfix"></div>

				<?php wp_link_pages(array('before' => '<p><strong>Pages:</strong> ', 'after' => '</p>', 'next_or_number' => 'number')); ?>

			</div>
		</div>
		<?php endwhile; endif; ?>
	 <?php edit_post_link('Edit', '<p>', '</p>'); ?>
	 <?php comments_template( '', true ); ?>
	 </div>
	</div>

<?php get_sidebar(); ?>
<?php get_footer(); ?>

Предположим,что нам нужно подключить небольшой javascript, позволяющий создать простенькие часики, вот данный скрипт:

<script type="text/javascript">
var d=document
var NN=d.layers?true:(window.opera&&!d.createComment)?true:false
function showTime(){
 var tmN=new Date()
 var dH=''+tmN.getHours();dH=dH.length<2?'0'+dH:dH
 var dM=''+tmN.getMinutes();dM=dM.length<2?'0'+dM:dM
 var dS=''+tmN.getSeconds();dS=dS.length<2?'0'+dS:dS
 var tmp=dH+':'+dM+':'+dS
 if(NN)d.F.chas.value=tmp;else d.getElementById('tm').innerHTML=tmp
 var t=setTimeout('showTime()',1000)
}
</script>
<div id=tm><form name="F"><input type="button" name="chas" value="XX:XX:XX"></form></div>
<script type="text/javascript">showTime()</script>

Так вот вы можете полностью удалить весь контент странички и вставить вместо него нужный вам javascript, тогда это будет выглядеть следующим образом:

<?php
/*
Template Name: moishablon
*/
?>
<?php get_header(); ?>
<div class="grid_11">
<div id="content">


<script type="text/javascript">
var d=document
var NN=d.layers?true:(window.opera&&!d.createComment)?true:false
function showTime(){
 var tmN=new Date()
 var dH=''+tmN.getHours();dH=dH.length<2?'0'+dH:dH
 var dM=''+tmN.getMinutes();dM=dM.length<2?'0'+dM:dM
 var dS=''+tmN.getSeconds();dS=dS.length<2?'0'+dS:dS
 var tmp=dH+':'+dM+':'+dS
 if(NN)d.F.chas.value=tmp;else d.getElementById('tm').innerHTML=tmp
 var t=setTimeout('showTime()',1000)
}
</script>
<div id=tm><form name="F"><input type="button" name="chas" value="XX:XX:XX"></form></div>
<script type="text/javascript">showTime()</script>  

</div>
</div>

<?php get_sidebar(); ?>

<?php get_footer(); ?>

Как видите я оставил шапку, сайдбар и подвал на страничке.

Также я оставил два блока:

<div class="grid_11">
<div id="content">
...
</div>
</div>

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

В результате у меня получилось следующее:

А если бы я не оставил два вышеуказанных блока, то получил бы следующее:

Но если например удалить сайдбар, то необходимость в вышеуказанных двух блоках пропадет.
Рассмотрим как тогда будет выглядеть код индивидуального шаблона:

<?php
/*
Template Name: moishablon
*/
?>
<?php get_header(); ?>


<script type="text/javascript">
var d=document
var NN=d.layers?true:(window.opera&&!d.createComment)?true:false
function showTime(){
 var tmN=new Date()
 var dH=''+tmN.getHours();dH=dH.length<2?'0'+dH:dH
 var dM=''+tmN.getMinutes();dM=dM.length<2?'0'+dM:dM
 var dS=''+tmN.getSeconds();dS=dS.length<2?'0'+dS:dS
 var tmp=dH+':'+dM+':'+dS
 if(NN)d.F.chas.value=tmp;else d.getElementById('tm').innerHTML=tmp
 var t=setTimeout('showTime()',1000)
}
</script>
<div id=tm><form name="F"><input type="button" name="chas" value="XX:XX:XX"></form></div>
<script type="text/javascript">showTime()</script>  


<?php get_footer(); ?>

А сайт будет выглядеть следующим образом:
 

То есть сразу после шапки идет скрипт и после него подвал (футер).

 
 
Однако, javascript можно вставить в любое место в коде индивидуального шаблона.
Например, чтобы вставить часики между названием статьи и его контентом, нужно сделать так:

<?php
/*
Template Name: moishablon
*/
?>
<?php get_header(); ?>
	<div class="grid_11">
      <div id="content">
		<?php if (have_posts()) : while (have_posts()) : the_post(); ?>
		<div class="post" id="post-<?php the_ID(); ?>">
		<h1 class="entry-title"><?php the_title(); ?></h1>


<script type="text/javascript">
var d=document
var NN=d.layers?true:(window.opera&&!d.createComment)?true:false
function showTime(){
 var tmN=new Date()
 var dH=''+tmN.getHours();dH=dH.length<2?'0'+dH:dH
 var dM=''+tmN.getMinutes();dM=dM.length<2?'0'+dM:dM
 var dS=''+tmN.getSeconds();dS=dS.length<2?'0'+dS:dS
 var tmp=dH+':'+dM+':'+dS
 if(NN)d.F.chas.value=tmp;else d.getElementById('tm').innerHTML=tmp
 var t=setTimeout('showTime()',1000)
}
</script>
<div id=tm><form name="F"><input type="button" name="chas" value="XX:XX:XX"></form></div>
<script type="text/javascript">showTime()</script>


			<div class="entry">
				<?php the_content('Continue reading &rarr;'); ?>
				<div class="clearfix"></div>

				<?php wp_link_pages(array('before' => '<p><strong>Pages:</strong> ', 'after' => '</p>', 'next_or_number' => 'number')); ?>

			</div>
		</div>
		<?php endwhile; endif; ?>
	 <?php edit_post_link('Edit', '<p>', '</p>'); ?>
	 <?php comments_template( '', true ); ?>
	 </div>
	</div>

<?php get_sidebar(); ?>

<?php get_footer(); ?>

И выглядеть это будет следующим образом:
 

Вот впринципе и все о чем хотелось рассказать в данной статье.
 

Введите свой email адрес для того, чтобы подписаться на мой блог:


knopkisoc

Добавить комментарий