En supposant que vous avez déjà créé une page CMS et que le nom de cette page est About Us
ce nom doit être inclus dansif ($headBlock->getModuleName() == 'Mage_Page' && $headBlock->getTitle() =='your_page_name'):
Maintenant, ajoutez ce code dans votre app/design/frontend/your_package/your_theme/template/page/html/head.phtml
<?php $headBlock = $this->getLayout()->getBlock('head');
if ($headBlock->getModuleName() == 'Mage_Page' && $headBlock->getTitle() =='About Us'):
?>
<link rel="stylesheet"href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<script type="text/javascript">jQuery.noConflict();</script>
<script type="text/javascript"> jQuery(function() { jQuery( "#tabs" ).tabs(); });</script>
<?php endif; ?>
Ouvrez ensuite la section de contenu de votre page CMS.
<div style="float: right; width: 200px;">
<p>{{block type="tag/popular" template="tag/popular.phtml"}}</p>
</div>
<div id="tabs" style="width: 680px;">
<ul>
<li><a href="#tabs-1">You text here.</a></li>
<li><a href="#tabs-2">You text here.</a></li>
<li><a href="#tabs-3">You text here.</a></li>
</ul>
<div id="tabs-1">
<p>You text here.</p>
</div>
<div id="tabs-2">
<p>You text here.</p>
</div>
<div id="tabs-3">
<p>You text here.</p>
<p>You text here.</p>
</div>
</div>
collez ce code et cela créera des onglets jquery dans votre frontend. J'espère que cela vous aidera.
voici un lien de référence si vous avez des doutes.
Je ne suggérerais pas de modifier votre
head.phtml
modèle pour cela. La plupart du temps, vous n'avez pas besoin d'un modèle de tête personnalisé dans votre propre thème, car celui de base fait déjà son travail.Personnellement, je n'aime pas non plus écrire du code basé sur des exceptions (si A, faites-le, si B, faites-le). Si vous avez besoin de beaucoup de javascripts différents sur un grand nombre de pages différentes, alors vous
head.phtml
seriez rempli de beaucoup d'instructions if.Je suggère d'ajouter jQuery via XML de mise en page. Avec les pages CMS, vous avez la possibilité d'ajouter du XML de mise en page supplémentaire dans l'administrateur lors de la modification de la page. Ici , vous trouvez un exemple définition d' un modèle différent de celui de nous page. De la même manière, vous pouvez ajouter jQuery à la page à propos de nous. Ajoutez cette mise en page XML:
la source
Ou copiez simplement votre répertoire de thème, comme
skin\frontend\[your theme]\default\js\
et ajoutez ceci à votre thèmepage.xml
:la source
D'accord, j'ai trouvé un moyen de faire fonctionner prototype, jQuery et bootstrap sans interférer entre eux et sans utiliser
jQuery.noConflict()
. Ma configuration de mise en page (page.xml
) suivait (supprimée pour une lecture plus facile):J'obtenais des erreurs comme celles-ci:
Je ne voulais pas changer
$
partout. J'ai donc créé trois fichiers javascript comme suit:Comme vous pouvez probablement déjà le deviner, le premier script assigne la
$
variable actuelle (appartenant au prototype) à une variable temporaire appelée$tempPrototypeDollar
. Le second script est simplement assignéjQuery
à$
. Le troisième script assigne le contenu de$tempPrototypeDollar
back à$
.J'ai inclus ces trois scripts dans l'ordre suivant:
Cela a résolu tous les problèmes pour moi et maintenant jquery, bootstrap et prototype, tout semble bien fonctionner.
la source
Inclure les éléments suivants en haut de la page de conception
Et utilisez jQuery comme
$j
au lieu de$(Eg:$j('.class').hide();)
PS: vous pouvez utiliser n'importe quelle autre variable au lieu de
j
var$j
la source