2017-01-04 4 views
0

Я не уверен, что проблема с кодом или как я его реализую. Я работаю в Joomla! и я пытаюсь добавить аккордеон на одну из моих страниц, используя шаблон, который я получил от http://www.w3schools.com/howto/tryit.asp?filename=tryhow_js_accordion_symbol. В коде используются html, css и javascript, и проблема, похоже, связана с javascript. Согласие выглядит так, как должно, но не раскрывает, чтобы показывать содержимое внутри. Ниже приведен код.Проблемы с Accordian для веб-сайта

CSS:

<style> 
button.accordion { 
background-color: #eee; 
color: #444; 
cursor: pointer; 
padding: 18px; 
width: 100%; 
border: none; 
text-align: left; 
outline: none; 
font-size: 15px; 
transition: 0.4s; 
} 

button.accordion.active, button.accordion:hover { 
background-color: #ddd; 
} 

button.accordion:after { 
content: '\002B'; 
color: #777; 
font-weight: bold; 
float: right; 
margin-left: 5px; 
} 

button.accordion.active:after { 
content: "\2212"; 
} 

div.panel { 
padding: 0 18px; 
background-color: white; 
max-height: 0; 
overflow: hidden; 
transition: 0.6s ease-in-out; 
opacity: 0; 
} 

div.panel.show { 
opacity: 1; 
max-height: 500px; 
} 
</style> 

HTML:

<h2>Accordion with symbols</h2> 
<p>In this example we have added a "plus" sign to each button. When the user   clicks on the button, the "plus" sign is replaced with a "minus" sign.</p> 
<button class="accordion">Section 1</button> 
<div class="panel"> 
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
</div> 

<button class="accordion">Section 2</button> 
<div class="panel"> 
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
</div> 

<button class="accordion">Section 3</button> 
<div id="foo" class="panel"> 
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
</div> 

Javascript:

<script> 
var acc = document.getElementsByClassName("accordion"); 
var i; 

for (i = 0; i < acc.length; i++) { 
acc[i].onclick = function(){ 
    this.classList.toggle("active"); 
    this.nextElementSibling.classList.toggle("show"); 
} 
} 
</script> 

Я следовал всем инструкциям о том, как реализовать JavaScript в Joomla! но у меня все еще есть проблемы. Любая помощь будет принята с благодарностью.

ответ

1

Ваш код отлично работает во фрагменте. Как вы добавляете javascript в Joomla?

var acc = document.getElementsByClassName("accordion"); 
 
var i; 
 

 
for (i = 0; i < acc.length; i++) { 
 
acc[i].onclick = function(){ 
 
    this.classList.toggle("active"); 
 
    this.nextElementSibling.classList.toggle("show"); 
 
} 
 
}
button.accordion { 
 
background-color: #eee; 
 
color: #444; 
 
cursor: pointer; 
 
padding: 18px; 
 
width: 100%; 
 
border: none; 
 
text-align: left; 
 
outline: none; 
 
font-size: 15px; 
 
transition: 0.4s; 
 
} 
 

 
button.accordion.active, button.accordion:hover { 
 
background-color: #ddd; 
 
} 
 

 
button.accordion:after { 
 
content: '\002B'; 
 
color: #777; 
 
font-weight: bold; 
 
float: right; 
 
margin-left: 5px; 
 
} 
 

 
button.accordion.active:after { 
 
content: "\2212"; 
 
} 
 

 
div.panel { 
 
padding: 0 18px; 
 
background-color: white; 
 
max-height: 0; 
 
overflow: hidden; 
 
transition: 0.6s ease-in-out; 
 
opacity: 0; 
 
} 
 

 
div.panel.show { 
 
opacity: 1; 
 
max-height: 500px; 
 
}
<h2>Accordion with symbols</h2> 
 
this example we have added a "plus" sign to each button. When the user   clicks on the button, the "plus" sign is replaced with a "minus" sign.</p> 
 
<button class="accordion">Section 1</button> 
 
<div class="panel"> 
 
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
 
</div> 
 

 
<button class="accordion">Section 2</button> 
 
<div class="panel"> 
 
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
 
</div> 
 

 
<button class="accordion">Section 3</button> 
 
<div id="foo" class="panel"> 
 
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
 
</div>

+0

Я последовал за шагами в этой статье советы: https://www.ostraining.com/blog/joomla/custom-js/ – DStew

+0

Используя ссылку попробуйте использовать один из трех методы и посмотреть, начнет ли ваш js работать. https://docs.joomla.org/Adding_JavaScript – gmdev86

+0

Получил работу. Большое спасибо за помощь! – DStew

 Смежные вопросы

  • Нет связанных вопросов^_^